IMA4 2018/2019 P1

De Wiki de Projets IMA
Révision datée du 23 octobre 2018 à 17:22 par Qboens (discussion | contributions) (Calendrier prévisionnel)


Présentation générale

Description

L'objectif de ce projet est de concevoir et réaliser des manettes à base de micro-contrôleurs, pour des travaux pratiques GIS3 et IMA4.

Chaque manette devra utiliser un protocole de communication différent de l'autre.

Objectifs

La première manette devra être conçue pour pouvoir communiquer via le protocole UDP.

La seconde, sera détectée par le PC comme un périphérique USB, plus précisément de type HID.

Préparation du projet

Cahier des charges

Chaque manette comportera 10 LEDS, qui serviront à indiquer le bon fonctionnement de l'objet. On trouvera également 5 boutons et 2 vibreurs.

La première manette sera semblable à une Arduino Uno, avec un micro-contrôleur ATMega328p et un FTDI. Elle devra se comporter comme un périphérique IP. Grace à une communication série, en protocole UDP, il devra être possible de contrôler les LEDs situées sur la manette. Elle devra également être capable de renvoyer l'état des boutons, par sollicitation du PC.

Pour la seconde, une plateforme Arduino Leonardo et un micro-contrôleur ATMega16u2 seront utilisés. En utilisant la bibliothèque LUFA, il sera possible de la programmer pour qu'elle corresponde à un périphérique USB. J'ai déjà utilisé cette dernière, lors d'un tutorat durant le semestre 7.

Choix techniques : matériel et logiciel

Pour ce projet, il m'est possible de me baser sur les réalisations d'autres élèves, dans le cadre d'épreuves complémentaires. Je réutiliserai donc leur matériel, auquel j'ajouterai le mien, dans le cas où des modifications doivent êtres apportées.

Liste du matériel :

Manette 16u2 Manette 328p
LED rouge x12 LED rouge x12
Résistance 10kOhm x6 Résistance 10kOhm x6
Varistances x2
Résistance 22Ohm x2
Résistance 220Ohm x12 Résistance 220Ohm x12
Résistance 1kOhm x2 Résistance 1kOhm x4
Résistance 1MOhm x1 Résistance 1MOhm x1
Capacité 100nF x1 Capacité 100nF x 6
Capacité 22pF x2 Capacité 22pF x2
Capacité 1µF x1
XTAL 16MHz x1 XTAL 16MHz x1
Transistor Bipolaire NPN x2 Transistor Bipolaire NPN x2
Diode Melf DO-213 x4 Diode Melf DO-213 x2
Sparkfun isp header 6 broches x1 Sparkfun isp header 6 broches x1
Switch boitier THT x5 Switch boitier SMD x5
Switch boitier smd x1 Switch boitier smd x1
USB-miniB-smd-ns x 1 USB-miniB-smd-ns x 1
Vibreur (Sparkfun motor) x2 Vibreur (Sparkfun motor) x2
Atmega 16u2 x1 Atmega 328p x1

Liste des tâches à effectuer

Comme je l'ai expliqué plus haut, j'ai à ma disposition les projets réalisés par d'autres étudiants en épreuve complémentaire. Cependant, une phase de test sur les PCB doit être effectuée, afin de vérifier leur bon fonctionnement.

Après avoir discuté avec Mr Redon, celui ci m'a indiqué que la manette FTDI n'était pas fonctionnelle. En effet, le FTDI n'est pas connecté correctement, ce qui fait que la manette n'arrive pas à communiquer avec le PC. J'ai donc prévu de corriger le PCB, en me basant sur la datasheet du FTDI (modèle FT232BL), afin de résoudre le problème. De plus, certaines LEDs ne sont pas correctement connectées au micro-contrôleur. Il faudra également que je corrige ce point sur le PCB.

La manette 16u2 n'avait pas été testée l'année précédente. Par conséquent, il me faudra vérifier son bon fonctionnement, pour ensuite apporter des modifications si nécessaire.

Une fois les deux manettes corrigées, je passerai à la programmation. Je commencerai par la manette FTDI, afin que celle-ci puisse communiquer en UDP avec le PC.

Puis je terminerai par programmer la manette 16u2, afin quelle puisse communiquer en me basant sur la bibliothèque LUFA.

Calendrier prévisionnel

Les trois premières semaines seront consacrés aux tests, et corrections, des PCB crées lors des épreuves complémentaires.

Pour les semaines qui suivront, l'attention sera portée sur la manette FTDI, afin quelle se comporte comme un périphérique IP.

Enfin je me consacrerai à la deuxième manette, pour qu'elle soit détectée en tant que périphérique USB par le PC.

Réalisation du Projet

Feuille d'heures

Tâche Prélude Heures S1 Heures S2 Heures S3 Heures S4 Heures S5 Heures S6 Heures S7 Heures S8 Heures S9 Heures S10 Total
Analyse du projet 3h 3h
Manette 1 : 328P
1 - PCB 9h 3h 12h
2 - Programme manette 8h 14h 22h
3 - Programme PC
Manette 2 : 16u2
1 - PCB 6h 6h
2 - Programme manette
3 - Programme PC
Autres
1 - Gestion du Wiki 2h 3h 1h 1h 7h
TOTAL 3h 11h 12h 9h 15h 50h

Prologue

Planning

Planning (V2.1) de réalisation du projet

Semaine 1

Manette 1 - 328p

  • Réalisé

Pour cette première semaine, je me suis concentré sur la correction des erreurs dans le PCB de la manette FTDI. En comparant avec la datasheet, j'ai constaté que plusieurs éléments manquaient, notamment des résistances.

En examinant le PCB, j'ai aussi observé que les PINs RX et TX du FTDI étaient reliés, respectivement, aux PINs RX et TX du micro-contrôleur. Cette erreur est de loin la plus importante, puisque la communication entre le FTDI et l'atmega ne peut pas s'effectuer correctement.

Semaine 2

Manette 1 - 328p

  • Réalisé

J’ai terminé le routage de la manette.

Avec l’aide de Mr Redon, j’ai pu corriger les problèmes que j’ai rencontrés. Il s’agissait notamment de fils volants, dont j’ignorais l’origine et que je n’arrivais pas à supprimer, sans provoquer de nouvelles erreurs.

  • Difficultés rencontrées

Fritzing : problèmes de raccordements de composants. Vu avec Mr Redon (cf ci-dessus).

  • Prochaines actions semaine 3

Démarrer la programmation de la manette.

Contacter Mr Redon afin de faire imprimer la manette 328p.

Je vais également voir, si je peux obtenir une plaque Arduino utilisée par les GIS et IMA lors de leurs TPs. Ainsi je pourrai tester mes programmes, sans devoir attendre la fabrication de mes manettes.

Manette 2 - 16u2

  • Réalisé

En voulant souder les composants à ma disposition sur la manette, je me suis rendu compte que la version du schéma de routage et la manette à ma disposition ne correspondent pas. Le fichier du schéma est en version 5. La manette est fabriquée selon une version au 7, elle-même modifiée.

Pour cette raison, il me manque certains composants, que je n’ai pas commandés auprès de Mr Redon. Je l’ai donc prévenu avant qu’il ne valide les commandes de matériel.

J’ai soudé quelques composants, qui sont communs aux deux versions : le connecteur USB, le Quartz et les capacités nécessaires au Quartz.

  • Difficultés rencontrées

Différences entre la manette et le schéma de routage, donc manque de composants.

  • Prochaines actions semaine 3

Comme pour la manette 1, essayer d’obtenir une plaque Arduino utilisée par les GIS et IMA lors de leurs TPs.

Semaine 3

Manette 1 - 328p

  • Réalisé

J’ai principalement travaillé sur le programme de la manette et plus précisément les points suivants :

  • Définition des entrées/sorties des différents ports
  • Acquisition des états des boutons
  • Construction de la trame IP-UDP, dont le calcul des checksums
  • Envoi de la trame

Vendredi : Mr Redon m’a contacté pour que j'apporte des modifications au PCB.

  • Difficultés rencontrées

Le planning tenait compte d’un délai de fabrication de 2 semaines à partir du lundi. Il ne pourra pas être respecté pour la manette 1.

  • Prochaines actions semaine 4

Terminer le calcul du checksum UDP

Programmer la lecture des trames reçues par le PC

Manette 2 - 16u2

  • Réalisé

Comme annoncé dans le planning, pas d’avancement cette semaine.

  • Prochaines actions semaine 4

Pas d'action prévue.

Semaine 4

Manette 1 - 328p

  • Réalisé

Mr Redon a envoyé la commande pour mon PCB.


Programmation

Lors de la semaine 3, j’avais annoncé me concentrer sur les checksums UDP et IP. J’avais également parlé de la gestion des trames reçues par le PC.

Dans le cas du checksum UDP, j’ai demandé de l’aide à Mr Vantroy, car un des paramètres nécessaires au calcul n’était pas très clair pour moi. Une fois ce problème résolu, j’ai pu terminer le calcul sans problème.

Lorsqu’une trame est reçue par la manette, celle-ci va vérifier si les checksums sont cohérents avec ceux annoncés par la trame. Si c’est le cas, suivant la demande reçue, la manette renverra l’état des boutons, des LEDs et/ou des vibreurs.

J’ai également travaillé sur la gestion des LEDs et apporté différentes corrections sur les fonctions liées aux boutons. En effet, ma commande déterminant si un bouton est activé, ou non, renvoyait le résultat inverse. J’ai rapidement corrigé ce problème.

Grâce à toutes ces corrections et nouvelles fonctions, j’ai pu terminer le programme de la manette 1.


Test programme

Grâce à une Arduino, fournie par Mr Redon, j’ai pu vérifier que le programme envoie des données conformes à mes attentes.


  • Difficultés rencontrées

Pour calculer le checksum UDP il faut prendre en compte l’adresse IP source, de destination, le protocole IP et la longueur du datagrame (en octet). C’est ce dernier paramètre qui m’a posé problème. Après avoir discuté avec Mr Vantroy, j’ai compris qu’il s’agissait de la longueur de la partie UDP : en-tête + données.

L’erreur sur la gestion des boutons était très subtile. Voir ci-dessous.

 return ((PINB & entree)!=0)?1:0;   Bonne version
 return ((PINB & entree)!=0)?0:1;   Mauvaise version


  • Prochaines actions semaine 5

Le programme de la manette 1 fini, je vais maintenant écrire le programme PC, afin de permettre l’envoi et la lecture de données provenant du port série.


Manette 2 - 16u2

  • Réalisé

Nous avons reçu les différents composants attendus pour souder la manette.

  • Prochaines actions semaine 5

Réalisation du soudage de la manette.

Vérification de la détection de la manette par le PC.

Semaine 5

Semaine 6

Documents Rendus