Binome2020-5 : Différence entre versions

De Wiki de bureau d'études PeiP
(Journal de la réalisation de la clé USB)
(Journal de la réalisation de la clé USB)
 
(30 révisions intermédiaires par 2 utilisateurs non affichées)
Ligne 9 : Ligne 9 :
 
=<div class="mcwiki-header" style="border-radius: 15px; padding: 15px; font-weight: bold; color: #FFFFFF; text-align: center; font-size: 80%; background: #0000FF; vertical-align: top; width: 98%;">Réalisation de l'option </div>=
 
=<div class="mcwiki-header" style="border-radius: 15px; padding: 15px; font-weight: bold; color: #FFFFFF; text-align: center; font-size: 80%; background: #0000FF; vertical-align: top; width: 98%;">Réalisation de l'option </div>=
  
Tous d'abord nous allons réaliser un projet intermédiaire nous permettant de réaliser notre option.  
+
Tous d'abord nous allons réalisé un projet intermédiaire nous permettant de réaliser notre option.  
  
 
Pour cela , nous avons crée un circuit électronique nous permettant de contrôler 3 afficheurs 7 segments afin d'afficher un chiffre préalablement défini.
 
Pour cela , nous avons crée un circuit électronique nous permettant de contrôler 3 afficheurs 7 segments afin d'afficher un chiffre préalablement défini.
Ligne 40 : Ligne 40 :
 
* Essayer de mettre un maximum sur la même face de la carte.
 
* Essayer de mettre un maximum sur la même face de la carte.
  
* Ne pas faire d'angles droit.
+
* Ne pas faire d'angle droit.
  
 
* "Sortir droit au niveau des broches".
 
* "Sortir droit au niveau des broches".
Ligne 60 : Ligne 60 :
 
04/02: Soudage  
 
04/02: Soudage  
  
Nous avons récupéré les différents composants (pins, micro-controleur, batterie) ainsi que la carte éléctronique et effectué le soudage de tous ces composants sur celle-ci.
+
Nous avons récupéré les différents composants (pins, micro-contrôleur, batterie) ainsi que la carte électronique et effectué le soudage de tous ces composants sur celle-ci.
  
 
[[File:carte.jpg|thumb|left|250px]]  
 
[[File:carte.jpg|thumb|left|250px]]  
Carte contenant le microcontroleur, l'alimentation auxiliaire et les pins  
+
Carte contenant le micro-contrôleur, l'alimentation auxiliaire et les pins  
  
 
de connexion à la seconde carte.
 
de connexion à la seconde carte.
  
*Lien fritzing PCB carte avec le microcontroleur et l'alimentation externe pour notre option:
+
*Lien fritzing PCB carte avec le micro-contrôleur et l'alimentation externe pour notre option:
 
[[Fichier:PCB_option.zip]]
 
[[Fichier:PCB_option.zip]]
  
Ligne 76 : Ligne 76 :
 
08/02: Prise en main d'Arduino  
 
08/02: Prise en main d'Arduino  
  
Nous avons configuré les paramètres Arduino pour qu'il reconnaisse et que l'on puisse commander notre micro-contrôleur. Puis nous avons commencé la résolution du code nous permettant d'afficher un nombre préalablement défini sur nos 3 afficheurs.
+
Nous avons configuré les paramètres Arduino pour qu'il reconnaisse et que l'on puisse commander notre micro-contrôleur. Puis nous avons commencé la réalisation du code nous permettant d'afficher un nombre préalablement défini sur nos 3 afficheurs.
  
 
11/02:  
 
11/02:  
Ligne 88 : Ligne 88 :
 
08/03 :
 
08/03 :
  
Suite a des problemes pour allumer les 3 afficheurs en meme temps, nous avons ré-écrit le tableau liant les LED et le controle des afficheurs a leur pins respectifs:
+
Suite à des problèmes pour allumer les 3 afficheurs en même temps, nous avons ré-écrit le tableau liant les LED à leur pins respectifs sur le micro-contrôleur :
  
 
[[File:attiny_datasheet.jpg|thumb|right|5000px]]
 
[[File:attiny_datasheet.jpg|thumb|right|5000px]]
 +
[[File:afficheurs.jpg|thumb|right|150px]]
  
 
{| class="wikitable"
 
{| class="wikitable"
Ligne 130 : Ligne 131 :
 
|}
 
|}
  
Suite a cela, nous avons developpé un code afin de verifier le bon fonctionnement de la carte "affichage":
+
Suite à cela, nous avons devellopé un code afin de vérifier le bon fonctionnement de la carte "affichage":
  
  
Ligne 187 : Ligne 188 :
  
 
[[File:carte_test.jpg|thumb|left|250px]]  
 
[[File:carte_test.jpg|thumb|left|250px]]  
Test d'affichage : comme on peut le voir, les 3 afficheurs s'allument
+
Test d'affichage : comme on peut le voir, les 3 afficheurs s'allument et affichent ici trois zéro. En essayant d'afficher différents chiffres on s'est rendu compte que la LED D ne s'allumait jamais . Après avoir effectuer des recherches, on s'est rendu compte que on avait connecté cette LED à la broche 4 du micro-contrôleur, qui correspond à la broche reset qui ne peut donc pas contrôler/allumer la LED.
  
  
Ligne 210 : Ligne 211 :
 
[[File:carte_finalise.jpg|thumb|left|250px]]  
 
[[File:carte_finalise.jpg|thumb|left|250px]]  
  
Carte de test de notre fonction supplémentaire avec la carte de controle
+
Carte de test de notre fonction supplémentaire avec la carte de contrôle
  
et la carte d'affichage. Nous avons pu la tester grace au code ci dessus
+
et la carte d'affichage. Nous avons pu la tester grâce au code ci dessus
  
 
et cela fonctionne.
 
et cela fonctionne.
Ligne 229 : Ligne 230 :
 
Nous avons intégré notre fonction sur le fichier Fritzing de la clé USB. Nous avons réalisé ces deux solutions probables suivantes:
 
Nous avons intégré notre fonction sur le fichier Fritzing de la clé USB. Nous avons réalisé ces deux solutions probables suivantes:
  
- Sans modification des composants :[[Fichier:Cle_usb_sm.zip]]
+
* Sans modification des composants :[[Fichier:Cle_usb_sm.zip]]
 
+
* Avec modification des composants :[[Fichier:CUSB_Chloe_Thomas.zip]]
- Avec modification des composants :[[Fichier:CUSB_Chloe_Thomas.zip]]
+
* Solution proposée par ReX : [[Fichier:ClefChloeThomas2021.zip]]
 
 
- Solution proposée par ReX : [[Fichier:ClefChloeThomas2021.zip]]
 
  
 
<div style='display:flex; justify-content:space-around; align-items:center; flex-flow:row nowrap;'>[[File:Schematic_CleUSB.png|thumb|250px]]  [[File:PCB_CleUSB.png|thumb|250px]] </div>
 
<div style='display:flex; justify-content:space-around; align-items:center; flex-flow:row nowrap;'>[[File:Schematic_CleUSB.png|thumb|250px]]  [[File:PCB_CleUSB.png|thumb|250px]] </div>
  
Les séries de pins en haut et en bas servent a connecter la carte de la clé avec une autre carte (nommée bouclier) qui elle assurera la partie affichage, tandis que la carte en dessous sera la clé USB avec la partie mémoire et contrôle  
+
Les séries de pins en haut et en bas servent à connecter la carte de la clé avec une autre carte (nommée bouclier) qui elle assurera la partie affichage, tandis que la carte en-dessous sera la clé USB avec la partie mémoire et contrôle.
  
 
<div style='display:flex; justify-content:space-around; align-items:center; flex-flow:row nowrap;'>[[File:bouclierAv.jpg|thumb|center|250px]]
 
<div style='display:flex; justify-content:space-around; align-items:center; flex-flow:row nowrap;'>[[File:bouclierAv.jpg|thumb|center|250px]]
 
[[File:bouclierAr.jpg|thumb|center|250px]] </div>
 
[[File:bouclierAr.jpg|thumb|center|250px]] </div>
 +
 +
Chaque afficheur est contrôlé grâce à un transistor. On a relié chaque cathode de LED A des trois afficheurs entre elles, le tout connecté à une résistance. On a fait pareil pour les LED B,C,D,E...
  
 
15/03:
 
15/03:
 
   
 
   
Nous avons regardé au PCB ainsi que au schematic réalisé sous Fritzing par M.Redon.
+
Nous avons regardé au PCB ainsi que au schématique réalisé sous Fritzing par M.Redon.
Après avoir regarder à celui ci nous avons commencé à lire et essayer de comprendre le programme pour la Clé USB.
+
Après avoir regarder à celui-ci nous avons commencé à lire et essayer de comprendre le programme pour la Clé USB.
  
 
18/03:
 
18/03:
Ligne 262 : Ligne 263 :
 
25/03 et 29/03:
 
25/03 et 29/03:
  
Test des mémoires sur la premiere clé fonctionnelle :
+
Test des mémoires sur la premiere clé fonctionnelle :
      * TestMemRW [[Fichier: TestMemRW.zip]]
+
* TestMemRW [[Fichier: TestMemRW.zip]]
      * TestmemRW2[[Fichier:TestmemRW2.zip]]
+
* TestmemRW2[[Fichier:TestmemRW2.zip]]
  
 
Ces deux tests fonctionnent sur la clé USB.
 
Ces deux tests fonctionnent sur la clé USB.
Ligne 274 : Ligne 275 :
  
  
Soudure des differents composants sur la deuxieme clé.
+
Soudure des différents composants sur la deuxieme clé.
  
 
<br style="clear:both;"/>
 
<br style="clear:both;"/>
Ligne 306 : Ligne 307 :
 
   };
 
   };
  
Il nous reste donc a programmer notre fonction supplémentaire, l’affichage de la capacité de la clé.
+
Il nous reste donc à programmer notre fonction supplémentaire, l’affichage de la capacité de la clé.
  
 
19/04:  
 
19/04:  
Ligne 318 : Ligne 319 :
 
Nous n'avons malheureusement pas eu le temps de finir et nous avons tenté de finir chez nous mais aucun de nous étant sous Linux nous avons pas réussi à programmer nos clés avec nos nouveaux codes.
 
Nous n'avons malheureusement pas eu le temps de finir et nous avons tenté de finir chez nous mais aucun de nous étant sous Linux nous avons pas réussi à programmer nos clés avec nos nouveaux codes.
  
Vacances:
+
=<div class="mcwiki-header" style="border-radius: 15px; padding: 15px; font-weight: bold; color: #FFFFFF; text-align: center; font-size: 80%; background: #0000FF; vertical-align: top; width: 98%;">Clé USB finale</div>=
 
 
Nous avons réalisé une petite vidéo montrant que l'aspect clé USB fonctionne correctement : [[Fichier:VideoCleUSB.mp4]]
 
 
 
 
 
<div class="mcwiki-header" style="border-radius: 15px; padding: 15px; font-weight: bold; color: #FFFFFF; text-align: center; font-size: 80%; background: #0000FF; vertical-align: top; width: 98%;">Clé USB final
 
</div>
 
  
 
==Clé soudée et assemblée avec le bouclier==
 
==Clé soudée et assemblée avec le bouclier==
Ligne 332 : Ligne 327 :
 
== Code==
 
== Code==
  
Aperçu du MassStorage.c
+
Code dans nos clés à ce jour:[[Fichier:MassStoragePeiPF.zip]]
 
 
/*
 
            LUFA Library
 
    Copyright (C) Dean Camera, 2017.
 
 
 
  dean [at] fourwalledcubicle [dot] com
 
          www.lufa-lib.org
 
*/
 
 
 
/*
 
  Copyright 2017  Dean Camera (dean [at] fourwalledcubicle [dot] com)
 
 
 
  Permission to use, copy, modify, distribute, and sell this
 
  software and its documentation for any purpose is hereby granted
 
  without fee, provided that the above copyright notice appear in
 
  all copies and that both that the copyright notice and this
 
  permission notice and warranty disclaimer appear in supporting
 
  documentation, and that the name of the author not be used in
 
  advertising or publicity pertaining to distribution of the
 
  software without specific, written prior permission.
 
 
 
  The author disclaims all warranties with regard to this
 
  software, including all implied warranties of merchantability
 
  and fitness.  In no event shall the author be liable for any
 
  special, indirect or consequential damages or any damages
 
  whatsoever resulting from loss of use, data or profits, whether
 
  in an action of contract, negligence or other tortious action,
 
  arising out of or in connection with the use or performance of
 
  this software.
 
*/
 
 
 
/** \file
 
*
 
*  Main source file for the MassStorage demo. This file contains the main tasks of
 
*  the demo and is responsible for the initial application hardware configuration.
 
*/
 
 
 
#include "MassStorage.h"
 
#include <stdio.h>
 
#include <avr/io.h>
 
#include <util/delay.h>
 
 
 
#include "Lib/io.h"
 
#include "Lib/card_io.h"
 
 
 
#define NB_CHIFFRES 3
 
 
 
#define TEST_DISP
 
#define REFRESH_DISP
 
 
 
int compteur[NB_CHIFFRES]={0,0,0};
 
long ms=0;
 
 
 
void effacer(void){
 
int i;
 
for(i=1;i<MAX_LED;i++) LED_set(leds[i]);
 
}
 
 
 
int zero[]={0,1,2,3,4,5,-1};
 
int un[]={1,2,-1};
 
int deux[]={0,1,3,4,6,-1};
 
int trois[]={0,1,2,3,6,-1};
 
int quatre[]={1,2,5,6,-1};
 
int cing[]={0,2,3,5,6,-1};
 
int six[]={0,2,3,4,5,6,-1};
 
int sept[]={0,1,2,-1};
 
int huit[]={0,1,2,3,4,5,6,-1};
 
int neuf[]={0,1,2,3,5,6,-1};
 
 
 
int *chiffres[]={zero,un,deux,trois,quatre,cing,six,sept,huit,neuf};
 
 
 
void afficher(int c){
 
if(c<0 || c>9) return;
 
int i=0;
 
while(chiffres[c][i]>=0){
 
  LED_unset(leds[chiffres[c][i]+1]);
 
  i++;
 
  }
 
}
 
 
 
 
 
/** LUFA Mass Storage Class driver interface configuration and state information. This structure is
 
*  passed to all Mass Storage Class driver functions, so that multiple instances of the same class
 
*  within a device can be differentiated from one another.
 
*/
 
USB_ClassInfo_MS_Device_t Disk_MS_Interface =
 
{
 
.Config =
 
{
 
.InterfaceNumber          = INTERFACE_ID_MassStorage,
 
.DataINEndpoint            =
 
{
 
.Address          = MASS_STORAGE_IN_EPADDR,
 
.Size              = MASS_STORAGE_IO_EPSIZE,
 
.Banks            = 1,
 
},
 
.DataOUTEndpoint          =
 
{
 
.Address          = MASS_STORAGE_OUT_EPADDR,
 
.Size              = MASS_STORAGE_IO_EPSIZE,
 
.Banks            = 1,
 
},
 
.TotalLUNs                = TOTAL_LUNS,
 
},
 
};
 
 
 
 
 
/** Main program entry point. This routine contains the overall program flow, including initial
 
*  setup of all components and the main program loop.
 
*/
 
int main(void)
 
{
 
SetupHardware();
 
 
 
LEDs_SetAllLEDs(LEDMASK_USB_NOTREADY);
 
GlobalInterruptEnable();
 
 
 
for (;;)
 
{
 
#ifdef REFRESH_DISP
 
  int i;
 
  for(i=0;i<MAX_DISPLAY;i++)
 
{
 
    DISP_unset(displays[i]);
 
    afficher(compteur[i]);
 
    _delay_us(10);//_delay_ms(1); _delay_us()
 
  effacer();
 
    DISP_set(displays[i]);
 
  }
 
#endif
 
MS_Device_USBTask(&Disk_MS_Interface);
 
USB_USBTask();
 
}
 
}
 
 
 
/** Configures the board hardware and chip peripherals for the demo's functionality. */
 
void SetupHardware(void)
 
{
 
#if (ARCH == ARCH_AVR8)
 
/* Disable watchdog if enabled by bootloader/fuses */
 
MCUSR &= ~(1 << WDRF);
 
wdt_disable();
 
 
 
/* Disable clock division */
 
clock_prescale_set(clock_div_1);
 
#elif (ARCH == ARCH_XMEGA)
 
/* Start the PLL to multiply the 2MHz RC oscillator to 32MHz and switch the CPU core to run from it */
 
XMEGACLK_StartPLL(CLOCK_SRC_INT_RC2MHZ, 2000000, F_CPU);
 
XMEGACLK_SetCPUClockSource(CLOCK_SRC_PLL);
 
 
 
/* Start the 32MHz internal RC oscillator and start the DFLL to increase it to 48MHz using the USB SOF as a reference */
 
XMEGACLK_StartInternalOscillator(CLOCK_SRC_INT_RC32MHZ);
 
XMEGACLK_StartDFLL(CLOCK_SRC_INT_RC32MHZ, DFLL_REF_INT_USBSOF, F_USB);
 
 
 
PMIC.CTRL = PMIC_LOLVLEN_bm | PMIC_MEDLVLEN_bm | PMIC_HILVLEN_bm;
 
#endif
 
 
 
/* Hardware Initialization */
 
LEDs_Init();
 
USB_Init();
 
DataflashManager_Initialisation();
 
 
 
/* Check if the Dataflash is working, abort if not */
 
if (!(DataflashManager_CheckDataflashOperation()))
 
{
 
LEDs_SetAllLEDs(LEDMASK_USB_ERROR);
 
for(;;);
 
}
 
 
 
/* Clear Dataflash sector protections, if enabled */
 
DataflashManager_ResetDataflashProtections();
 
 
 
outputs_init(OUTPUT_PORTB,OUTPUT_PORTC,OUTPUT_PORTD);
 
  int i;
 
  for(i=0;i<MAX_DISPLAY;i++) DISP_set(displays[i]);
 
  for(i=1;i<MAX_LED;i++) LED_set(leds[i]);
 
#ifdef TEST_DISP
 
{
 
int i,j;
 
for(j=0;j<MAX_DISPLAY;j++){
 
DISP_unset(displays[j]);
 
  for(i=1;i<MAX_LED;i++){
 
  LED_toggle(leds[i]);
 
  _delay_ms(50);
 
    LED_toggle(leds[i]);
 
  }
 
DISP_set(displays[j]);
 
  }
 
}
 
#endif
 
}
 
 
 
/** Event handler for the library USB Connection event. */
 
void EVENT_USB_Device_Connect(void)
 
{
 
LEDs_SetAllLEDs(LEDMASK_USB_ENUMERATING);
 
}
 
 
 
/** Event handler for the library USB Disconnection event. */
 
void EVENT_USB_Device_Disconnect(void)
 
{
 
LEDs_SetAllLEDs(LEDMASK_USB_NOTREADY);
 
}
 
 
 
/** Event handler for the library USB Configuration Changed event. */
 
void EVENT_USB_Device_ConfigurationChanged(void)
 
{
 
bool ConfigSuccess = true;
 
 
 
ConfigSuccess &= MS_Device_ConfigureEndpoints(&Disk_MS_Interface);
 
 
 
LEDs_SetAllLEDs(ConfigSuccess ? LEDMASK_USB_READY : LEDMASK_USB_ERROR);
 
}
 
 
 
/** Event handler for the library USB Control Request reception event. */
 
void EVENT_USB_Device_ControlRequest(void)
 
{
 
MS_Device_ProcessControlRequest(&Disk_MS_Interface);
 
}
 
  
/** Mass Storage class driver callback function the reception of SCSI commands from the host, which must be processed.
+
==Rendu final==
*
 
*  \param[in] MSInterfaceInfo  Pointer to the Mass Storage class interface configuration structure being referenced
 
*/
 
bool CALLBACK_MS_Device_SCSICommandReceived(USB_ClassInfo_MS_Device_t* const MSInterfaceInfo)
 
{
 
bool CommandSuccess;
 
  
LEDs_SetAllLEDs(LEDMASK_USB_BUSY);
+
A la fin de ces séances de BE, nous avons une clé fonctionnelle même si elle n'affiche pas exactement ce que l'on souhaitait au départ.
CommandSuccess = SCSI_DecodeSCSICommand(MSInterfaceInfo);
+
Nous sommes ravis d'avoir pu suivre vos cours et réaliser cela.
LEDs_SetAllLEDs(LEDMASK_USB_READY);
 
  
return CommandSuccess;
+
Vidéo de notre clé en cours d'utilisation :[[Fichier:CleUSB.mp4]]
}
 

Version actuelle datée du 24 mai 2021 à 14:45

Introduction

Dans ce bureau d'étude, nous souhaitons réaliser une Clé USB de A à Z , en créant le circuit électronique, soudant les composants et programmant le micro-contrôleur, avec l'ajout d'une option qui rendra cette clé USB unique.

Après plusieurs pistes étudiées , nous avons décidé d'intégrer à un boitier pratique, trois afficheurs 7 segments affichant la capacité restante sur la clé USB en pourcentage. Nous refléchissons également à un nom pour cette règle de poche que l'on pourra graver sur le boitier en plus de la capacité totale de la clé.

Afin de s'initier à toutes ces nouvelles expériences, nous allons commencer par réaliser un projet intermédiaire contenant notre option avant de s'attaquer à la clé USB.

Réalisation de l'option

Tous d'abord nous allons réalisé un projet intermédiaire nous permettant de réaliser notre option.

Pour cela , nous avons crée un circuit électronique nous permettant de contrôler 3 afficheurs 7 segments afin d'afficher un chiffre préalablement défini.

Choix des composants

Dans un premier temps, nous avons commencé par chercher et lire les datasheet des composants utiles à la réalisation de notre option :

  • Un micro-contrôleur ATMEGA8U2 (pour la réalisation de l'option utilisation de l'Attiny84)
  • Une batterie
  • Des pins
  • 3 afficheurs 7 segments
  • 8 Résistances
  • 3 Transistors
ATMEGAU2.jpg
Afficheur.jpg


Élaboration du PCB et du schématique sous fritzing

25/01: Prise en main du logiciel Fritzing.

Nous avons découvert le logiciel ainsi que les règles de réalisation utiles à la réalisation d'un PCB.

Quelques règles:

  • Ne jamais se faire croiser des fils.
  • Essayer de mettre un maximum sur la même face de la carte.
  • Ne pas faire d'angle droit.
  • "Sortir droit au niveau des broches".

27/01: Avancement du PCB.

Nous avons commencé par réaliser la totalité du PCB avec tous les composants (transistors, résistances, afficheurs, micro-contrôleur, pile,...)

Finalement, nous avons supprimé la partie "affichage" de notre carte car elle sera transferée sur une autre carte que nous pourrons emboiter par dessus.

01/02:

Nous avons terminé la réalisation de notre PCB , la mise en forme du schématique.

Après l'avoir rooter, nous avons fait la demande de génération de la carte sur le site de l'école : eei.polytech-lille.net

PCBOption.png

04/02: Soudage

Nous avons récupéré les différents composants (pins, micro-contrôleur, batterie) ainsi que la carte électronique et effectué le soudage de tous ces composants sur celle-ci.

Carte.jpg

Carte contenant le micro-contrôleur, l'alimentation auxiliaire et les pins

de connexion à la seconde carte.

  • Lien fritzing PCB carte avec le micro-contrôleur et l'alimentation externe pour notre option:

Fichier:PCB option.zip


Code Arduino

08/02: Prise en main d'Arduino

Nous avons configuré les paramètres Arduino pour qu'il reconnaisse et que l'on puisse commander notre micro-contrôleur. Puis nous avons commencé la réalisation du code nous permettant d'afficher un nombre préalablement défini sur nos 3 afficheurs.

11/02:

Poursuite du code

18/02:

Test de notre code après l'avoir transféré sur le micro-contrôleur. Problème: impossible d'allumer la LED D des afficheurs car on l'a lié à la pin 4 du micro-contrôleur qui est la pin reset.

08/03 :

Suite à des problèmes pour allumer les 3 afficheurs en même temps, nous avons ré-écrit le tableau liant les LED à leur pins respectifs sur le micro-contrôleur :

Attiny datasheet.jpg
Afficheurs.jpg
Numero du Pin Fonction
0 Afficheur 1
1 Afficheur 2
2 Afficheur 3
3 LED A
4 LED B
5 LED C
6 LED DP
7 LED F
8 LED G
9 LED E
11 LED D

Suite à cela, nous avons devellopé un code afin de vérifier le bon fonctionnement de la carte "affichage":


 unsigned char c0[8]={0,0,0,0,0,0,1,1}; //LED = {a,b,c,d,e,f,g,dp} c0[8][0]=0
 unsigned char c1[8]={1,0,0,1,1,1,1,1};
 unsigned char c2[8]={0,0,1,0,0,1,0,1};
 unsigned char c3[8]={0,0,0,0,1,1,0,1};
 unsigned char c4[8]={1,0,0,1,1,0,0,1};
 unsigned char c5[8]={0,1,0,0,1,0,0,1};
 unsigned char c6[8]={0,1,0,0,0,0,0,1};
 unsigned char c7[8]={0,0,0,1,1,1,0,1};
 unsigned char c8[8]={0,0,0,0,0,0,0,1};
 unsigned char c9[8]={0,0,0,0,1,0,0,1};
 const byte PIN_SEGMENT_A = 3; 
 const byte PIN_SEGMENT_B = 4;
 const byte PIN_SEGMENT_C = 5;
 const byte PIN_SEGMENT_D = 11;
 const byte PIN_SEGMENT_E = 9;
 const byte PIN_SEGMENT_F = 7;
 const byte PIN_SEGMENT_G = 8;
 const byte PIN_SEGMENT_DP = 6;
 const byte PIN_CONTROL_1 = 0;
 const byte PIN_CONTROL_2 = 1;
 const byte PIN_CONTROL_3 = 2;
 #define NB_LEDS 8
 #define NB_TR   3
 int LEDpins[]={PIN_SEGMENT_A,PIN_SEGMENT_B,PIN_SEGMENT_C,PIN_SEGMENT_D,PIN_SEGMENT_E,PIN_SEGMENT_F,PIN_SEGMENT_G,PIN_SEGMENT_DP};
 int TRpins[]={PIN_CONTROL_1,PIN_CONTROL_2,PIN_CONTROL_3};
 unsigned char *p;
 void setup() {
   int i;
   for(i=0;i<NB_LEDS;i++){ 
     pinMode(LEDpins[i], OUTPUT);
     digitalWrite(LEDpins[i], HIGH);
   }
   for(i=0;i<NB_TR;i++){ 
     pinMode(TRpins[i], OUTPUT);
     digitalWrite(TRpins[i], HIGH);
   }
   p=c0;
 }
 void loop() {
   for(int i = 0;i<NB_TR;i++)
   {
      for(int a=0;a<NB_LEDS;a++){
         digitalWrite(LEDpins[a],p[a]);
      }
      digitalWrite(TRpins[i], LOW);
      delay(1);
      digitalWrite(TRpins[i], HIGH);
   }
 }

Carte Finalisée

Carte test.jpg

Test d'affichage : comme on peut le voir, les 3 afficheurs s'allument et affichent ici trois zéro. En essayant d'afficher différents chiffres on s'est rendu compte que la LED D ne s'allumait jamais . Après avoir effectuer des recherches, on s'est rendu compte que on avait connecté cette LED à la broche 4 du micro-contrôleur, qui correspond à la broche reset qui ne peut donc pas contrôler/allumer la LED.











Carte finalise.jpg

Carte de test de notre fonction supplémentaire avec la carte de contrôle

et la carte d'affichage. Nous avons pu la tester grâce au code ci dessus

et cela fonctionne.



Journal de la réalisation de la clé USB

08/03: Réalisation de la forme du PCB final de notre clé USB sous Inkscape. Pour ce faire, nous avons séparé les deux layers qui composaient le fichier de la forme de la clé, puis nous les avons modifié (silkscreen en dernier) pour s'adapter a notre fonction supplémentaire.

Clef PCB F.png

11/03:

Nous avons intégré notre fonction sur le fichier Fritzing de la clé USB. Nous avons réalisé ces deux solutions probables suivantes:

Schematic CleUSB.png
PCB CleUSB.png

Les séries de pins en haut et en bas servent à connecter la carte de la clé avec une autre carte (nommée bouclier) qui elle assurera la partie affichage, tandis que la carte en-dessous sera la clé USB avec la partie mémoire et contrôle.

BouclierAv.jpg
BouclierAr.jpg

Chaque afficheur est contrôlé grâce à un transistor. On a relié chaque cathode de LED A des trois afficheurs entre elles, le tout connecté à une résistance. On a fait pareil pour les LED B,C,D,E...

15/03:

Nous avons regardé au PCB ainsi que au schématique réalisé sous Fritzing par M.Redon. Après avoir regarder à celui-ci nous avons commencé à lire et essayer de comprendre le programme pour la Clé USB.

18/03:

Nous avons poursuivi notre travail de compréhension sur le programme et ajouter les quelques lignes manquantes.

22/03:

Nous avons commencer à modifier le fichier d'écriture et de lecture de la memoire de la clé USB : Fichier:*DataFlashManager.zip et commencer le soudage de la première clé.

Pour commencer, nous soudons uniquement les composants nécessaire à la partie micro-contrôleur.

Photos de la clé USB avec soudure de la partie micro-contrôleur et mémoire:

CleUSBSoudeeAV.jpg
CleUSBSoudeeAR.jpg

25/03 et 29/03:

Test des mémoires sur la premiere clé fonctionnelle :

Ces deux tests fonctionnent sur la clé USB.

01/04 et 08/04:

Test du code pour contrôler les afficheurs afin d'afficher un compteur. Code: Fichier:Bouclier7seg.zip


Soudure des différents composants sur la deuxieme clé.


12/04:

Test en fin de séance du bouclier d’affichage. Problème sur les chiffres qui ne s’affichent pas comme il le faudrait. Nous pensons donc qu’il y a un problème concernant l’affectation des pins aux LEDs des différents afficheurs dans le fichier nommé « card_io.h »

15/04:

Nous avons eu beaucoup de mal pour faire détecter la clé USB par l’ordinateur. Lorsque l’on tape la commande lsusb dans le terminal de commande, nous n’obtenions pas la ligne suivante: Bus 001 Device 064: ID 03eb:2ffa Atmel Corp. at90usb162 DFU bootloader

Nous sommes tout de meme parvenu a la faire détecter plus souvent et avons résolu le problème des afficheurs qui affichent correctement les différents chiffres: Nous avons modifié les valeurs hexadécimales correspondant aux pins de l’ATMega ou nous avions relié chacune des LED et avons également rectifié une erreur sur la valeur hexadécimale des ports de sorties. Nous avons donc les valeurs suivantes:

Ports de sorties:
#define OUTPUT_PORTB	0x80
#define OUTPUT_PORTC	0x74
#define OUTPUT_PORTD	0xFE
LEDS:
uint32_t leds[MAX_LED]={
 0x00400000,
 0x00000080, 0x00000040, 0x00000020, 0x00000002,
 0x00000400, 0x00000008, 0x00000004, 0x00000010
 };
Afficheurs:
uint32_t displays[MAX_DISPLAY]={
 0x00001000, 0x00002000, 0x00800000
 };

Il nous reste donc à programmer notre fonction supplémentaire, l’affichage de la capacité de la clé.

19/04:

Nous avons modifié le fichier DataFlashManager.c afin de prendre en compte les modifications faites par Mr.Redon. Nous avons également ajouté le refresh des afficheurs dans le code mis sur la clé USB mais aucun afficheur ne s’allume, laissant présager un problème de ce côté la. Comme point positif, l’ordinateur reconnaît maintenant notre clé comme un device de « LUFA Mass Storage »

22/04:

Nous avons programmé les deux clés USB afin de pouvoir écrire, lire et stocker et que nos afficheurs affichent 000. Finalement nous avons tenté de modifier notre programme afin que les afficheurs affichent un compteur pour commencer avant d'essayer d'afficher la capacité comme voulu initialement. Nous n'avons malheureusement pas eu le temps de finir et nous avons tenté de finir chez nous mais aucun de nous étant sous Linux nous avons pas réussi à programmer nos clés avec nos nouveaux codes.

Clé USB finale

Clé soudée et assemblée avec le bouclier

CleUSBbouclier.jpg
Assemblage.jpg

Code

Code dans nos clés à ce jour:Fichier:MassStoragePeiPF.zip

Rendu final

A la fin de ces séances de BE, nous avons une clé fonctionnelle même si elle n'affiche pas exactement ce que l'on souhaitait au départ. Nous sommes ravis d'avoir pu suivre vos cours et réaliser cela.

Vidéo de notre clé en cours d'utilisation :Fichier:CleUSB.mp4