Interfata seriala a unui calculator compatibil IBM PC-AT
In mod uzual, pentru implementarea unei interfete seriale se foloseste un circuit (controlor) specializat care indeplineste functiile de baza ale interfetei : serializarea datelor de iesire, generarea informatiilor de control ( biti de start, stop, paritate la transmisia pe caracter sau cimuri de control la transmisia pe cadre), deserializarea datelor receptionate, generarea semnalelor de control conform standardului utilizat, pastrarea temporara a datelor receptionate si acelor ce urmeaza a fi transmise, si altele. Procesorul are acces la canalul serial de comunicatie prin intermediul registrelor de date, control si stare ale controlorului. In tabelul de mai jos se prezinta registrele interfetei seriale a unui calculator compatibil IBM PC-AT.
Tabelul 2
Adresa |
Tip registru |
Tip operatie |
Descriere registru |
XF8 |
Registru de date |
citire |
contine data receptionata (registru de receptie) |
scriere |
contine data ce trebuie transmisa (registru de transmisie) daca XFB.bit7=1 atunci contine partea mai putin semnificativa a divizorului de frecventa |
||
XF9 |
Registru de validare intrerupere |
scriere |
D3=1- validare intrerupere generata de modificarea starii
modemului (CTS, D2=1 - validare intrerupere generata la modificarea starii liniei (eroare sau break) D1=1 - validare intrerupere generata la golirea registrului de transmisie D0=0 - validare intrerupere generata la receptia unui caracter daca XFB.bit7=1 atunci contine partea mai semnificativa a divizorului de frecventa |
XFA |
Registru de identificare a intreruperii |
citire |
D2,1=00- modificare stare linie (eroare sau break) =01- caracter receptionat =10- registru de transmisie gol =11- modificare stare modem D0=0 - lipsa intrerupere =1 - prezenta intrerupere |
XFB |
Registru de control linie |
citire/ scriere |
D7- determina modul de utilizare a registrelor XF8 si XF9 (D7=0 registru de date ; D7=1 registre pt. divizarea frecventei de transmisie) D6- generare semnal de break (se genereaza zero in mod continuu) D4,3 - paritate (x0- fara paritate, 10-para, 11-inpara) D2- biti de stop (0-un bit, 1- doi biti) D1,0 - lungime caracter (00-5biti, 01-6 biti, 10-7 biti, 11-8 biti) |
XFC |
Registru de control modem |
scriere |
D4 - activare bucla inversa pentru testare D3- activare OUT2 D2 - activare OUT1 D1- activare RTS D0 - activare DTR |
XFD |
Registru de stare linie |
citire |
D6- registru de serializare gol (transmisie) D5- registru de transmisie gol D4- indicator break D3- eroare de cadrare D2- eroare de paritate D1- eroare de supraincarcare D0- registru de receptie plin |
XFE |
Registru de stare modem |
citire |
D7- detectie purtatoare D6- indicator sonerie D5- DSR D4- CTS |
Obs : X poate lua valoarea 2 sau 3.
In mod uzual un calculator compatibil IBM PC contine doua canale seriale plasate incepind de la adresele 2F8 si 3F8. In faza de initializare a sistemului se testeaza prezenta interfetelor seriale, si in caz afirmativ adresele canalelor detectate se inscriu in memoria RAM, incepind de la adresa 40:00. Sistemul de operare va asigna nume logice COM1 si COM2 adreselor de canale seriale in ordinea in care ele sunt prezente la adresa 40:00.
Un transfer serial se poate realiza prin controlul direct al programului sau prin intreruperi. In continuare sunt descrise in pseudocod algoritmii de transmisie si respectiv de receptie seriala pentru primul mod de transfer (transfer prin program).
Proc Transmisie-seriala(Buf, Nr_car)
if(contor>=val_max)
else
Scriere_reg_transmisie(Buf[i]) ;
}
}
Proc Receptie_seriala(Buf, Nr_oct)
if(contor>=val_max)
else
Buf[i]= Citire_reg_date() ;
}
}
In algoritmii prezentati s-au folosit urmatoarele apeluri de rutine :
Initializare_canal() - efecueaza programarea controlorului serial la parametri ceruti de transmisie ; se programeaza : frecventa de transmisie, numar de biti de date pe un caracter, numarul de biti de stop (1 sau 2), tip paritate (fara paritate, paritate indiferenta, paritate para sau inpara),etc.
Citire_reg_stare() - realizeaza citirea registrului de stare linie si stare modem si pozitioneaza corespunzator variabilele de stare ( stare_reg_receptie, stare_reg_transmisie, stare_linie)
Citire_reg_date() - citeste registrul de receptie al controlorului
Scriere_reg_date() - scrie caracter nou in registrul de transmisie
- eroare() - semnalizarea unei erori de transfer
Variabila contor se utilizeaza cu scopul de a limita timpul de asteptare la transmisia sau receptia unui caracter, datorita neindepliniri conditiilor de transmisie.
Algoritmii prezentati nu contin o schema de control al fluxului de date. Se presupune ca unitatea receptoare poate sa prelucreze datele receptionate in ritmul in care ele sunt receptionate pe canalul serial (timpul necesar pentru transmiterea seriala a urmatorului caracter este suficienta pentru prelucrarea celui precedent).