« Kidule Dé/PIC Entrées Sorties » : différence entre les versions

Contenu supprimé Contenu ajouté
Marc0NICOLE (discussion | contributions)
Aucun résumé des modifications
Ligne 24 :
On peut alors écrire ce que l'on veut dans LATx (en bleu) et à la fin de l'écriture, ce sera mémorisé dans le Data Latch et la sortie aura donc changé.
 
pourPour écrire un 0 dans le bit 0 du PORTA, on peut écrire
<source lang="C">
PORTAbits.LATA0 = 0;
Ligne 30 :
{{clr}}
 
{{Preuve|titre=pourPour les experts : différence entre LAT et PORT|contenu=
Lors de la définition des entrées sorties, faire attention avec un 18F2550 d'utiliser LATxxx pour les sorties et PORTxxx pour les entrées. En effet, si deux instructions assembleurs BCF ou BSF se suivent sur le même PORT, le résultat n'est pas prédictible !!! La doc du PIC est assez peu claire sur ces instructions dites "Read-Modify-Write", mais on peut très bien avoir un résultat erroné (p. ex. BCF PORTA,0 suivit de BSF PORTA,1 peut fort bien se terminer avec le bit 0 de PORTA qui clignote (passe à 0 lors du BCF, puis repasse à 1 lors du BSF de son voisin). En regardant bien le schéma, on comprend pourquoi: lorsque l'on écrit, la donnée que l'on veut est mise dans le Data Latch à la fin de l'écriture. Or la lecture d'une pin est "gelée" durant toute la lecture. Si deux instructions "Read-Modify-Write" se suivent, la première met la donnée sur la pin à la fin du Write. Comme il s'agit d'une pin, qui a un consommateur au bout, la tension ne va pas monter instantanément. Or l'instruction suivante est un "read-modify-write", qui si il est fait sur PORTx et non sur Latx, va lire non pas le registre, mais la pin. Comme la tension sur la pin est '''entrainen train''' de changer et que l'on gèle la lecture de la pin avec un Latch au début du cycle, on a en fait des risques de mémoriser l'état d'avant !!! d'où un comportement étonnant.
 
Ce problème est présent sur tous les PIC, mais l'avantage avec la famille 18Fxxxx est que l'on peut lire et écrire le registre LAT. Dans les premiers PIC, ce registre existe aussi, mais on ne peut pas le lire, on ne peut que l'écrire via PORT... le risque est alors grand, et il faut faier attention en écrivant le soft de ne pas faire 2 "read-modify-write" de suite.
Ligne 39 :
Pour plus d'info, voir le forum microchip [[http://www.microchip.com/forums/tm.aspx?m=421256]] et [[http://www.microchip.com/forums/tm.aspx?m=110258]]
}}
 
==== Allumage d'une LED ====
[[Fichier:Kidule Pilotage Led.png|left]] Si on regarde le schéma, on voit que le fil de la LED0 est connecté à la patte RA0 du processeur et cette patte est elle même connectée à une variable LATA0 qui se trouve dans le processeur. Pour être exact, le processeur a une variable LATAbits qui possède dedans 8 petites variables qui ne peuvent avoir que 1 ou 0. Lorsque l'on met un 0 dans cette variable, cela met 0 Volts sur la patte du processeur. Si on met un 1 dans cette variable, cela met 5 Volts sur la patte du processeur.