Binome2019-2
Introduction
L'objectif de ce nouveau bureau d'étude est de concevoir et créer une clé USB en créant un circuit électronique, en soudant des composants électroniques et en programmant le micro-processeur.
L'objectif supplémentaire de bureau d'étude est d'ajouter à notre clé USB une ou plusieurs fonctionnalités qui la rendra unique.
Nous avons fait le choix que notre fonctionnalité supplémentaire sera déverrouillage par haut volume sonore à l'aide d'un micro que nous plaçerons sur notre clé USB.
Matériel utilisé
Dé électronique
Avant de commencer notre clé USB, nous avons réalisé un petit projet préalable.
Nous avons créé un dé électronique, son fonctionnement est simple : Il faut appuyer sur le bouton et il nous donne un chiffre aléatoire (le nombre de leds correspondant s'allume).
Ce projet nous a permis de connaître les logiciels qui nous seront utiles pour notre clé USB.
Nous avons codé à l'aide de l'IDE Arduino et nous avons réalisé le PCB à l'aide de Fritzing.
Nous avons également appris à souder les composants à l'aide du matériel présent à Polytech.
Code du dé électronique
#include <stdio.h> #include <stdlib.h> #include <time.h> #define LED1 0 #define LED2 1 #define LED3 2 #define LED4 3 #define LED5 4 #define LED6 5 #define LED7 6 int Tableaupin[7]= {5,4,1,3,6,2,0}; int BROCHE_BOUTON=7; void setup() { // initialisation Serial.begin(9600); pinMode(Tableaupin[LED1], OUTPUT); pinMode(Tableaupin[LED2], OUTPUT); pinMode(Tableaupin[LED3], OUTPUT); pinMode(Tableaupin[LED4], OUTPUT); pinMode(Tableaupin[LED5], OUTPUT); pinMode(Tableaupin[LED6], OUTPUT); pinMode(Tableaupin[LED7], OUTPUT); pinMode(BROCHE_BOUTON,INPUT_PULLUP); digitalWrite(Tableaupin[LED1],HIGH); delay(200); digitalWrite(Tableaupin[LED1],LOW); digitalWrite(Tableaupin[LED2],HIGH); delay(200); digitalWrite(Tableaupin[LED2],LOW); digitalWrite(Tableaupin[LED3],HIGH); delay(200); digitalWrite(Tableaupin[LED3],LOW); digitalWrite(Tableaupin[LED4],HIGH); delay(200); digitalWrite(Tableaupin[LED4],LOW); digitalWrite(Tableaupin[LED5],HIGH); delay(200); digitalWrite(Tableaupin[LED5],LOW); digitalWrite(Tableaupin[LED6],HIGH); delay(200); digitalWrite(Tableaupin[LED6],LOW); digitalWrite(Tableaupin[LED7],HIGH); delay(200); digitalWrite(Tableaupin[LED7],LOW); randomSeed(analogRead(0)); } int random_a_b(int a,int b) //fonction qui renvoie un nombre entre a inclus et b exclus { return random()%(b-a) +a; } //fct nombre de leds allumées void de1T() { digitalWrite(Tableaupin[LED4],HIGH); delay(1000); } void de2T() { digitalWrite(Tableaupin[LED3],HIGH); digitalWrite(Tableaupin[LED5],HIGH); delay(1000); } void de3T() { digitalWrite(Tableaupin[LED3],HIGH); digitalWrite(Tableaupin[LED4],HIGH); digitalWrite(Tableaupin[LED5],HIGH); delay(1000); } void de4T() { digitalWrite(Tableaupin[LED1],HIGH); digitalWrite(Tableaupin[LED3],HIGH); digitalWrite(Tableaupin[LED5],HIGH); digitalWrite(Tableaupin[LED7],HIGH); delay(1000); } void de5T() { digitalWrite(Tableaupin[LED1],HIGH); digitalWrite(Tableaupin[LED3],HIGH); digitalWrite(Tableaupin[LED4],HIGH); digitalWrite(Tableaupin[LED5],HIGH); digitalWrite(Tableaupin[LED7],HIGH); delay(1000); } void de6T() { digitalWrite(Tableaupin[LED1],HIGH); digitalWrite(Tableaupin[LED2],HIGH); digitalWrite(Tableaupin[LED3],HIGH); digitalWrite(Tableaupin[LED5],HIGH); digitalWrite(Tableaupin[LED6],HIGH); digitalWrite(Tableaupin[LED7],HIGH); delay(1000); } // fonct eteint lampe void de6F() { digitalWrite(Tableaupin[LED1],LOW); digitalWrite(Tableaupin[LED2],LOW); digitalWrite(Tableaupin[LED3],LOW); digitalWrite(Tableaupin[LED4],LOW); digitalWrite(Tableaupin[LED5],LOW); digitalWrite(Tableaupin[LED6],LOW); digitalWrite(Tableaupin[LED7],LOW); } //fonction d'affichage resultat final void loop() { int LED; // partie selection dé if (digitalRead(BROCHE_BOUTON) == HIGH){ LED=random_a_b(0,6); de6F(); } unsigned char test=(digitalRead(BROCHE_BOUTON)==LOW); switch (LED) { case 0: if (test) de1T(); break; case 1: if (test) de2T(); break; case 2: if (test) de3T(); break; case 3: if (test) de4T(); break; case 4: if (test) de5T(); break; case 5: if (test) de6T(); break; } }
Illustration du dé électronique
Photos du dé
Vidéo du dé
Fichier fritzing de notre dé
Clé USB
Code de la clé USB
Nous avons modifié le code de key.c qui se trouve dans ce dossier.
Ce code permet d'échantillonner le son.
Illustration de la clé USB
Schéma et circuit imprimé de notre clé USB:
Fichier contenant la forme de notre clé USB réalisé sur Inkscape :
Fichier contenant la version finale du fritzing de notre clé USB:
Chronologie
Janvier
27/01/2020
Idée : Synthèse vocale qui décrit tout ce que la clef fait
Février
10/02/2020
Nouvelle idée pour remplacer la précédente : Clé qui se verrouille/déverrouille et pour la déverrouiller de façon originale : crier dessus
Recherche de notre microphone : https://fr.farnell.com/kingstate/kecg2740pbj/microphone-miniature-electret/dp/1299885?gclid=EAIaIQobChMIntmX98TG5wIVVJnVCh1wkga7EAQYAiABEgL_XfD_BwE&gross_price=true&mckv=GxWpbYpX_dc%7Cpcrid%7C80993908502%7C&CMP=KNC-GFR-GEN-SHOPPING-1299885
17/02/2020 & 02/03/2020
Nous avons appris à utiliser le logiciel Fritzing en réalisant le Schematic et le PCB d'un circuit imprimé. Le but est ici de créer un dé avec des leds.
Voici le circuit du dé que nous avons réalisé :
Mars
09/03/2020
Programmation du dé et début de la soudure
12/03/2020
Fin de la soudure et de la programmation du dé
Test ReX 15/03/2020, Après quelques soudures le programme suivant passe sur l'ATtiny84 :
#define MAX_LED 7 int leds[]={0,1,2,3,4,5,6}; void setup() { int i; for(i=0;i<MAX_LED;i++) pinMode(leds[i], OUTPUT); } void loop() { int i; for(i=0;i<MAX_LED;i++) digitalWrite(leds[i], HIGH); delay(1000); for(i=0;i<MAX_LED;i++) digitalWrite(leds[i], LOW); delay(1000); }
Démonstration de l'exécution : media:binome2019-2-test1.mp4.
16/03/2020
Première séance via chat.plil.fr Test sur la carte, corrections de bugs dans le programme Test à l'aide d'un Arduino Uno et des composants disponibles chez Eve :
19/03/2020
Finalisation du dé électronique et début de la conception de la carte de la clef USB sur Fritzing.
23/03/2020
Nous avions pris la cle_usb_bis du wiki mais nous avons remarqué qu'il n'y avait pas d'I/O analogique donc nous avons pris la clé "plus simple" (cle_usb sur le wiki). Nous avons ensuite ajouté un microphone et un amplificateur.
26/03/2020
Nous avons modifié notre schematic afin qu'il soit plus clair et nous avons changé d'I/O de l'ATMega8u2 le micro afin d'être sur une I/O analogique.
31/03/2020
Nous avons commencé à regarder le wiki et avons avancé sur le fritzing de la clé. Nous avons appris à l'aide de Inkscape à créer une forme personnalisée pour la clé, voici la forme que nous avons choisi : Fichier:FormeB2.zip
Avril
02/04/2020
Nous avons continué le circuit imprimé de notre clé en mettant tous nos composants ajoutés en composants de surface sauf le micro.
06/04/2020
Nous avons continué le circuit imprimé de notre clé en réorganisant les différents éléments dessus afin d'optimiser la place prise par les composants.
09/04/2020
Nous avons fini le fritzing de notre clé USB en l'optimisant au maximum au niveau des fils et de la place prise. Au niveau de la partie programmation, nous avons fait les modifications nécessaires comme indiqué sur le wiki au niveau des dossiers et de la modification de fichiers. Nous avons également mis la vidéo de notre dé sur le wiki.
27/04/2020
Nous avons complété notre wiki dans la partie "matériel utilisé" et l'avons optimisé afin de séparer les choses terminées de la chronologie afin que ce soit plus clair. Nous avons commencé à réfléchir à un programme permettant d'échantillonner le son et l'écrire dans une mémoire, nous avons écrit ceci (sur Arduino):
const int pinMicro = A0; void setup() { // put your setup code here, to run once: Serial.begin(9600); } void loop() { // put your main code here, to run repeatedly: if (analogRead(pinMicro) >= 30) { Serial.println("dévérouillage"); } }
Cependant, sur le microcontrôleur il n'y a pas de convertisseur et il faut donc utiliser un comparateur, nous allons essayer de modifier cela à la prochaine séance.
30/04/2020
Nous nous sommes rendues compte qu'il fallait écrire dans la mémoire.
Les modifications suivantes ont été réalisées dans key.c dans le fichier TestMemRW.
Notre but aujourd'hui était de déclarer un tableau de 256 octets puis de le remplir avec les bits récupérés sur la pin PD5 branchée sur le micro et d'envoyer le tableau dans la mémoire jusqu'à ce qu'elle soit pleine.
unsigned char inputs[]={0x00,0x00,0x20}; unsigned char pullups[]={0x00,0x00,0x00}; inputs_init(inputs,pullups); unsigned char data[256]; int i,j; unsigned char values[3]; for(i=0;i<MEM_SIZE/256;i++) for(j=0;j<8;j++){ inputs_get(values); data[i] = (data[i]<<1) | (values[2]>>5); }
Afin d'écrire dans la mémoire nous utilisons les lignes de codes :
AT45DB641E_write_buffer(&MEM1_PORT,MEM1_PIN,data,len,SEQ_START|SEQ_STOP); AT45DB641E_write_page(&MEM1_PORT,MEM1_PIN,0);
Mai
04/05/2020
Nous avons fini la partie la plus importante du code, nous avons continué de modifier le fichier key.c.
Nous avons également commencé à chercher le délai nécessaire pour faire l'acquisition à une vitesse raisonnable, car nous ne pouvons pas écrire plus vite que l'on peut écrire dans la mémoire.
Pour cela nous recherchons deux choses :
- La vitesse maximale SPI utilisable avec un AT45DB641E
- La vitesse SPI d'un ATMega16U2 avec comme configuration
SPSR = (1<<SPI2X); SPCR = (1<<SPE)|(1<<MSTR)|(1<<CPOL)|(1<<CPHA);
Nous avons trouvé comme vitesse maximale SPI utilisable avec un AT45DB641E : 104MHz.
Nous chercherons à la prochaine séance la vitesse SPI de l'ATMega16U2.
07/05/2020
Nous cherchons la fréquence pour l'horloge du bus SPI.
Nous avons: SPR0=0, SPR1=1, SPI2X=1.
Donc à l'aide de la table Table 17-5 de la datasheet de l'ATMega16U2 : http://ww1.microchip.com/downloads/en/DeviceDoc/doc7799.pdf :
Nous trouvons fosc/2 et fosc (la fréquence inscrite sur le quartz) est 8Mhz, soit fosc/2 = 4 MHz.
La vitesse SPI de l'ATMega16U2 est de 4 MHz.
Il faut maintenant ralentir la boucle d'acquisition, nous supposons que le temps d'écriture est négligeable à 4 Mhz par rapport à la vitesse d'échantillonnage.
Nous avons donc cherché combien il fallait attendre entre 2 itérations pour arriver à 40 kHz.
Nous avons trouvé qu'il fallait un délai de 25 us dans la boucle d'acquisition des sons pour que cela se fasse à 40 kHz.
Nous avons donc rajouté la ligne suivante dans notre code :
if(i<len-1 || j<7) __delay_us(25);