Microprocesoare - Z80
Microprocesoare - Z80
Procesorul reprezintă realizarea cu cel mai mare impact asupra evoluţiei ulterioare a
societăţilor industrializate. Uşurinţa implementarii diverselor aplicaţii, flexibilitatea privind
conducerea proceselor, modularizarea aplicaţiilor, fiabilitatea ridicată, au contribuit la o
utilizare pe scară largă a microprocesoarelor şi implicit la o scădere a preţului de cost a
aplicaţiilor respective.
În acest context microprocesorul este dispozitivul electronic care însoţeşte aproape
orice echipament de calcul sau instalaţie tehnologică. Rafinarea microprocesoarelor a aparut
ca o necesitatea obiectivă datorită faptului că cerinţele impuse sistemelor de calcul au
evoluat şi ele de asemenea într-o manieră naturală. O scurtă trecere în revistă a
procesoarelor dezvăluie dinamica evoluţiei acestora şi creativitatea specialiştilor în acest
domeniu. Reorganizarea modului de procesare împreună cu implementarea diferitelor
mecanisme de calcul paralel au contribuit la creşterea puterii de prelucrare a procesoarelor.
Piaţa structurilor de calcul cunoaşte o mare diversitate şi pune în evidenţă faptul că
specialiştii din acest domeniu sunt într-o continuă căutare de noi soluţii care să răspundă
provocărilor prezentului şi viitorului.
Schema bloc a unui microcalculator realizata in jurul unui microprocesor este dată în cele ce
urmează.
1
permite încărcarea unui alt program care la rândul său încarcă sistemul de operare.
Memoriile program au evoluat de la memorii ROM care sunt scrise de către fabricant o
singura dată, până la memorii EEPROM ce permit ştergerea şi programarea lor de mai
multe ori pe cale electrică de către utilizator.
Memoria de date permite stocarea datelor care se pot modifica în timpul execuţiei
programului. Memoria de date este de doua tipuri: memoria RAM – statică care nu necesită
refreşarea informaţiei stocate şi memorii RAM – dinamice care necesită refreşarea
informaţiei la un interval de aproximativ de 2ms.
Interfeţele pentru cuplarea perifericelor permit conectarea dispozitivelor externe la
U.C.P. în vederea comunicării cu operatorul uman şi respectiv a editării unor documente
privind anumite mărimi din proces.
Interfaţa de proces este utilizată pentru conectarea procesului la microcalculator.
Magistralele microsistemului permit transferul de informaţii între dispozitivele electronice
ale microcalculatorului.
Microprocesorul Z80 reprezintă unul dintre cele mai performante procesoare organizate
pe 8 biţi, fiind realizat într-o structură unitară şi dispunând de un set de instrucţiuni evoluat,
comparativ cu celelalte procesoare pe 8 biţi.
2
Circuitele pentru decodificarea instrucţiunilor reprezintă componenta de bază a unui
microprocesor având rolul de a interpreta (decodifica) instrucţiunile reţinute în registrul de
instrucţiuni şi de a genera acele semnale de comandă (interne şi externe) care permit
rezolvarea cerinţei specificată de către instrucţiunea care se execută la momentul curent.
Registrul de instrucţiuni menţine, un timp bine precizat, codul instrucţiunii în curs de
execuţie la intrările circuitului pentru decodificarea instrucţiunilor.
Registrele unităţii centrale sunt memorii rapide care au rolul de a mări viteza de execuţie
a instrucţiunilor şi de a creşte flexibilitatea în ceea ce priveşte implementarea algoritmilor.
Registrele unităţii centrale mai conţin şi informaţii cum ar fi adresa de refreshare (registrul
R), adresa memoriei stivă (registrul SP), partea high a adresei tabelei unde se află adresele
rutinelor de tratare a întreruperilor (registrul I), etc.
Registrele tampon de date şi adrese au rolul de a menţine adresele şi datele pe
magistralele de adrese şi date un interval de timp bine definit.
Unitatea aritmetico-logică (U.A.L.) reprezintă o altă componentă importantă a
microprocesorului care are rolul de a executa operaţii aritmetice şi logice între operanzi ce
se pot afla în registrele unităţii centrale sau în memoria sistemului.
M 1 - indică extragerea unui cod de operaţie numit şi OPCOD sau aşa cum este cunoscut si
sub denumirea de ciclul FETCH.
Obs.: M 1 + IOREQ indică un ciclu de achitare a unei întreruperi
MREQ - este activ pe zero logic şi indică lucrul cu memoria. Semnalizează faptul că pe
magistrala de adrese se află o adresă de citire sau scriere din/în memoria externă.
IOREQ - permite lucrul cu dispozitivele de intrare/ieşire. Indică plasarea pe octetul mai
puţin semnificativ al magistralei de adrese a unei adrese care va fi utilizată într-o operaţie de
citire sau scriere la dispozitivele de I-E.
3
RD - un semnal cu ajutorul căruia se realizează citirea informaţiei din memorie sau de la un
periferic. Se utilizează acest semnal pentru a valida cu ajutorul lui plasarea datelor pe
magistrala de date.
WR - permite scrierea informaţiei în memorie sau la un periferic de ieşire. Semnalează
faptul că pe magistrala de date se găsesc datele ce trebuiesc scrise în memoria externă sau la
dispozitivul periferic adresat.
RFSH - semnal cu ajutorul căruia se realizează refresharea memoriei RAM dinamice. Pe
perioada când RFSH este activ se activează şi MREQ, iar pe liniile A0 – A6 se află adresa de
reîmprospătare a memoriei RAM dinamică.
HALT - indică oprirea U.C.P., timp în care se aşteaptă de regulă o întrerupere nemascabilă
sau una mascabilă, dar validată în prealabil, pentru a putea ieşi din starea HALT.
Obs.: în timpul opririi se execută instrucţiuni de tip NOP (No operation) cu scopul de a se
refresha RAM-ul dinamic.
WAIT - semnal prin care se poate realiza dialogul cu perifericele mai lente prin introducerea
unor stări de aşteptare. În timpul stărilor de aşteptare nu se generează semnale de refresh.
INT - cerere de întrerupere mascabilă care este validată numai dacă se execută
instrucţiunea EI (Enable Interrupt). Cererea poate fi invalidată executând instrucţiunea DI
(Disable Interrupt).
NMI - permite întreruperea activităţii microprocesorului în orice moment de timp
(întrerupere nemascabilă). În momentul apariţiei unei întreruperi nemascabile se suspendă
execuţia programului şi se face saltul la adresa 0066H, unde se află rutina de tratare a
întreruperii nemascabile.
RESET - este un semnal de resetare a microprocesorului care trebuie ţinut pe zero logic cel
puţin 3 perioade de ceas pentru a reseta toate elementele componente ale microprocesorului.
După reset avem următoarea stare: PC (Program Counter) = 0000H ; IF1=0, IF2=0;I=00H,
R=00H; modul de întrerupere setat este modul zero.
BUSRQ - este un semnal de cerere de magistrală trimis de o altă unitate de procesare care
este tratat la sfârşitul fiecărui ciclu maşină.
BUSAK - este un semnal prin care microprocesorul anunţă unitatea de calcul care a cerut
magistralele faptul că acestea pot fi preluate.
Ø - clock-ul U.C.P.-ului care permite desfăşurarea operaţiilor executate de microprocesor.
Domeniul clock-ului Ø este [2…10] MHz.
Magistralele de adrese şi de date permit adresarea şi transferul de informaţii de la şi către
dispozitivele microsistemului.
4
A - registrul acumulator, este un registru des utilizat de către U.A.L. Informaţia conţinută în
acesta poate fi atât sursă cât şi destinaţie în cadrul operaţiilor executate de către
microprocesor.
BC, DE, HL – sunt regitre de câte 16 biţi, care pot fi utilizaţi şi ca registre de 8 biţi (B, C,
D, E, H, L). Aceste regitre sunt folosite atât în operaţiile logice şi aritmetice, cât şi în
operaţiile prin care se realizează transfer de informaţie.
de la memorie la microprocesor şi invers.
Ix, Iy - registre de index, care permit memorarea adresei de bază în cazul unor instrucţiuni
care folosesc adresarea relativă.
SP - indicator de stivă, care este de fapt un registru pe 16 biţi ce permite lucrul cu memoria
de tip stivă, memorie utilizată în cazul instrucţiunilor de tip CALL sau în cazul tratării
întreruperilor. Spaţiul rezervat memoriei de tip stivă nu trebuie modificat de către
programele în curs de execuţie.
PC - contor de program, este un registru pe 16 biţi care memorează adresa instrucţiunii în
curs de execuţie.
I - registru pe 8 biţi care conţine cei mai semnificativi 8 biţi ai adresei tabelei cu adresele
rutinelor de tratare a întreruperilor.
F - registru care memorează indicatorii de condiţie rezultaţi în urma efectuării operaţiilor.
unde:
5
S - indicator de semn (S = 1 dacă rezultatul operaţiei executate este negativ);
Z - indicator de zero (Z = 1 dacă rezultatul unei operaţii este zero);
C - indicator de transport care se setează cu 1 dacă operaţia a produs un transport la cel mai
semnificativ bit al operandului sau rezultatului;
P/V - indicator de paritate/depăşire (pentru operaţii logice avem paritate, iar pentru operaţii
aritmetice avem depăşire). În cazul parităţii, dacă P/V=1, atunci rezultatul are un număr par
de biţi, iar în cazul depăşirii, dacă P/V=1, atunci rezultatul a depăşit limitele intervalului
[-128, 127];
H - indicator de transport auxiliar, fiind utilizat numai de către instrucţiunile de ajustare
zecimală;
N - indicator de adunare sau scădere care este utilizat de asemenea de către instrucţiunile de
ajustare zecimală;
6
Ciclul instrucţiune prezentat corespunde instrucţiunii LD A,(8020H) şi conţine patru
cicluri maşină. Primul ciclu este un ciclu FETCH (extragere cod operaţie), urmat de două
cicluri maşină necesare extragerii adresei de memorie de unde se va face transferul. Ultimul
ciclu corespunde executării propriu-zise a instrucţiunii de transfer a datei din memorie în
registrul A.
Microprocesorul Z80 dispune de cicluri de citire din memorie (extragere cod
operaţie, citire operand, citire date din memorie) şi cicluri de scriere în memorie, care se
referă la transferul informaţiei de la microprocesor în memoria RAM statică sau dinamică a
microsistemului. De asemenea Z80 dispune de cicluri de citire/scriere din/în porturi de
intrare/ieşire, care sunt similare ciclurilor de citire/scriere din/în memorie. În cadrul acestor
cicluri se activează IOREQ în loc de MREQ .
În cazul comunicării cu dispozitivele mai lente se utilizează tehnica de WAIT
necesară transferului de date între perifericile cu timp de acces mai mare şi microprocesor.
7
Cicluri de scriere/citire în/din memorie sau port de ieşire/intrare cu stari WAIT
Pe frontul căzător al perioadei T2 se testează WAIT, iar în cazul în care este găsit pe 0
logic se mai introduce încă o stare de aşteptare Tw. Pe frontul căzător al lui Tw se testează
din nou WAIT până când acesta este pe 1 logic. După ce se trece WAIT pe 1 logic se
continuă desfăşurarea normală a ciclului maşină.
Transferul datelor are loc pe frontul căzător al perioadei T3, moment în care se
realizează tranziţia semnalelor de citire/scriere din 0 în 1 logic. În funcţie de semnalul care
se activează ( MREQ , IOREQ , RD , WR ) microprocesorul execută una dintre operaţiile
date în tabelul următor.
8
• instrucţiuni de transfer pe 8 biţi;
• instrucţiuni de transfer pe 16 biţi;
• instrucţiuni de transfer pe blocuri şi căutări în interiorul blocurilor de memorie;
• instrucţiuni specifice operaţiilor aritmetice şi logice pe 8 biţi;
• instrucţiuni corespunzătoare operaţiilor de comandă a U.C.P.;
• instrucţiuni de rotaţie şi deplasare;
• instrucţiuni de salt;
• instrucţiuni apel de subrutine şi revenire în programul principal;
• instrucţiuni specifice operaţiilor de intrare/ieşire.
Modurile de adresare ale microprocesorului Z80 permit un transfer eficient între registre,
memoria externă şi dispozitivele periferice. În cele ce urmează se prezintă modurile de
adresare ale microprocesorului Z80.
Adresare imediată
Structura instrucţiunii
Structura instrucţiunii:
9
Adresare relativă
Structura instrucţiunii:
Adresare extinsă
Structura instrucţiunii:
Adresare indexată
Structura instrucţiunii:
Adresare la registru
Structura instrucţiunii:
10
Adresare implicită
Structura instrucţiunii:
Structura instrucţiunii:
Adresare pe bit
Structura instrucţiunii:
11
asamblare se face printr-o adresare relativă care presupune şi operaţii prin care se
determină adresa respetivă. Registrele prin care se adresează respectivul element nu
trebuiesc folosite şi de alte instrucţiuni sau dacă sunt folosite trebuie salvate la acel
moment ca apoi să se refacă. Toate aceste operaţii necesită o abordare riguroasă şi
coerentă în ceea ce priveşte realizarea programelor într-un limbaj de asamblare.
Abordare impune ca programatorul să cunoască starea tuturor resurselor procesorului
(registrele acestuia, alocarea memoriei, sistemul de întrerupere etc) şi implicaţiile
modificării acestor resurse asupra bunei funcţionări a întregului microsistem.
Realizarea şi rularea unui program în asamblare presupune parcurgerea următoarelor
etape:
• conceperea algoritmului;
• scrierea programului în limbajul de asamblare corespunzător procesorului Z80;
• translarea fişierului text care conţine programul sursă, în fişiere obiect relocabile
utilizând un assembler;
• linke-ditarea fişierelor obiect într-un singur fişier obiect executabil, prin reevaluarea atât
a legăturilor interne cât şi a legăturilor externe. Aceasta etapă de lucru se realizează cu
ajutorul unui program denumit linkeditor;
• încărcarea programului în memoria de lucru a microsistemului;
• rularea programului încărcat în memorie şi evident verificarea rezultatului obţinut.
În cele ce urmează se ilustrează etapele menţionate mai sus, considerând un exemplu
simplu de calcul al sumei unei constante la un vector şi apoi memorarea acelui vector la o
anumită zonă de memorie. Programul realizat şi editat cu un editor de fişiere text este dat
mai jos şi este însoţit de comentarii, astfel că nu mai necesită şi alte explicaţii suplimentare.
12
; Se seteaza constanta CT1 0017 0029 ; Se seteaza constanta CT1 001B 00
CT1 .EQU 14H 0018 0029 CT1 .EQU 14H 001C 00
LP1: LD BC,LD1 0019 0029 01 23 00 LP1: LD BC,LD1 001D 00
LD HL,SD1 0020 002C 21 26 00 LD HL,SD1 001E 00
LD D,03H; 0021 002F 16 03 LD D,03H; 001F 00
LP2: CALL R1 0022 0031 CD 39 00 LP2: CALL R1
DEC D 0023 0034 15 DEC D 0020 C3 29 00
JP NZ,LP2 0024 0035 C2 31 00 JP NZ,LP2
HALT 0025 0038 76 HALT 0023 04
0024 03
0025 02
0026 00
; Rutina care aduna la data 0026 0039 ; Rutina care aduna la data 0027 00
; din memorie de la adresa (BC) 0027 0039 ; din memorie de la adresa (BC) 0028 00
; contanta CT1si o depune 0028 0039 ; contanta CT1si o depune
; la adresa de memorie (HL) 0029 0039 ; la adresa de memorie (HL) 0029 01 23 00
002C 21 26 00
R1: LD A,(BC) 0030 0039 0A R1: LD A,(BC) 002F 16 03
ADD A,CT1 0031 003A C6 14 ADD A,CT1 0031 CD 39 00
LD (HL),A 0032 003C 77 LD (HL),A 0034 15
INC BC 0033 003D 03 INC BC 0035 C2 31 00
INC HL 0034 003E 23 INC HL 0038 76
RET 0035 003F C9 RET
.END 0036 0040 .END 0039 0A
003A C6 14
003C 77
003D 03
003E 23
003F C9
13
Spatiul de memorie necesar executiei programului, dupa rularea acestuia
14
Cererile de magistrală sunt prioritare şi se tratează la sfârşitul ciclurilor maşină.
Întreruperile nemascabile sunt preluate în orice moment şi se tratează la sfârşitul
instrucţiunii în curs de execuţie, iar întreruperile mascabile au prioritatea cea mai mică şi
sunt preluate şi tratate la sfârşitul instrucţiunii în curs de execuţie, numai dacă acestea
(întreruperile nemascabile) au fost activate în prealabil (IF1=1).
15
întreruperii nemascabile prin execuţia rutinei de tratare a întreruperii care se află la adresa
0066H. Modul de conectare a unui periferic care generează o intrerupere nemascabilă şi
tratarea acesteia sunt ilustrate în figurile următoare
16
Observaţie: La resetarea microprocesorului întreruperile mascabile sunt dezactivate, iar
modul setat este modul zero.
Modul 0 de intrerupere
17
Dacă se utilizează controlerul de întrerupere CI 8259, atunci rutinele de tratare a
întreruperilor pot fi plasate oriunde în memoria microsistemului, deoarece acestea sunt
memorate într-o tabelă, iar accesul la adresa rutinei se face prin intermediul a doi octeţi
generaţi de controler.
Modul 1 de intrerupere
Dacă întreruperile sunt validate, iar la sfârşitul instrucţiunii în curs de executie pinul
INT se afla la ‘0’ logic, atunci microprocesorul salveaza PC-ul instructiunii imediat
urmatoare si trece la tratarea intreruperii executand programul care se afla la adresa 0038H.
Întreruperea mascabilă-modul 1 este similara întreruperii nemascabile cu exceptia faptului
ca aceasta (intreruperea nemascabilă) se trateaza cu ajutorul unui program aflat la adresa
0066H. Acest mod de intrerupere se poate utiliza şi în cazul când există mai multe
periferice care generează o întrerupere, urmând ca prioritatea să se stabilească prin
interogare.
Schema de principiu în cazul modului 1 de întrerupere prin care se tratează
întreruperi de la 8 periferice este dată în figura următoare.
18
• microprocesorul ia cunostinţă de întrerupere şi salvează contorul program
corespunzător înstrucţiunii imediat următoare, trecând apoi la execuţia programului de
la adresa 0038H. În cadrul acestui program se citeşte data de la perifericul de intrare şi
se trece la tratarea intreruperii perifericului cu prioritate maximă, ca apoi sa se revină în
programul principal sau sa se trateze întreruperea imedia urmatoare in ordinea
prioritatilor. Achitarea intreruperii trebuie sa o faca rutina de tratare a intreruperilor prin
resetarea cererii (INT i =0).
Programul prin care se realizeaza tratarea intreruperilor este dat mai jos.
19
În cadrul acestui mod de întrerupere se simplifică hardul în ceea ce priveşte
stabilirea priorităţilor, dar creşte durata privind determinarea perifericului care a generat
întreruperea, deoarece aceasta (stabilirea priorităţilor) se face prin program.
Modul 2 de intrerupere
Dacă sunt îndeplinite condiţiile menţionate mai sus, în cazul apariţiei unei întreruperi se
parcurg următoarele etape:
20
Fiecare periferic din familia lui Z80 dispune de o iesire de inhibare a celorlalte
periferice (IEO). De fapt prin acest mecanism se stabileşte prioritatea în cazul apariţiei mai
multor cereri de intrerupere. Când un periferic a generat o întrerupere acesta genereaza un
semnal 0 logic la iesirea IEO, semnal care inhibă toate perifericele plasate fizic după
acesta. Modul de tratare a întreruperii este ilustrat în figura următoare.
Prin utilizarea acestui mod de intrerupere, atăt tabela cât şi rutinele de tratare a
intreruperilor pot fi plasate oriunde în memorie.
Starea HALT
Starea HALT reprezintă starea în care intră microprocesorul Z80 în urma execuţiei
instrucţiunii HALT care are codul 76. Trebuie specificat faptul că pe durata instructiunii
HALT se execută instructiuni NOP.
Scoaterea microprocesorului din această stare se poate face prin resetarea lui, sau
printr-o întrerupere nemascabilă sau mascabilă. Întreruperea mascabilă are efect numai
dacă inainte de intrarea microprocesorului în stare HALT, întreruperile mascabile au fost
activate.
21