Cours:CoursM2103 : Différence entre versions

De troyesGEII
Aller à : navigation, rechercher
Ligne 143 : Ligne 143 :
 
   loop_until_bit_is_set(PIND,PD4);
 
   loop_until_bit_is_set(PIND,PD4);
 
   //changer alors la sortie PD3
 
   //changer alors la sortie PD3
   PORD^=(1<<PD3);
+
   PORTD^=(1<<PD3);
 
   //Attendre que PD4 repasse à 0 avant de recommencer
 
   //Attendre que PD4 repasse à 0 avant de recommencer
 
   loop_until_bit_is_clear(PIND,PD4);
 
   loop_until_bit_is_clear(PIND,PD4);

Version du 3 février 2023 à 16:23

gestion des broches

Entrée/Sortie

Direction Input/Output

Mettre la broche PC3 en sortie :
DDRC |=  ( 1 << PC3 );
Mettre la broche PE5 en entrée :
DDRE &=~ ( 1 << PE5 );

Exemples

broche Rôle Registre Code
PC5 Sortie DDRC DDRC |= (1<<PC5);
PD5 et PD7 Sortie DDRD DDRD |= (1<<PD5)|(1<<PD7);
PA3 Entrée DDRA DDRA &=~(1<<PA3);
PD0 et PD1 Entrée DDRD  DDRD &=~( (1<<PD0)|(1<<PD1));
// 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/1

Mettre la broche PC3 à 1 :
PORTC |=  ( 1 << PC3 );
Mettre la broche PE5 à 0 :
PORTE &=~ ( 1 << PE5 );

Exemples

Attention, 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/1

include <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) )...

Exemples

Attention, 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'état

include <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);

Exemples

Attention, 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°interruption

Spécifique à chaque µcontrôleur, en général :

  1. choisir le numéro d'interruption en fonction de la broche
    INT0 INT1 INT2 ...
  2. choisir à quel moment s'exécute l'interruption
    • front montant de l'entrée
    • front descendant de l'entrée
    • changement d'état (tous les fronts)
  3. autoriser l'interruption
  4. écrire la fonction d'interruption

Exemples

pour 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)
  {
  }
}