Treść książki

Przejdź do opcji czytnikaPrzejdź do nawigacjiPrzejdź do informacjiPrzejdź do stopki
18
1.Architekturaprocesorówrodzinyx86
procesorarealizowaneoperacjeprzetwarzaniadanych,ajednostkawspółpracy
zmagistraląjestodpowiedzialnazawystawianienazewnątrzprocesoraadresówfizycz-
nychpowcześniejszymprzetworzeniuadresówlogicznychzgodniezalgorytmemokre-
ślonymprzezsegmentacjępamięci.
1.1.1.Rejestryprocesora
Rejestryprocesoramożnapodzielićnaczterynastępującegrupy:rejestrflagowy,reje-
stryogólnegoprzeznaczenia,wskaźnikrozkazuorazrejestrysegmentowe.
Rejestrflagowy(znaczników)FRzawieraciągbitówcharakteryzującychwynik
ostatniejoperacjiarytmetycznejlublogicznej,atakżebityustawianeprogramowo,okre-
ślającesposóbpracyprocesora.Niemożeonbyćmodyfikowanyorazodczytywanybez-
pośrednio,adowykonywaniaoperacjinanimsłużąodrębnerozkazy(CLD,STIoraz
CMC).StrukturęrejestruFRprzedstawiononarys.1.2.
Rysunekl.2.Strukturarejestruflagowegoprocesorówrodzinyx86wtrybierzeczywistym
Bityrejestruflagowegomożnapodzielićna
bitywarunkówustawianeprzezjednostkęarytmetyczno-logicznąpokażdej
operacjiarytmetycznejlublogicznejibędącepodstawądowykonywaniarozka-
zówskokówwarunkowych;
bitystanuustawianeprogramowo,określającesposóbpracyprocesora.
Bitywarunków:
C
(ang.Carryflag)flaga(znacznik)przeniesienia,informującaowystąpieniu
przeniesieniaznajstarszegobituwyniku;
O(ang.Overflowflag)flagaprzepełnienia,ustawianapodczasprzekroczeniazakresu
liczbzeznakiem;
Z
(ang.Zeroflag)flagazera,ustawiana,gdywynikostatniejoperacjijestrównyzeru;
S
(ang.Sineflag)flagaznaku,ustawiana,gdywynikostatniejoperacjijestujemny;
P
(ang.Parityflag)flagaparzystości,ustawiana,gdywośmiumłodszychbitach
wynikuznajdujesięparzystaliczbajedynek;
A(ang.Auxiliarycarryflag)flagaprzeniesieniapomocniczego,wykorzystywana
podczasoperacjinaliczbachdziesiętnychwkodzieBCD.
Bitystanu:
D(ang.Directionflag)flagakierunku,określającakierunekoperacjinablokach
pamięci,dlaD=0operacjewykonywane„wprzód”(wkierunkunarastających
adresów),dlaD=1wtył;
I
(ang.Interruptflag)flagamaskowaniaprzerwań,dlaI=0przerwaniazamaskowane;