« I2L 2022 Groupe4 » : différence entre les versions

De wiki-se.plil.fr
Aller à la navigation Aller à la recherche
Aucun résumé des modifications
Aucun résumé des modifications
Ligne 32 : Ligne 32 :
Par défaut le micro processeur a un bootloader qui permet de faire de la programmation (sans passer par le SPI) , l'utilitaire que nous utilisons est DFU/USB.
Par défaut le micro processeur a un bootloader qui permet de faire de la programmation (sans passer par le SPI) , l'utilitaire que nous utilisons est DFU/USB.


"5.2  ATMega328p: Chaîne de compilation (2/2)" de https://rex.plil.fr/Enseignement/Systeme/Systeme.PSE/systeme.html
"5.2  ATMega328p: Chaîne de compilation (2/2)" de https://rex.plil.fr/Enseignement/Systeme/Systeme.PSE/systeme.html<syntaxhighlight lang="shell">
$ apt install gcc-avr avr-libc avrdude // DFU/USB dfu 6 programmer


<nowiki>#</nowiki> apt install gcc-avr avr-libc <s>avrdude</s> '''//''' '''DFU/USB dfu 6 programmer'''
$ avr-gcc -mmcu=atmega328p -DF_CPU=8000000UL -c -Wall -I. -Os timer.c -o timer.o // compilation source en un . objet


$ avr-gcc -mmcu=atmega328p -DF_CPU=8000000UL -c -Wall -I. -Os timer.c -o timer.o '''// compilation source en un . objet'''
$ avr-gcc -mmcu=atmega328p -g -lm -Wl,--gc-sections -o timer.elf timer.o // édition des liens (afin d'obtenir un exécutable)


$ avr-gcc -mmcu=atmega328p -g -lm -Wl,--gc-sections -o timer.elf timer.o '''// édition des liens (afin d'obtenir un exécutable)'''
$ avr-objcopy -j .text -j .data -O ihex timer.elf timer.hex // nécessaire pour les utilitaires
 
$ avr-objcopy -j .text -j .data -O ihex timer.elf timer.hex '''// nécessaire pour les utilitaires'''


$ dfu_programmer atmega16u2 erase
$ dfu_programmer atmega16u2 erase
Ligne 47 : Ligne 46 :


$ dfu_programmer atmega16u2 reset
$ dfu_programmer atmega16u2 reset
</syntaxhighlight>


== Gestion des entrées-sorties numériques avec avr-gcc ==
== Gestion des entrées-sorties numériques avec avr-gcc ==
Ligne 65 : Ligne 65 :
   }
   }
}
}
</syntaxhighlight>
</syntaxhighlight>Ports B  : 8 sorties
 
Port C  :  > 8 sorties
 
Port D  : 8 sorties
 
En général 8 fois 3 entrées, ici une vingtaine de sorties
 
Registre DDR

Version du 22 mai 2023 à 08:16

Clavier de raccourcis programmables - par Axel Lebas & Wassim Djamaa & Maxime Vitse

Proposition de système

Une carte avec 4 boutons programmables via un fichier de configuration qui est fourni par l'utilisateur. Accompagnée d'une LED.

Contre-proposition

Bonne idée. Votre périphérique USB sera programmé avec une interface comportant un point d'accès OUT pour envoyer les chaînes de caractères à envoyer sur pression des boutons. Il serait intéressant d'écrire ces chaînes dans l'EEPROM de l'ATMega16u2 pour qu'elles persistent une fois le périphérique débranché. Les LED du périphérique doivent permettre d'indiquer quelles touches sont programmées. Le programme de configuration sera écrit avec la bibliothèque libusb-1.0.

Fichiers

Le circuit imprimé à utiliser est le même que celui du groupe 2 avec le clavier optionnel.

3 parties à faire

  • Prog SE:

- LED

- Bouton

- Haut Parleur (pas dans notre use case)

  • Prog USB:

- LUFA

  • Prog PC:

- Lib usb

Makefile pour automatiser le processus suivant

Par défaut le micro processeur a un bootloader qui permet de faire de la programmation (sans passer par le SPI) , l'utilitaire que nous utilisons est DFU/USB.

"5.2  ATMega328p: Chaîne de compilation (2/2)" de https://rex.plil.fr/Enseignement/Systeme/Systeme.PSE/systeme.html

$ apt install gcc-avr avr-libc avrdude // DFU/USB dfu 6 programmer

$ avr-gcc -mmcu=atmega328p -DF_CPU=8000000UL -c -Wall -I. -Os timer.c -o timer.o // compilation source en un . objet

$ avr-gcc -mmcu=atmega328p -g -lm -Wl,--gc-sections -o timer.elf timer.o // édition des liens (afin d'obtenir un exécutable)

$ avr-objcopy -j .text -j .data -O ihex timer.elf timer.hex // nécessaire pour les utilitaires

$ dfu_programmer atmega16u2 erase

$ dfu_programmer atmega16u2 flash time.hex

$ dfu_programmer atmega16u2 reset

Gestion des entrées-sorties numériques avec avr-gcc

#include <avr/io.h>

#define LED     8
#define BOUTON  9

int main(void){
DDRB |= 0x01;                // Sortie pour la LED
DDRB &= ~0x02;               // Entrée pour le bouton
PORTB |= 0x02;               // Configuration de la résistance de tirage

while(1){
  if(PINB & 0x02) PORTB &= ~0x01;      // LED éteinte
  else PORTB |= 0x01;                  // LED allumée
  }
}

Ports B  : 8 sorties

Port C  : > 8 sorties

Port D  : 8 sorties

En général 8 fois 3 entrées, ici une vingtaine de sorties

Registre DDR