Cours:CoursM2103 : Différence entre versions
Ligne 1 : | Ligne 1 : | ||
+ | =Fixed width integer types= | ||
+ | On utilisera les types explicitant directement l'espace utilisé dans la mémoire : | ||
+ | |||
+ | {| class="wikitable" | ||
+ | |- | ||
+ | ! usage || type !! taille (bits) !! minimum || maximum | ||
+ | |- | ||
+ | | entier positif || uint8_t || 8 || 0 || 255 | ||
+ | |- | ||
+ | | entier relatif || int8_t || 8 || -128 || 127 | ||
+ | |- | ||
+ | | entier positif || uint16_t || 16 || 0 || 65535 | ||
+ | |- | ||
+ | | entier relatif || int16_t || 16 || -32768 || 32767 | ||
+ | |- | ||
+ | | entier positif || uint32_t || 32 || 0 || 2^32-1 | ||
+ | |- | ||
+ | | entier relatif || int32_t || 32 || -2^31 || 2^31-1 | ||
+ | |- | ||
+ | | entier positif || uint64_t || 64 || 0 || 2^64-1 | ||
+ | |- | ||
+ | | entier relatif || int64_t || 64 || -2^63 || 2^63-1 | ||
+ | |} | ||
+ | |||
=gestion des broches= | =gestion des broches= | ||
==Entrée/Sortie== | ==Entrée/Sortie== |
Version du 8 février 2023 à 15:07
Sommaire
Fixed width integer types
On utilisera les types explicitant directement l'espace utilisé dans la mémoire :
usage | type | taille (bits) | minimum | maximum |
---|---|---|---|---|
entier positif | uint8_t | 8 | 0 | 255 |
entier relatif | int8_t | 8 | -128 | 127 |
entier positif | uint16_t | 16 | 0 | 65535 |
entier relatif | int16_t | 16 | -32768 | 32767 |
entier positif | uint32_t | 32 | 0 | 2^32-1 |
entier relatif | int32_t | 32 | -2^31 | 2^31-1 |
entier positif | uint64_t | 64 | 0 | 2^64-1 |
entier relatif | int64_t | 64 | -2^63 | 2^63-1 |
gestion des broches
Entrée/Sortie
Direction Input/OutputMettre la broche PC3 en sortie : DDRC |= ( 1 << PC3 ); Mettre la broche PE5 en entrée : DDRE &=~ ( 1 << PE5 ); |
Exemples
// modifier la direction de toutes les broches d'un port
// ex : PA0,PA1,PA2,PA3 en entrées
// ex : PA4,PA5,PA6,PA7 en sortie
DDRA=0b11110000;
//ou
DDRA=0xF0;
//ou
DDRA=(1<<PA7)|(1<<PA6)|(1<<PA5)|(1<<PA4)|(0<<PA3)|(0<<PA2)|(0<<PA1)|(0<<PA0);
//ou
DDRA|=(1<<PA7)|(1<<PA6)|(1<<PA5)|(1<<PA4);
DDRA&=~((1<<PA3)|(1<<PA2)|(1<<PA1)|(1<<PA0));
|
Modifier l'état d'une sortie
Il faut avoir déclarer la broche en sortie, cf ci-dessus !!
Mettre à 0/1Mettre la broche PC3 à 1 : PORTC |= ( 1 << PC3 ); Mettre la broche PE5 à 0 : PORTE &=~ ( 1 << PE5 ); |
ExemplesAttention, il vaut mieux mettre quques parenthèses en trop que pas assez !! ...
// mettre la broche PA2 à 1 :
PORTA |= (1<<PA2);
// mettre la broche PB3 à 0 :
PORTB &=~ (1<<PB3);
// changer l'état de la broche PC5 :
PORTC ^= (1<<PC5);
// mettre les broche PB2 et PB3 à 1 :
PORTB |= ( (1<<PB2) | (1<<PB3) );
// mettre les broche PC4 et PC6 à 0 :
PORTC &=~ ( (1<<PC4) | (1<<PC6) );
// mettre à 0 PA0 PA1 PA2 et à 1 PA3 PA4 PA5 PA6 PA7
// !! attention, cela modifie toutes les sorties !!
PORTA = 0b11111000;
// ou
PORTA = (1<<PA7)|(1<<PA6)|(1<<PA5)|(1<<PA4)|(1<<PA3)|(0<<PA2)|(0<<PA1)|(0<<PA0);
|
Lire l'état d'une entrée
Il faut éventuellement avoir déclarer la broche en entrée, cf ci-dessus !!
Action si 0/1include <avr/sfr_defs.h> Action si la broche PC3 à 1 : if ( bit_is_set(PINC,PC3) )... Action si broche PE5 à 0 : if ( bit_is_clear(PINE,PE5) )... |
ExemplesAttention, il vaut mieux mettre quques parenthèses en trop que pas assez !! // si la broche PB2 est à 1 et la broche PD3 est à 0
if ( bit_is_set(PINB,PB2) and bit_is_clear(PIND,PD3) )
{
// mettre la sortie PE4 à 1
PORTE |= (1<<PE4);
}
else
{
// sinon mettre la sortie PE4 à 0
PORTE &=~ (1<<PE4);
}
|
Attendre un changement d'étatinclude <avr/sfr_defs.h> Attendre que PC3 soit à 1 : loop_until_bit_is_set(PINC,PC3) ; Attendre que PE5 soit à 0 : loop_until_bit_is_clear(PINE,PE5); |
ExemplesAttention, il vaut mieux mettre quques parenthèses en trop que pas assez !! while(1)
{
//Attendre un front montant sur PD4
loop_until_bit_is_set(PIND,PD4);
//changer alors la sortie PD3
PORTD^=(1<<PD3);
//Attendre que PD4 repasse à 0 avant de recommencer
loop_until_bit_is_clear(PIND,PD4);
}
|
Déclencher une interruption sur changement des entrées
n°interruptionSpécifique à chaque µcontrôleur, en général :
|
Exemplespour un atmega328p, INT1 exécutée à chaque changement d'état cf Cours:Atmega328p#Interruptions pour détails #include <avr/io.h>
#include <avr/interrupt.h>
ISR(INT1_vect)
{
// changer l'état de PC3 à chaque interruption
PORTC ^= (1<<PC3);
}
int main()
{
// broche en sortie
DDRC |= (1<<PC3);
// INT1 sur changement d'état
EICRA |= (1<<ISC10);
// autorisation interruption
EIMSK |= (1<<INT1);
sei();
while(1)
{
}
}
|