Binome2020-2
Sommaire
Introduction
L'objectif de ce bureau d'étude est de concevoir entièrement une clé USB personnalisée.
Pour cela, nous passerons par plusieurs étapes :
- Réalisation du circuit électronique à l'aide du logiciel Fritzing.
- Soudage des différents composants sur notre clé.
- Programmation du microcontrôleur de la clé en Arduino.
- Conception de d'un boitier pour notre clé.
Pour personnaliser notre clé USB, l'idée retenue est de concevoir une clé USB déverrouillable par code.
Nous utiliserons des LED rouge et verte pour déterminer si le code rentré est respectivement mauvais ou bon.
De plus, il sera possible de redéfinir le code à l'aide d'un bouton de réinitialisation du code sur la clé.
Matériel/Composant
Tout d'abord, pour la conception de notre clé usb, nous aurons besoin d'un micro-contrôleur AVR. Plus précisément, nous choisirons l'ATMega16u2.
De plus, pour notre clé USB, nous utiliserons une mémoire AT45DB641E (64Mb) car celle-ci est adaptée à notre mciro-contrôleur.
Nous aurons aussi besoin de 2 LED cms ( une rouge et une verte )
6 boutons
Projet Intermédiaire
- Avant de concevoir notre clé usb, on réalise d'abord un projet intermédiaire sur une carte et avec un micro-contrôleur (ATTiny84) plus facile à souder que celui que l'on utilisera pour la clé (ATMega16u2).
- Ce projet à pour but de nous faire travailler seulement dans un premier temps sur la fonctionnalité supplémentaire de notre clé usb.
- Dans notre cas, il s'agira de travailler sur nos 6 boutons et nos 2 LED rouge et verte.
- 5 boutons serviront à rentrer un chiffre par couple [(0,1), (2,3)...,(8,9)] tandis que le dernier fera office de bouton "2nde" pour rentrer le deuxième chiffre de la paire.
- Il est possible de retrouver ci-dessous le PCB de notre projet intermédiaire :
Fichier:Projet intermediaire.zip
PCB : Vue schématique
C'est tout d'abord sur la partie schématique que nous avons commencé la réalisation de notre PCB.
Après avoir intégré le micro-contrôleur, nous avons ajouté les différents composants dont nous avions besoin pour notre carte.
Nous avons donc ajouté nos 6 boutons, ainsi que nos 2 LED rouge et verte chacune reliée à une résistance de 220Ω. Le tout étant à la fois relié à la masse ainsi qu'au micro-contrôleur.
De plus, nous avons rajouté une alimentation et un ICSP.
PCB : Vue circuit-imprimé
Après avoir tout ajouté et relié sur la partie schématique, il a fallu placer et relier concrètement les différents composants sur la carte dans la partie "circuit-imprimé" de Fritzing.
Ainsi, après avoir disposé tous les composants sur la carte, nous avons dû les relier pour certains entre eux et tous au micro-contrôleur.
Nous avons donc optimiser le placement des composants, le tout en prenant soin de ne provoquer aucun entrecroisement et en évitant de faire des angles droits.
Pour pouvoir faire les branchements plus facilement, il a été possible de créer des via qui nous ont permis de faire certains branchements (représentés en orange) sur l'arrière de la carte.
Enfin, pour une question d'esthétisme et de simplicité nous avons plongé le circuit dans la masse puis nous avons envoyé notre carte à l'impression.
PCB : Vide
Une fois la carte imprimée, nous sommes allés en atelier soudure.
Nous avons tout pris connaissance du matériel que l'on allait utiliser pour souder.
On a appris qu'il fallait gommer la carte pour enlever l'oxydation et pouvoir souder plus proprement.
Pour souder, nous avions à disposition du fil d'étain que nous faisions fondre, à l'aide d'un fer à environ 340°C, sur le cuivre et sur la patte du composant afin que celui-ci soit fixé sur la carte.
Dans le cas où nous mettions trop d'étain nous avions une tresse à souder pour enlever facilement ce surplus.
PCB Soudé
Notre carte est maintenant complétement soudée. De ce fait, il nous reste plus qu'à la programmer pour que celle-ci soit fonctionnelle.
Notre but est donc de faire une sorte de mot de passe, qui quand celui-ci est validé, allume la 2eme LED rouge. Pour cela, nous avons essayé de créer sur arduino notre propre système de mot de passe, mais ce fut un échec ...
De ce fait, en nous renseignant sur internet, nous avons trouvé une bibliothèque arduino nommé "Password Library", et qui nous sera bien utile dans notre cas. Pour pouvoir l'utiliser, on a d'abord défini l'utilité de nos boutons. Nous avons d'abord essayé de définir les 5 boutons (roses) en tant que chiffre (2 chiffre par bouton, avec une double impulsion pour avoir le second chiffre) et un bouton validé (marron). Avec cette méthode là, nous n'avions pas de limite de caractère pour le mot de passe, mais le programme était un peu plus dur à réaliser.
Nous avons donc opter pour la deuxième solution qui consiste à utiliser le bouton validé comme un boutont Control/Second, qui permet donc d'atteindre les seconds chiffres plus facilement, le seul "problème" est qu'on a du instaurer une limite de caractère, on a donc laissé 4 chiffres, comme un code PIN.
Code test projet intermédiaire
#include <Password.h> const int ledred = 8; const int ledgreen = 7; // Dans notre cas on va dire que notre mot de passe sera 1234 Password password = Password("1234"); void setup() { // on définit les branches de 0 à 5 en résistance PULLUP for( int i= 0; i<6; i++){ pinMode(i,INPUT_PULLUP); } // Les 2 LED sont définies commes des OUTPUT pinMode(ledred,OUTPUT); pinMode(ledgreen,OUTPUT); } void loop() { // La LED de confimation reste éteinte digitalWrite(ledgreen, LOW); // Tant que le mdp n'est pas bon, la LED rouge reste éteinte if(password.evaluate()==false) digitalWrite(ledred, HIGH); // Les chiffres de 1 à 5 sont attribués aux 5 premiers boutons, à chaque fois qu'on appuie sur un bouton, le mdp s'incrémente d'un chiffre // Le dernier bouton est le bouton validé if (digitalRead(1)==LOW) {password.append('1'); delay(50); } if (digitalRead(0)==LOW) {password.append('2'); delay(50); } if (digitalRead(2)==LOW) {password.append('3'); delay(50); } if (digitalRead(3)==LOW) {password.append('4'); delay(50); } if (digitalRead(4)==LOW) {password.append('5'); delay(50); } // En appuyant sur ce bouton, on vérifie si le mot de passe proposé est équivalent au mot de passe de base // Si il ne correspond pas, la LED rouge clignotte et le mdp se réinitialise // Si il correspond, la LED Verte s'allume if (digitalRead(5)==LOW) {if (!( password.evaluate())) {digitalWrite(ledred,LOW); delay(50); digitalWrite(ledred,HIGH); delay(50); digitalWrite(ledred,LOW); delay(50); digitalWrite(ledred,HIGH); delay(50); digitalWrite(ledred,LOW); delay(50); password.reset(); } else {digitalWrite(ledred, LOW); digitalWrite(ledgreen, HIGH); delay(300); password.reset();}}}
Projet Final : Clef à déverrouillage par code
PCB final
Fichier:Cle USB Groupe2 Antoine-Telian.zip
Chronologie
- 18/01/2021
Présentation du bureau d'étude et choix de la fonctionnalité supplémentaire à ajouter sur notre clé USB.
- 21/01/2021
L'idée retenue est de réaliser une clé USB dévérouillable par un code pin à l'aide de boutons sur la clé.
On y placera aussi deux leds : une rouge pour indiquer si le code n'est pas rentré ou s'il est faut et une led verte qui indiquera si le code est bon.
- 25/01/2021
On réalise d'abord notre Projet intermédiaire. Celui-ci consiste à concevoir une première carte dont le micro-contrôleur est l'ATTiny84. Nous concevons cette première carte avec notre fonctionnalité supplémentaire.
Initiation au logiciel Fritzing pour la réalisation de circuit imprimé.
- 28/01/2021
On continue la réalisation de notre circuit imprimé sur Fritzing en plaçant correctement nos différents composants.
- 01/02/2021
Commencement du programme pour notre Projet intermédiaire sur Arduino.
- 04/02/2021
Fin de la conception de notre circuit imprimé sur Fritzing après avoir ajouté la batterie et l'ICSP.
Nous avons continué notre programme arduino pour notre Projet intermédiaire.
- 08/02/2021
Impression de la carte.
Fin de notre programme arduino pour notre projet intermédiaire.
- 11/02/2021
Début de la soudure des composants (micro-contrôleur, boutons)
- 15/02/2021
Soudage des composants (résistances, LED)
- 18/02/2021
Fin de la soudure (câbles)
Test du programme arduino avec succès
-8/03/2021
Factorisation du code avec des boucles suite aux conseils de Rex.
-11/03/2021
Conception du PCB de la clef sur inkscape.
-18/03/2021
Exportation du fichier d'inkscape sur fritzing et ajout des composants nécessaires.
-22/03/2021
Branchements des composants sur le Fritzing.
-25/03/2021
Fin élaboration du pcb sur Fritzing.
-29/03/2021
Rectification du PCB par Rex. Et commande réalisée.
-01/04/2021
En attente de la réception de la clé.
-08/04/2021
-12/04/2021
Liste des composants établie.
Sur les conseils de Rex, nous avons regardé le programme réalisé pour le binôme 10 pouvant nous être utile également.
-15/04/2021
Clé réceptionnée.
Démarrage de la soudure.
-19/04/2021
Fin de la soudure.
Test des mémoires sur la clé réussis.
Carte commandée
La carte est commandée, le dessin SVG de la carte a du être refait, il n'était pas correct. Des modifications ont été effectuées au niveau du routage. En particulier descendre les distances pour la DRC à 0.15 millièmes d'inch n'était pas très malin. Les fichiers ci-dessous :
Fichiers SVG : Fichier:ClefUSBAntoineTelianSVG.zip.
Fichier Fritzing source : Fichier:ClefUSBAntoineTelian.zip.