Asynch Serial
Asynch Serial
Asynch Serial
Réception
Emission
d7 d0
Avantage : pas cher : 3 fils au minimum (émission Tx, réception Rx, masse GND), (5 ou 9) très
souvent.
Inconvénients : Assez lent.
L'émetteur et le récepteur doivent être configurés de manière identique (même
nombre de bits par mot, même ordre d'émission des bits, même rythme de transmission des bits,
etc....
Comme l'horloge n'est pas transmise, le récepteur ne sait pas quand commence et
quand fini la transmission : On ajoute des bits (Start, Stop) pour que le récépteur puisse se
synchroniser.
2)Liaison RS232
Mot transmis de 5,6 7 ou 8 bits.
1 bits de start (0) et 1,1.5 ou 2 bits de stop (1) indiquent le début et la fin du mot transmis.
1 bit de parité (paire ou impaire) est éventuellement ajouté pour détecter les erreurs de
transmission.
Transmission à 75,150,300,600,1200,2400,4800,9600,19200,....115.2K bit/s (appellé aussi
Baud)
Half duplex (émission/réception alternées) ou Full-duplex (émission/reception simultanées).
Nov2003 SB
Caractéristiques électriques :
'0' niveau émis +V,
'1' niveau émis -V
avec V compris entre 5 et 25 Volts (12Volts pour les ports séries COM1, COM2 sur un PC).
Transmission limitée à une dizaine de mètres maximum.
Exemple : transmission d'un 'A' = 65 = 0x41, transmission 8bits, parité impaire, 1 bit de start, 1 bit
de stop. 0X41 = 0100 0001 soit
La liaison série bidirectionnelle la plus simple utilise 3 fils : Tx, Rx , Masse. C'est une
connexion entre 2 équipements qui se conforme au schéma suivant :
Tx1 Tx2
Rx1 Rx2
GND GND
D7 d0 D7 d0
Equipement 1 Equipement 2
Ce type de connexion 3fils est peu fiable pour la raison suivante : à 9600Baud, la
transmission de 8 bits de données nécessite l'envoie de 10 bits minimum (8bits + 1 bit de start +1 bit
de stop). Si l'un des équipements envoie des données en permanence, il le fait au rythme de
9600Baud/10bits = 960 caractères par seconde. Ainsi l'équipement de réception doit etre capable de
retirer 1 caractère toute les millisecondes et de le traiter. Or il y a de nombreux cas ou l'équipement
de réception n'en est pas capable, en particulier les PC équipés de système d'éxploitation (OS)
récents (les différentes saveurs de Windows (95/98/Me/NT/2K/XP etc) et les systèmes Unix/Linux).
Nov2003 SB
Dans ces systèmes, les INTERRUPTIONS peuvent etre masquées pendant plusieurs centaines de
millisecondes interdisant la prise en compte de l'interruption UART signalant la présence d'un
caractère dans le buffer de réception. Les caractères reçus sont ecrasés au fur et à mesure par les
nouveaux arrivant. Les spécifications du DOS impose un temps de masquage des interruptions
toujours inférieur à 1ms.
Pour pallier ce defaut -d'autant plus critique que la transmission se fait à débit élévé
(115.2Kbits/s)- deux solutions sont utilisées : le protocole de gestion du flux materiel (RTS/CTS)
ou logiciel (XON/XOFF) et des UART incorporant un buffer de 16,64,128 caractères ou plus (voir
paragraphe sur les UART).
Le contrôle de flux logiciel permet de controler le flux sur une liaison série 3 fils. Le
fonctionnement tire parti de 2 caractères de contrôle XON (caractère 17 de la table ASCII ou Ctrl-
Q) et XOFF ( 19 ou Ctrl-S). La transmission s'effectue d'un equipement 1 vers un equipement 2.
Lorsque l'équipement 2 ne peut plus recevoir et traiter les données arrivant, il envoie XOFF à
l'équipement émetteur (lui demandant un arrèt de transmission). Dès que l' est a nouveau prêt, il
envoie XON.
Seul l'émetteur “écoute” les XON et XOFF mais pas le recepteur, il est donc possible
de transmettre des données brutes (contenant des 0x11 et 0x13) de l'équipement d'émission vers
l'équipement de récéption.
La laison ne necessite que 3 fils, et convient particulièrement aux microcontroleurs qui
implémentent rarement le controle de flux materiel par RTS/CTS (liaison 5 fils).
Dans une liaison série asynchrone sur 5 fils, 2 signaux (RTS/CTS) supplémentaires
servent à assurer le controle du flux de transmission. Ils permettent à l'équipement de réception de
signaler qu'il n'est pas apte à recevoir d'autres données (étape 7) du protocole RTS/CTS ci dessous).
RTS1 RTS2
CTS1 CTS2
Tx1 Tx2
Rx1 Rx2
GND
d7 d0 d7 d0
Equipement 1 Equipement 2
Nov2003 SB
Protocole RTS/CTS :
1) L'emetteur positionne RTS1 à 0 : c'est la requète d'émission, il demande à émettre
2) Le récepteur positionne CTS1 à 0 : il est près à recevoir.
3) L'émission commence
4) L'émetteur signale la fin d'émission ( il redemandera une émission en 6))
5) Le recepteur acquiesce, en repassant CTS1 à l'etat 1, une autorisation sera possible + tard
(8)
6) L'émetteur fait une nouvelle requète d'émission
7) elle n'est pas prise en compte tout de suite car le recepteur est occupé...)
8) Le recepteur est de nouveau prèt et acquièce.
9,10...) la suite est identique à 3,4 5
RTS1 1 4 6 10
CTS1 2 5 8
7
Tx1 3 9 Data
Data
Pour faire dialoguer 2 ordinateurs distants entre eux, on a souvent recours à une
transmission par modems (modulateur/démodulateur) au travers d'une ligne téléphonique. Un telle
liaison est schématisée ci dessous :
FranceTelecom
Paire torsadée
PC1 RS232 Modem1
9fils
Modem2 RS232
9fils PC2
DTR/DSR : Data Terminal Ready (PC Prêt à emettre)/Data Send Ready(Modem prêt à recevoir)
DCD : Data Carrier Detect : le modem prévient qu'une transmission est en cours
RI : RIng (DDDDRRRIIINNNNNNGGGGGGG......)
Nov2003 SB
RING RING
DCD DCD
DTR1 DTR2
DSR1 DSR2
RTS1 RTS2
CTS1 CTS2
Tx1 Tx2
Rx1 Rx2
GND
d7 d0
On peut se demander si les signaux de contrôle DTR/DSR ne font pas doublons avec les
signaux de contrôle de flux RTS/CTS. En fait ils servent à contrôler l'état de la laison pour
savoir si quelqu'un est à l'autre bout.
4) Différentes UART
Cf TD
5)Cablages
Nov2003 SB