Système embarqué TCP/IP

De Wiki d'activités IMA

Présentation

Le but de ce projet est principalement de réaliser un système embarqué TCP/IP, qui pourrait représenter grâce aux LEDs ou à des moulins à vent la charge sur les différents commutateurs de l'école, décrivant ainsi l'activité de ces derniers.

Préparation du projet

Matériel requis

  • microcontroleur [Arduino Duemilanove] (disponible) ;
  • LEDs multicolores (disponibles) ;
  • moulins à vent avec moteur à courant continu : nous augmenterons la tension d'alimentation des moteurs proportionnellement à l'occupation des switch ; (commande annulée)
  • plateforme Altium ;
  • un module ELZ50 [1] (disponible).
  • l'Ether card de Jeelabs
  • Matrice de leds 8*8

Commentaires des encadrants sur le matériel

Préciser le dispositif "moulin à vent". En particulier, ils doivent être motorisés (comment ?). Vous devez aussi vous préoccuper de la commande des moteurs, ce qui impactera l'architecture à implémenter sous Altium.

Avancement du projet

Objectifs suggérés par les encadrants pour la prise en main du sujet

  • Ecrire un programme avec les fichiers fournis permettant dans un premier temps de créer une machine virtuelle répondant à la commande ping :
    • nettoyer les fichiers fournis pour enlever toute référence aux sockets Unix ou Internet ; FAIT
    • réaliser des fonctions de lecture et d'écriture pour une interface TAP ; FAIT
    • écrire une procedure main réalisant les actions suivantes :
      • initialisation d'une variables de pile TCP/IP (type netstack) ; FAIT
      • création d'une interface de type TAP avec les fichiers libtap.c et libtab.h fournis ; FAIT
      • écriture d'un "pilote" pour cette interface (c'est à dire remplissage d'une structure avec le descripteur lié à l'interface et les fonctions de lecture et d'écriture sur l'interface TAP) ;
      • ajout d'une interface réseau et d'une adresse IP à cette pile (par exemple 192.168.0.100/24) ; FAIT
      • démarrage de la fonction de gestion de la pile (stackOn). FAIT
  • Test de votre programme; lancement du programme, ajout d'une adresse IP (par exemple 192.168.0.200/24) sur l'interface tap0 créée par le programme, test de réponse de la pile par la commande ping (par exemple sur l'adresse 192.168.0.100). FAIT

Objectifs progressifs

Partie Informatique

  • Faire du profiling d'utilisation d'espace mémoire afin de voir de quelle taille il faudrait réduire le programme pour qu'il soit portable sur un arduino FAIT
  • Tester une ou deux fonctions sur l'arduino pour savoir qu'est-ce-qu'il faut changer dans le code FAIT
  • Inclure les fichiers en-tête de la librairie stack FAIT
  • Créer un fichier de compilation, makefile propre à l'arduino FAIT
  • Répartir l'analyse des différentes couches des trames
    • Reception d'un paquet Ethernet sur l'arduino FAIT
    • Reception d'un paquet ARP: fonction programmee
    • Reception d'un paquet IP: fonction programmee
    • Reception d'un paquet ICMP: fonction pragrammee
    • Tests fonctions: FAIT
    • Programmer une fontion avec une variable locale pour le paquet (trames ethernet contenant toutes les couches) FAIT
    • Supprimer les tableaux de paquets et utiliser plutôt des pointeurs FAIT
    • Augmenter la table ARP FAIT
    • Faire la reception et le renvoi d'une trame ethernet en test FAIT
  • Communication par liaison série
    • Modifier les fonctions pour recevoir et envoyer des paquets par liaison serie FAIT
    • Allumer une led lorsqu'on reçoit un paquet FAIT
    • Eteindre la led lorsque le paquet reponse est envoyé
    • Instancier une variable globale "echo" pour gerer la led multicolore FAIT
    • Changer la couleur de la led RVB en fonction de la taille du paquet reçu
  • Perspectives
    • Créer une fonction de renvoi des paquets Ethernet reçus qui contiendra une variable Packet dans laquelle seront stockés les en-têtes dudit paquet pour l'optimisation d'espace mémoire à l’exécution du programme sur l'arduino
  • Matrice de leds
    • Ecrire une routine pour réaliser un effet graphique en fonction de l'événement repéré: envoi/réception de paquets par liaison série ou en réseau FAIT
  • Module EZL60
    • ecrire un programme permettant à l'arduino d'envoyer et de recevoir des paquets par liaison série vers le module (module finalement non utilisé)

Partie Électronique

  • Concevoir le module d'émission/réception de la plate-forme altium vers l'arduino des trames Ethernet.

Note : Dans un premier temps, les tests sont fait avec un petit exécutable développé pour récupérer et envoyer des octets avec un adaptateur USB-Série sur un ordinateur. Dans un second temps, il faudra adapter ce code C pour faire deux fonctions intégrées à l'Arduino.

  • Architecture matérielle FAIT
  • Émission seule FAIT
    • Récupération d'un paquet Ethernet FAIT
    • Émission du paquet sur la liaison série FAIT
  • Réception seule
    • Récupération d'un paquet Ethernet en série FAIT
    • Émission de la requête sur la liaison Ethernet FAIT
  • E/R simultanés
    • Processus Multithreadé FAIT
    • Éventuellement : Gestion de la ressource avec un sémaphore
  • Réception sur l'Arduino
    • Portage du code C de réception sur l'Arduino
    • Gestion de la simultanéité E/R
  • Concevoir le module de réception des commandes actionneur de l'arduino

Difficultés rencontrées

  • Partie Informatique
    • Comprendre le code fourni et savoir se servir des fonctions
    • Comprendre la syntaxe d'un makefile avec le compilateur avr dude et une édition de liens entre fichiers codés en C et ceux codés en C++,et maîtriser la compilation modulaire sur l'arduino (impossibilité d'inclure certaines bibliothèques du C)
    • Saisir la particularité du compilateur avr-dude dans le traitement de types de données tels "long int" qui sont tronqués; solution: on a utilisé des "short int"
    • Gérer la communication par liaison série avec l'arduino à l'aide de thread ( bibliothèque time)
  • Partie Électronique
    • Conception de l'architecture matérielle avec un buffer associé à la liaison Ethernet
    • Décomposition de la taille du paquet Ethernet (short int = 2 octets) en deux paquets d'un octet chacun, et récupération des deux premiers paquets sur l'arduino pour reconstruire la taille du paquet.