

# 1 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције, а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: непосредно адресирање (immed), меморијско директно адресирање (memdir), регистарско индиректно адресирање са померајем (regindrom) и регистарско директно адресирање (regdir). Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је старији бајт операнда дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код меморијског директног адресирања 16 битна адреса меморијске локације је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе дат другим, а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код регистарског индиректног адресирања са померајем 8 битни померај је целобројна величина са знаком у другом комплементу дата другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 2 бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

## 2 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције, а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: непосредно адресирање (immed), меморијско директно адресирање (memdir), регистарско индиректно адресирање са померајем (regindrom) и регистарско директно адресирање (regdir). Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је старији бајт операнда дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код меморијског директног адресирања 16 битна адреса меморијске локације је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе дат другим, а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код регистарског индиректног адресирања са померајем 8 битни померај је целобројна величина са знаком у другом комплементу дата другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 2 бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

### 3 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 баjt.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача PC, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: непосредно адресирање (immed), меморијско директно адресирање (memdir), регистарско индиректно адресирање са померајем (regindrom) и регистарско директно адресирање (regdir). Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је млађи бајт операнда дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код меморијског директног адресирања 16 битна адреса меморијске локације је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код регистарског индиректног адресирања са померајем 8 битни померај је целобројна величина са знаком у другом комплементу дата другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 2 бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

## 4 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 баjt.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача PC, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: непосредно адресирање (immed), меморијско директно адресирање (memdir), регистарско индиректно адресирање са померајем (regindrom) и регистарско директно адресирање (regdir). Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је млађи бајт операнда дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код меморијског директног адресирања 16 битна адреса меморијске локације је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код регистарског индиректног адресирања са померајем 8 битни померај је целобројна величина са знаком у другом комплементу дата другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 2 бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 5 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 баjt.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно адресирање (regind), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindpom). Код регистарског директног и регистарског индиректног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код меморијског директног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код регистарског индиректног са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је три бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

## 6 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишијој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: регистарско индиректно са померајем адресирање (regindpom), регистарско директно адресирање (regdir), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског индиректног адресирања са померајем 16 битни померај је целобројна величина са знаком у другом комплементу дата другим и трећим бајтом инструкције при чему је старији бајт дат другим бајтом а млађи бајт помераја трећим бајтом. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код РС релативно са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је два бајта. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 7 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишијој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: регистарско индиректно са померајем адресирање (regindpom), регистарско директно адресирање (regdir), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског индиректног адресирања са померајем 16 битни померај је целобројна величина са знаком у другом комплементу дата другим и трећим бајтом инструкције при чему је старији бајт дат другим бајтом а млађи бајт помераја трећим бајтом. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код РС релативно са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је два бајта. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 8 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно са померајем адресирање (regindrom), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског директног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код регистарског индиректног са померајем адресирања трећи и четврти бајт инструкције садрже 16 битни померај који је дат као целобројна величина са знаком, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи бајт инструкције садржи 8 битни податак. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају

уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији `int`. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом без спајања корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 9 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно са померајем адресирање (regindrom), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског директног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код регистарског индиректног са померајем адресирања трећи и четврти бајт инструкције садрже 16 битни померај који је дат као целобројна величина са знаком, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи бајт инструкције садржи 8 битни податак. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају

уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији `int`. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 10 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим бајтом а старији бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишеј локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удељено за једно место (ASR), инструкција логичког померања садржаја акумулатора удељено за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 11 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о меморијском директном (memdir), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код меморијског адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим а старији бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Бездресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов           |
|-------------|-------------------------------------------|-----------------|
| BEQL        | скок на једнако                           | Z = 1           |
| BNEQ        | скок на неједнако                         | Z = 0           |
| BNEG        | скок на N = 1                             | N = 1           |
| BNNG        | скок на N = 0                             | N = 0           |
| BOVF        | скок на V = 1                             | V = 1           |
| BNVF        | скок на V = 0                             | V = 0           |
| BCR         | скок на C = 1                             | C = 1           |
| BNCR        | скок на C = 0                             | C = 0           |
| BGRT        | скок на веће него (са знаком)             | (N ⊕ V) ∨ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N ⊕ V = 0       |
| BLSS        | скок на мање него (са знаком)             | (N ⊕ V) = 1     |
| BLEQ        | скок на мање него или једнако (са знаком) | (N ⊕ V) ∨ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C ∨ Z = 0       |
| BGREU       | скок на веће него или једнако (без знака) | C = 0           |
| BLSSU       | скок на мање него (без знака)             | C = 1           |
| BLEQU       | скок на мање него или једнако (без знака) | C ∨ Z = 1       |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија

$\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $\text{PC}_{15\ldots 0}$  и програмска статусна реч  $\text{PSW}_{15\ldots 0}$ , затим се у разреде  $\text{PSWI}$  и  $\text{PSWT}$  програмске статусне речи  $\text{PSW}_{15\ldots 0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $\text{PSWL1}$  и  $\text{PSWL0}$  регистра  $\text{PSW}_{15\ldots 0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $\text{IVTP}_{15\ldots 0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $\text{IVTP}_{15\ldots 0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $\text{PC}_{15\ldots 0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигналса спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 12 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о меморијском директном (memdir), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код меморијског адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим а старији бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Бездресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија

$\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $\text{PC}_{15\ldots 0}$  и програмска статусна реч  $\text{PSW}_{15\ldots 0}$ , затим се у разреде  $\text{PSWI}$  и  $\text{PSWT}$  програмске статусне речи  $\text{PSW}_{15\ldots 0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $\text{PSWL1}$  и  $\text{PSWL0}$  регистра  $\text{PSW}_{15\ldots 0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $\text{IVTP}_{15\ldots 0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $\text{IVTP}_{15\ldots 0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $\text{PC}_{15\ldots 0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом без спајања корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 13 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о меморијском директном (memdir), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код меморијског адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим а старији бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према низим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхрона са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 14 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим бајтом а старији бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишеј локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С

удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватавају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 15 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим бајтом а старији бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишеј локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С

удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватавају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 16 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о непосредном (immed), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат другим а старији бајт податка трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други и трећи бајт инструкције садржи 16 битни померај који је дат као целобројна величина са знаком, при чему је млађи бајт помераја дат другим а старији бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Бездресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов           |
|-------------|-------------------------------------------|-----------------|
| BEQL        | скок на једнако                           | Z = 1           |
| BNEQ        | скок на неједнако                         | Z = 0           |
| BNEG        | скок на N = 1                             | N = 1           |
| BNNG        | скок на N = 0                             | N = 0           |
| BOVF        | скок на V = 1                             | V = 1           |
| BNVF        | скок на V = 0                             | V = 0           |
| BCR         | скок на C = 1                             | C = 1           |
| BNCR        | скок на C = 0                             | C = 0           |
| BGRT        | скок на веће него (са знаком)             | (N ⊕ V) ∨ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N ⊕ V = 0       |
| BLSS        | скок на мање него (са знаком)             | (N ⊕ V) = 1     |
| BLEQ        | скок на мање него или једнако (са знаком) | (N ⊕ V) ∨ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C ∨ Z = 0       |
| BGREU       | скок на веће него или једнако (без знака) | C = 0           |
| BLSSU       | скок на мање него (без знака)             | C = 1           |
| BLEQU       | скок на мање него или једнако (без знака) | C ∨ Z = 1       |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија

$\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $\text{PC}_{15\ldots 0}$  и програмска статусна реч  $\text{PSW}_{15\ldots 0}$ , затим се у разреде  $\text{PSWI}$  и  $\text{PSWT}$  програмске статусне речи  $\text{PSW}_{15\ldots 0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $\text{PSWL1}$  и  $\text{PSWL0}$  регистра  $\text{PSW}_{15\ldots 0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $\text{IVTP}_{15\ldots 0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $\text{IVTP}_{15\ldots 0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $\text{PC}_{15\ldots 0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 17 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе меморијске локације дат другим а млађи бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 18 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе меморијске локације дат другим а млађи бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjdjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 19 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишој локацији. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат трећим бајтом а млађи бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 20 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишој локацији. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат трећим бајтом а млађи бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 21 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно адресирање (regind), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom). Код регистарског директног и регистарског индиректног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код меморијског директног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код регистарског индиректног са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је три бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

## 22 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно адресирање (regind), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom). Код регистарског директног и регистарског индиректног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код меморијског директног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код регистарског индиректног са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је три бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 23 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: регистарско индиректно са померајем адресирање (regindpom), регистарско директно адресирање (regdir), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског индиректног адресирања са померајем 16 битни померај је целобројна величина са знаком у другом комплементу дата другим и трећим бајтом инструкције при чему је старији бајт дат другим бајтом а млађи бајт помераја трећим бајтом. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код РС релативно са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је два бајта. Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је старији бајт операнда дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватавају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 24 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: регистарско индиректно са померајем адресирање (regindpom), регистарско директно адресирање (regdir), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског индиректног адресирања са померајем 16 битни померај је целобројна величина са знаком у другом комплементу дата другим и трећим бајтом инструкције при чему је старији бајт дат другим бајтом а млађи бајт помераја трећим бајтом. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код РС релативно са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је два бајта. Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је старији бајт операнда дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватавају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 25 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: регистарско индиректно са померајем адресирање (regindpom), регистарско директно адресирање (regdir), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског индиректног адресирања са померајем 16 битни померај је целобројна величина са знаком у другом комплементу дата другим и трећим бајтом инструкције при чему је старији бајт дат другим бајтом а млађи бајт помераја трећим бајтом. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код РС релативно са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је два бајта. Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је старији бајт операнда дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватавају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач PC<sub>15...0</sub> и програмска статусна реч PSW<sub>15...0</sub>, затим се у разреде PSWI и PSWT програмске статусне речи PSW<sub>15...0</sub> уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра PSW<sub>15...0</sub> уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра IVTP<sub>15...0</sub> (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub>, респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра IVTP<sub>15...0</sub> и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар PC<sub>15...0</sub>.

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 26 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишијој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: непосредно адресирање (immed), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom) и регистарско директно адресирање (regdir). Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта. Код меморијског директног адресирања 16 битна адреса меморијске локације је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код регистарског индиректног адресирања са померајем 8 битни померај је целобројна величина са знаком у другом комплементу дата другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 2 бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 27 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишијој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: непосредно адресирање (immed), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrop) и регистарско директно адресирање (regdir). Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта. Код меморијског директног адресирања 16 битна адреса меморијске локације је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код регистарског индиректног адресирања са померајем 8 битни померај је целобројна величина са знаком у другом комплементу дата другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 2 бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

## 28 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишијој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишијој локацији. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи бајт инструкције садржи 8 битни податак,. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја акумулатора удеосно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом без спајања корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 29 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишијој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишијој локацији. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи бајт инструкције садржи 8 битни податак,. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхрона са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 30 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајта. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишијој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: регистарско индиректно са померајем адресирање (regindpom), регистарско директно адресирање (regdir), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског индиректног адресирања са померајем 16 битни померај је целобројна величина са знаком у другом комплементу дата другим и трећим бајтом инструкције при чему је старији бајт дат другим бајтом а млађи бајт помераја трећим бајтом. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код РС релативно са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је два бајта. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 31 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: непосредно адресирање (immed), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom) и регистарско директно адресирање (regdir). Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта. Код меморијског директног адресирања 16 битна адреса меморијске локације је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код регистарског индиректног адресирања са померајем 8 битни померај је целобројна величина са знаком у другом комплементу дата другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 2 бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја акумулатора удеосно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач PC<sub>15...0</sub> и програмска статусна реч PSW<sub>15...0</sub>, затим се у разреде PSWI и PSWT програмске статусне речи PSW<sub>15...0</sub> уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра PSW<sub>15...0</sub> уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра IVTP<sub>15...0</sub> (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub>, респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра IVTP<sub>15...0</sub> и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар PC<sub>15...0</sub>.

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

## 32 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0], R[1], R[2] и R[3] специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о непосредном (immed), РС релативном са померајем (pcrel), меморијском директном (memdir) или меморијском индиректном (memind) адресирању специфицираном вредностима битова 1 и 0. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат другим а млађи бајт податка трећим бајтом инструкције. Дужина инструкције је три бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим а млађи бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удељено за једно место (ASR), инструкција логичког померања садржаја акумулатора удељено за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач PC<sub>15...0</sub> и програмска статусна реч PSW<sub>15...0</sub>, затим се у разреде PSWI и PSWT програмске статусне речи PSW<sub>15...0</sub> уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра PSW<sub>15...0</sub> уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра IVTP<sub>15...0</sub> (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub>, респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра IVTP<sub>15...0</sub> и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар PC<sub>15...0</sub>.

Магистрала је асинхрона са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом без спајања корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 33 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0], R[1], R[2] и R[3] специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о непосредном (immed), РС релативном са померајем (pcrel), меморијском директном (memdir) или меморијском индиректном (memind) адресирању специфицираном вредностима битова 1 и 0. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат другим а млађи бајт податка трећим бајтом инструкције. Дужина инструкције је три бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим а млађи бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удељено за једно место (ASR), инструкција логичког померања садржаја акумулатора удељено за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чему линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач PC<sub>15...0</sub> и програмска статусна реч PSW<sub>15...0</sub>, затим се у разреде PSWI и PSWT програмске статусне речи PSW<sub>15...0</sub> уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра PSW<sub>15...0</sub> уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра IVTP<sub>15...0</sub> (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub>, респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра IVTP<sub>15...0</sub> и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар PC<sub>15...0</sub>.

Магистрала је асинхрона са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

## 34 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим бајтом а млађи бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишеј локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С

удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватавају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 35 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим бајтом а млађи бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишеј локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С

удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватавају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач PC<sub>15...0</sub> и програмска статусна реч PSW<sub>15...0</sub>, затим се у разреде PSWI и PSWT програмске статусне речи PSW<sub>15...0</sub> уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра PSW<sub>15...0</sub> уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра IVTP<sub>15...0</sub> (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub>, респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра IVTP<sub>15...0</sub> и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар PC<sub>15...0</sub>.

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 36 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind), респективно. Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе меморијске локације дат другим а млађи бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја акумулатора удеосно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 37 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 баjt.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача PC, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, PC релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), PC релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind), респективно. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат другим бајтом а старији бајт податка трећим бајтом. Дужина инструкције је 3 бајта. Код PC релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

## 38 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind), респективно. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат другим бајтом а старији бајт податка трећим бајтом. Дужина инструкције је 3 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 39 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат другим бајтом а старији бајт податка трећим бајтом. Дужина инструкције је 3 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 40 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат другим бајтом а старији бајт податка трећим бајтом. Дужина инструкције је 3 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 41 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно са померајем адресирање (regindrom), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског директног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код регистарског индиректног са померајем адресирања трећи и четврти бајт инструкције садрже 16 битни померај који је дат као целобројна величина са знаком, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат трећим бајтом а старији бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

## 42 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно са померајем адресирање (regindrom), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског директног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код регистарског индиректног са померајем адресирања трећи и четврти бајт инструкције садрже 16 битни померај који је дат као целобројна величина са знаком, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат трећим бајтом а старији бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 43 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат другим бајтом а старији бајт податка трећим бајтом. Дужина инструкције је 3 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

## 44 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат другим бајтом а старији бајт податка трећим бајтом. Дужина инструкције је 3 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 45 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим бајтом а млађи бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишеј локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је старији бајт операнда дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач PC<sub>15...0</sub> и програмска статусна реч PSW<sub>15...0</sub>, затим се у разреде PSWI и PSWT програмске статусне речи PSW<sub>15...0</sub> уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра PSW<sub>15...0</sub> уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра IVTP<sub>15...0</sub> (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub>, респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра IVTP<sub>15...0</sub> и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар PC<sub>15...0</sub>.

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 46 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишијој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 47 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 баjt.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача PC, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, PC релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), PC релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код PC релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 48 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишијој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: регистарско индиректно са померајем адресирање (regindpom), регистарско директно адресирање (regdir), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског индиректног адресирања са померајем 16 битни померај је целобројна величина са знаком у другом комплементу дата другим и трећим бајтом инструкције при чему је старији бајт дат другим бајтом а млађи бајт помераја трећим бајтом. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код РС релативно са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је два бајта. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом без спајања корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 49 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: регистарско индиректно са померајем адресирање (regindpom), регистарско директно адресирање (regdir), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског индиректног адресирања са померајем 16 битни померај је целобројна величина са знаком у другом комплементу дата другим и трећим бајтом инструкције при чему је старији бајт дат другим бајтом а млађи бајт помераја трећим бајтом. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код РС релативно са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је два бајта. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удељено за једно место (ASR), инструкција логичког померања садржаја акумулатора удељено за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 50 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно са померајем адресирање (regindpom), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског директног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код регистарског индиректног са померајем адресирања трећи и четврти бајт инструкције садрже 16 битни померај који је дат као целобројна величина са знаком, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи бајт инструкције садржи 8 битни податак. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају

уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији `int`. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 51 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind), респективно. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат другим бајтом а старији бајт податка трећим бајтом. Дужина инструкције је 3 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигналса спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

## 52 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишој локацији. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи бајт инструкције садржи 8 битни податак. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом без спајања корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 53 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишој локацији. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи бајт инструкције садржи 8 битни податак. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

## 54 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о меморијском директном (memdir), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код меморијског адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим а старији бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према низим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 55 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о меморијском директном (memdir), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код меморијског адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим а старији бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према низим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 56 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат другим бајтом а млађи бајт податка трећим бајтом. Дужина инструкције је 3 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе меморијске локације дат другим а млађи бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 57 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о непосредном (immed), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат другим а старији бајт податка трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други и трећи бајт инструкције садржи 16 битни померај који је дат као целобројна величина са знаком, при чему је млађи бајт помераја дат другим а старији бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Бездресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов           |
|-------------|-------------------------------------------|-----------------|
| BEQL        | скок на једнако                           | Z = 1           |
| BNEQ        | скок на неједнако                         | Z = 0           |
| BNEG        | скок на N = 1                             | N = 1           |
| BNNG        | скок на N = 0                             | N = 0           |
| BOVF        | скок на V = 1                             | V = 1           |
| BNVF        | скок на V = 0                             | V = 0           |
| BCR         | скок на C = 1                             | C = 1           |
| BNCR        | скок на C = 0                             | C = 0           |
| BGRT        | скок на веће него (са знаком)             | (N ⊕ V) ∨ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N ⊕ V = 0       |
| BLSS        | скок на мање него (са знаком)             | (N ⊕ V) = 1     |
| BLEQ        | скок на мање него или једнако (са знаком) | (N ⊕ V) ∨ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C ∨ Z = 0       |
| BGREU       | скок на веће него или једнако (без знака) | C = 0           |
| BLSSU       | скок на мање него (без знака)             | C = 1           |
| BLEQU       | скок на мање него или једнако (без знака) | C ∨ Z = 1       |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија

$\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $\text{PC}_{15\ldots 0}$  и програмска статусна реч  $\text{PSW}_{15\ldots 0}$ , затим се у разреде  $\text{PSWI}$  и  $\text{PSWT}$  програмске статусне речи  $\text{PSW}_{15\ldots 0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $\text{PSWL1}$  и  $\text{PSWL0}$  регистра  $\text{PSW}_{15\ldots 0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $\text{IVTP}_{15\ldots 0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $\text{IVTP}_{15\ldots 0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $\text{PC}_{15\ldots 0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

## 58 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о непосредном (immed), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат другим а старији бајт податка трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други и трећи бајт инструкције садржи 16 битни померај који је дат као целобројна величина са знаком, при чему је млађи бајт помераја дат другим а старији бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Бездресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија

$\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $\text{PC}_{15\ldots 0}$  и програмска статусна реч  $\text{PSW}_{15\ldots 0}$ , затим се у разреде  $\text{PSWI}$  и  $\text{PSWT}$  програмске статусне речи  $\text{PSW}_{15\ldots 0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $\text{PSWL1}$  и  $\text{PSWL0}$  регистра  $\text{PSW}_{15\ldots 0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $\text{IVTP}_{15\ldots 0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $\text{IVTP}_{15\ldots 0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $\text{PC}_{15\ldots 0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 59 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно адресирање (regind), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindpom). Код регистарског директног и регистарског индиректног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код меморијског директног адресирања трећи и четврти бајт инструкције садржи адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код регистарског индиректног са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је три бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 60 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно адресирање (regind), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindpom). Код регистарског директног и регистарског индиректног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код меморијског директног адресирања трећи и четврти бајт инструкције садржи адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код регистарског индиректног са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је три бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 61 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишијој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

## 62 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 63 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: регистарско индиректно са померајем адресирање (regindpom), регистарско директно адресирање (regdir), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског индиректног адресирања са померајем 16 битни померај је целобројна величина са знаком у другом комплементу дата другим и трећим бајтом инструкције при чему је старији бајт дат другим бајтом а млађи бајт помераја трећим бајтом. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код РС релативно са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је два бајта. Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је млађи бајт операнда дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватавају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 64 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о меморијском директном (memdir), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код меморијског адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим а млађи бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 65 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: непосредно адресирање (immed), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom) и регистарско директно адресирање (regdir). Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је старији бајт операнда дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код меморијског директног адресирања 16 битна адреса меморијске локације је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код регистарског индиректног адресирања са померајем 8 битни померај је целобројна величина са знаком у другом комплементу дата другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 2 бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватавају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 66 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно адресирање (regind), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom). Код регистарског директног и регистарског индиректног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код меморијског директног адресирања трећи и четврти бајт инструкције садржи адресу меморијске локације, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код регистарског индиректног са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је три бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 67 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0], R[1], R[2] и R[3] специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о непосредном (immed), РС релативном са померајем (pcrel), меморијском директном (memdir) или меморијском индиректном (memind) адресирању специфицираном вредностима битова 1 и 0. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат другим а млађи бајт податка трећим бајтом инструкције. Дужина инструкције је три бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим а млађи бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удељено за једно место (ASR), инструкција логичког померања садржаја акумулатора удељено за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде PSWI и PSWT програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхрона са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 68 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно адресирање (regind), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom). Код регистарског директног и регистарског индиректног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код меморијског директног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код регистарског индиректног са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је три бајта.

Стек расте према низим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач PC<sub>15...0</sub> и програмска статусна реч PSW<sub>15...0</sub>, затим се у разреде PSWI и PSWT програмске статусне речи PSW<sub>15...0</sub> уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра PSW<sub>15...0</sub> уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра IVTP<sub>15...0</sub> (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub>, респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра IVTP<sub>15...0</sub> и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар PC<sub>15...0</sub>.

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 69 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: непосредно адресирање (immed), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom) и регистарско директно адресирање (regdir). Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта. Код меморијског директног адресирања 16 битна адреса меморијске локације је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код регистарског индиректног адресирања са померајем 8 битни померај је целобројна величина са знаком у другом комплементу дата другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 2 бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја акумулатора удеосно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 70 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишеј локацији. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат трећим бајтом а млађи бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 71 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишијој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим бајтом а млађи бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишијој локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је старији бајт операнда дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чему линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде PSWI и PSWT програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхрона са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

## 72 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишеј локацији. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат трећим бајтом а старији бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 73 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind), респективно. Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

## 74 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкција инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно са померајем адресирање (regindpom), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског директног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код регистарског индиректног са померајем адресирања трећи и четврти бајт инструкције садрже 16 битни померај који је дат као целобројна величина са знаком, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи бајт инструкције садржи 8 битни податак. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају

уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији `int`. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 75 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно са померајем адресирање (regindrom), РС релативно са померајем (rcrel) и непосредно адресирање (immed). Код регистарског директног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код регистарског индиректног са померајем адресирања трећи и четврти бајт инструкције садрже 16 битни померај који је дат као целобројна величина са знаком, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат трећим бајтом а старији бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.

За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 76 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим бајтом а старији бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишој локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је млађи бајт операнда дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач PC<sub>15...0</sub> и програмска статусна реч PSW<sub>15...0</sub>, затим се у разреде PSWI и PSWT програмске статусне речи PSW<sub>15...0</sub> уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра PSW<sub>15...0</sub> уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра IVTP<sub>15...0</sub> (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub>, респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра IVTP<sub>15...0</sub> и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар PC<sub>15...0</sub>.

Магистрала је асинхрона са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 77 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајта. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: регистарско индиректно са померајем адресирање (regindpom), регистарско директно адресирање (regdir), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског индиректног адресирања са померајем 16 битни померај је целобројна величина са знаком у другом комплементу дата другим и трећим бајтом инструкције при чему је старији бајт дат другим бајтом а млађи бајт помераја трећим бајтом. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код РС релативно са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је два бајта. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја акумулатора удеосно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

## 78 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишеј локацији. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат трећим бајтом а старији бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 79 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим бајтом а млађи бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишеј локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С

удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватавају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 80 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно са померајем адресирање (regindpom), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског директног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код регистарског индиректног са померајем адресирања трећи и четврти бајт инструкције садрже 16 битни померај који је дат као целобројна величина са знаком, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат трећим бајтом а млађи бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигналса спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 81 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији, а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о меморијском директном (memdir), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код меморијског адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим а млађи бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Бездресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија

$\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $\text{PC}_{15\ldots 0}$  и програмска статусна реч  $\text{PSW}_{15\ldots 0}$ , затим се у разреде  $\text{PSWI}$  и  $\text{PSWT}$  програмске статусне речи  $\text{PSW}_{15\ldots 0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $\text{PSWL1}$  и  $\text{PSWL0}$  регистра  $\text{PSW}_{15\ldots 0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $\text{IVTP}_{15\ldots 0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $\text{IVTP}_{15\ldots 0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $\text{PC}_{15\ldots 0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

## 82 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира се код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира се код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције, а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: регистарско индиректно адресирање са померајем (regindpom), регистарско директно адресирање (regdir), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског индиректног адресирања са померајем 16 битни померај је целобројна величина са знаком у другом комплементу дата другим и трећим бајтом инструкције, при чему је старији бајт дат другим бајтом, а млађи бајт помераја трећим бајтом. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код РС релативног адресирања са померајем други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је два бајта. Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је млађи бајт операнда дат другим, а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватавају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 83 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције, а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: непосредно адресирање (immed), меморијско директно адресирање (memdir), регистарско индиректно адресирање са померајем (regindrom) и регистарско директно адресирање (regdir). Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је старији бајт операнда дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код меморијског директног адресирања 16 битна адреса меморијске локације је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе дат другим, а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код регистарског индиректног адресирања са померајем 8 битни померај је целобројна величина са знаком у другом комплементу дата другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 2 бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 84 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о непосредном (immed), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат другим а млађи бајт податка трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други и трећи бајт инструкције садржи 16 битни померај који је дат као целобројна величина са знаком, при чему је старији бајт помераја дат другим а млађи бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Бездресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија

$\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $\text{PC}_{15\ldots 0}$  и програмска статусна реч  $\text{PSW}_{15\ldots 0}$ , затим се у разреде  $\text{PSWI}$  и  $\text{PSWT}$  програмске статусне речи  $\text{PSW}_{15\ldots 0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $\text{PSWL1}$  и  $\text{PSWL0}$  регистра  $\text{PSW}_{15\ldots 0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $\text{IVTP}_{15\ldots 0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $\text{IVTP}_{15\ldots 0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $\text{PC}_{15\ldots 0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 85 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 баjt.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно адресирање (regind), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindpom). Код регистарског директног и регистарског индиректног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код меморијског директног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код регистарског индиректног са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је три бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 86 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим бајтом а старији бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишеј локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С

удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватавају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 87 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о меморијском директном (memdir), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код меморијског адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим а старији бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према низим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 88 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим бајтом а старији бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишеј локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удељено за једно место (ASR), инструкција логичког померања садржаја акумулатора удељено за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач PC<sub>15...0</sub> и програмска статусна реч PSW<sub>15...0</sub>, затим се у разреде PSWI и PSWT програмске статусне речи PSW<sub>15...0</sub> уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра PSW<sub>15...0</sub> уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра IVTP<sub>15...0</sub> (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub>, респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра IVTP<sub>15...0</sub> и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар PC<sub>15...0</sub>.

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 89 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о непосредном (immed), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат другим а старији бајт податка трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други и трећи бајт инструкције садржи 16 битни померај који је дат као целобројна величина са знаком, при чему је млађи бајт помераја дат другим а старији бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Бездресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија

$\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $\text{PC}_{15\ldots 0}$  и програмска статусна реч  $\text{PSW}_{15\ldots 0}$ , затим се у разреде  $\text{PSWI}$  и  $\text{PSWT}$  програмске статусне речи  $\text{PSW}_{15\ldots 0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $\text{PSWL1}$  и  $\text{PSWL0}$  регистра  $\text{PSW}_{15\ldots 0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $\text{IVTP}_{15\ldots 0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $\text{IVTP}_{15\ldots 0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $\text{PC}_{15\ldots 0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 90 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о непосредном (immed), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат другим а старији бајт податка трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други и трећи бајт инструкције садржи 16 битни померај који је дат као целобројна величина са знаком, при чему је млађи бајт помераја дат другим а старији бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Бездресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов           |
|-------------|-------------------------------------------|-----------------|
| BEQL        | скок на једнако                           | Z = 1           |
| BNEQ        | скок на неједнако                         | Z = 0           |
| BNEG        | скок на N = 1                             | N = 1           |
| BNNG        | скок на N = 0                             | N = 0           |
| BOVF        | скок на V = 1                             | V = 1           |
| BNVF        | скок на V = 0                             | V = 0           |
| BCR         | скок на C = 1                             | C = 1           |
| BNCR        | скок на C = 0                             | C = 0           |
| BGRT        | скок на веће него (са знаком)             | (N ⊕ V) ∨ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N ⊕ V = 0       |
| BLSS        | скок на мање него (са знаком)             | (N ⊕ V) = 1     |
| BLEQ        | скок на мање него или једнако (са знаком) | (N ⊕ V) ∨ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C ∨ Z = 0       |
| BGREU       | скок на веће него или једнако (без знака) | C = 0           |
| BLSSU       | скок на мање него (без знака)             | C = 1           |
| BLEQU       | скок на мање него или једнако (без знака) | C ∨ Z = 1       |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија

$\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $\text{PC}_{15\ldots 0}$  и програмска статусна реч  $\text{PSW}_{15\ldots 0}$ , затим се у разреде  $\text{PSWI}$  и  $\text{PSWT}$  програмске статусне речи  $\text{PSW}_{15\ldots 0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $\text{PSWL1}$  и  $\text{PSWL0}$  регистра  $\text{PSW}_{15\ldots 0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $\text{IVTP}_{15\ldots 0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $\text{IVTP}_{15\ldots 0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $\text{PC}_{15\ldots 0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 91 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе меморијске локације дат другим а млађи бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја акумулатора удеосно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

## 92 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишеј локацији. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат трећим бајтом а млађи бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач PC<sub>15...0</sub> и програмска статусна реч PSW<sub>15...0</sub>, затим се у разреде PSWI и PSWT програмске статусне речи PSW<sub>15...0</sub> уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра PSW<sub>15...0</sub> уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра IVTP<sub>15...0</sub> (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub>, респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра IVTP<sub>15...0</sub> и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар PC<sub>15...0</sub>.

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 93 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о непосредном (immed), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат другим а млађи бајт податка трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други и трећи бајт инструкције садржи 16 битни померај који је дат као целобројна величина са знаком, при чему је старији бајт помераја дат другим а млађи бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Бездресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија

$\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $\text{PC}_{15\ldots 0}$  и програмска статусна реч  $\text{PSW}_{15\ldots 0}$ , затим се у разреде  $\text{PSWI}$  и  $\text{PSWT}$  програмске статусне речи  $\text{PSW}_{15\ldots 0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $\text{PSWL1}$  и  $\text{PSWL0}$  регистра  $\text{PSW}_{15\ldots 0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $\text{IVTP}_{15\ldots 0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $\text{IVTP}_{15\ldots 0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $\text{PC}_{15\ldots 0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 94 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно адресирање (regind), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom). Код регистарског директног и регистарског индиректног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код меморијског директног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код регистарског индиректног са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је три бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 95 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно адресирање (regind), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom). Код регистарског директног и регистарског индиректног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код меморијског директног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код регистарског индиректног са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је три бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 96 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат другим бајтом а млађи бајт податка трећим бајтом. Дужина инструкције је 3 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе меморијске локације дат другим а млађи бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 97 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: регистарско индиректно са померајем адресирање (regindpom), регистарско директно адресирање (regdir), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског индиректног адресирања са померајем 16 битни померај је целобројна величина са знаком у другом комплементу дата другим и трећим бајтом инструкције при чему је старији бајт дат другим бајтом а млађи бајт помераја трећим бајтом. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код РС релативно са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је два бајта. Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је старији бајт операнда дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватавају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 98 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајта. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: регистарско индиректно са померајем адресирање (regindpom), регистарско директно адресирање (regdir), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског индиректног адресирања са померајем 16 битни померај је целобројна величина са знаком у другом комплементу дата другим и трећим бајтом инструкције при чему је старији бајт дат другим бајтом а млађи бајт помераја трећим бајтом. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код РС релативно са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је два бајта. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удељено за једно место (ASR), инструкција логичког померања садржаја акумулатора удељено за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 99 ЗАДАТAK

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишијој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: непосредно адресирање (immed), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom) и регистарско директно адресирање (regdir). Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта. Код меморијског директног адресирања 16 битна адреса меморијске локације је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код регистарског индиректног адресирања са померајем 8 битни померај је целобројна величина са знаком у другом комплементу дата другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 2 бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 100 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим бајтом а млађи бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишеј локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С

удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватавају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач PC<sub>15...0</sub> и програмска статусна реч PSW<sub>15...0</sub>, затим се у разреде PSWI и PSWT програмске статусне речи PSW<sub>15...0</sub> уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра PSW<sub>15...0</sub> уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра IVTP<sub>15...0</sub> (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub>, респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра IVTP<sub>15...0</sub> и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар PC<sub>15...0</sub>.

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 101 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind), респективно. Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе меморијске локације дат другим а млађи бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја акумулатора удеосно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 102 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно адресирање (regind), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom). Код регистарског директног и регистарског индиректног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код меморијског директног адресирања трећи и четврти бајт инструкције садржи адресу меморијске локације, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код регистарског индиректног са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је три бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхрона са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 103 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind), респективно. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат другим бајтом а старији бајт податка трећим бајтом. Дужина инструкције је 3 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 104 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат другим бајтом а старији бајт податка трећим бајтом. Дужина инструкције је 3 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач PC<sub>15...0</sub> и програмска статусна реч PSW<sub>15...0</sub>, затим се у разреде PSWI и PSWT програмске статусне речи PSW<sub>15...0</sub> уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра PSW<sub>15...0</sub> уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра IVTP<sub>15...0</sub> (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub>, респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра IVTP<sub>15...0</sub> и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар PC<sub>15...0</sub>.

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 105 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишијој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишијој локацији. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи бајт инструкције садржи 8 битни податак,. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја акумулатора удеосно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 106 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе меморијске локације дат другим а млађи бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја акумулатора удеосно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 107 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно са померајем адресирање (regindrom), РС релативно са померајем (rcrel) и непосредно адресирање (immed). Код регистарског директног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код регистарског индиректног са померајем адресирања трећи и четврти бајт инструкције садрже 16 битни померај који је дат као целобројна величина са знаком, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат трећим бајтом а старији бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 108 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишијој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: непосредно адресирање (immed), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom) и регистарско директно адресирање (regdir). Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта. Код меморијског директног адресирања 16 битна адреса меморијске локације је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код регистарског индиректног адресирања са померајем 8 битни померај је целобројна величина са знаком у другом комплементу дата другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 2 бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 109 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишијој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим бајтом а млађи бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишијој локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је старији бајт операнда дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде PSWI и PSWT програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 110 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно са померајем адресирање (regindpom), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског директног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код регистарског индиректног са померајем адресирања трећи и четврти бајт инструкције садрже 16 битни померај који је дат као целобројна величина са знаком, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи бајт инструкције садржи 8 битни податак. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају

уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији `intr`. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 111 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind), респективно. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат другим бајтом а старији бајт податка трећим бајтом. Дужина инструкције је 3 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 112 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о меморијском директном (memdir), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код меморијског адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим а старији бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према низим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 113 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат другим бајтом а млађи бајт податка трећим бајтом. Дужина инструкције је 3 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе меморијске локације дат другим а млађи бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 114 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкција инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно са померајем адресирање (regindpom), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског директног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код регистарског индиректног са померајем адресирања трећи и четврти бајт инструкције садрже 16 битни померај који је дат као целобројна величина са знаком, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи бајт инструкције садржи 8 битни податак. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају

уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији `int`. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 115 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о непосредном (immed), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат другим а старији бајт податка трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други и трећи бајт инструкције садржи 16 битни померај који је дат као целобројна величина са знаком, при чему је млађи бајт помераја дат другим а старији бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Бездресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов           |
|-------------|-------------------------------------------|-----------------|
| BEQL        | скок на једнако                           | Z = 1           |
| BNEQ        | скок на неједнако                         | Z = 0           |
| BNEG        | скок на N = 1                             | N = 1           |
| BNNG        | скок на N = 0                             | N = 0           |
| BOVF        | скок на V = 1                             | V = 1           |
| BNVF        | скок на V = 0                             | V = 0           |
| BCR         | скок на C = 1                             | C = 1           |
| BNCR        | скок на C = 0                             | C = 0           |
| BGRT        | скок на веће него (са знаком)             | (N ⊕ V) ∨ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N ⊕ V = 0       |
| BLSS        | скок на мање него (са знаком)             | (N ⊕ V) = 1     |
| BLEQ        | скок на мање него или једнако (са знаком) | (N ⊕ V) ∨ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C ∨ Z = 0       |
| BGREU       | скок на веће него или једнако (без знака) | C = 0           |
| BLSSU       | скок на мање него (без знака)             | C = 1           |
| BLEQU       | скок на мање него или једнако (без знака) | C ∨ Z = 1       |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија

$\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $\text{PC}_{15\ldots 0}$  и програмска статусна реч  $\text{PSW}_{15\ldots 0}$ , затим се у разреде  $\text{PSWI}$  и  $\text{PSWT}$  програмске статусне речи  $\text{PSW}_{15\ldots 0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $\text{PSWL1}$  и  $\text{PSWL0}$  регистра  $\text{PSW}_{15\ldots 0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $\text{IVTP}_{15\ldots 0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $\text{IVTP}_{15\ldots 0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $\text{PC}_{15\ldots 0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 116 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно адресирање (regind), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindpom). Код регистарског директног и регистарског индиректног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код меморијског директног адресирања трећи и четврти бајт инструкције садржи адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код регистарског индиректног са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је три бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигналса спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 117 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind), респективно. Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 118 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно са померајем адресирање (regindpom), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског директног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код регистарског индиректног са померајем адресирања трећи и четврти бајт инструкције садрже 16 битни померај који је дат као целобројна величина са знаком, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат трећим бајтом а млађи бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 119 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind). Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 120 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкција инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно адресирање (regind), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom). Код регистарског директног и регистарског индиректног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код меморијског директног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код регистарског индиректног са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је три бајта.

Стек расте према низим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 121 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о меморијском директном (memdir), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код меморијског адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим а млађи бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 122 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0], R[1], R[2] и R[3] специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о непосредном (immed), РС релативном са померајем (pcrel), меморијском директном (memdir) или меморијском индиректном (memind) адресирању специфицираном вредностима битова 1 и 0. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат другим а млађи бајт податка трећим бајтом инструкције. Дужина инструкције је три бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим а млађи бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удељено за једно место (ASR), инструкција логичког померања садржаја акумулатора удељено за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чему линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде PSWI и PSWT програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 123 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно адресирање (regind), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom). Код регистарског директног и регистарског индиректног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код меморијског директног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код регистарског индиректног са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је три бајта.

Стек расте према низим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

## 124 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишеј локацији. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат трећим бајтом а млађи бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 125 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишијој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим бајтом а млађи бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишијој локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је старији бајт операнда дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чему линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде PSWI и PSWT програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхрона са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 126 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind), респективно. Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе меморијске локације дат другим а млађи бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја акумулатора удеосно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 127 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишој локацији. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је млађи бајт податка дат трећим бајтом а старији бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 128 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind), респективно. Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са једном магистралом. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигналса са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 129 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишој локацији. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи бајт инструкције садржи 8 битни податак. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом са спајањем корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 130 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: непосредно адресирање (immed), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom) и регистарско директно адресирање (regdir). Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је млађи бајт операнда дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код меморијског директног адресирања 16 битна адреса меморијске локације је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код регистарског индиректног адресирања са померајем 8 битни померај је целобројна величина са знаком у другом комплементу дата другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 2 бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов           |
|-------------|-------------------------------------------|-----------------|
| BEQL        | скок на једнако                           | Z = 1           |
| BNEQ        | скок на неједнако                         | Z = 0           |
| BNEG        | скок на N = 1                             | N = 1           |
| BNNG        | скок на N = 0                             | N = 0           |
| BOVF        | скок на V = 1                             | V = 1           |
| BNVF        | скок на V = 0                             | V = 0           |
| BCR         | скок на C = 1                             | C = 1           |
| BNCR        | скок на C = 0                             | C = 0           |
| BGRT        | скок на веће него (са знаком)             | (N ⊕ V) ∨ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N ⊕ V = 0       |
| BLSS        | скок на мање него (са знаком)             | (N ⊕ V) = 1     |
| BLEQ        | скок на мање него или једнако (са знаком) | (N ⊕ V) ∨ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C ∨ Z = 0       |
| BGREU       | скок на веће него или једнако (без знака) | C = 0           |
| BLSSU       | скок на мање него (без знака)             | C = 1           |
| BLEQU       | скок на мање него или једнако (без знака) | C ∨ Z = 1       |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде PSWI и PSWT програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 131 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкција инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно са померајем адресирање (regindpom), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског директног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код регистарског индиректног са померајем адресирања трећи и четврти бајт инструкције садрже 16 битни померај који је дат као целобројна величина са знаком, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи бајт инструкције садржи 8 битни податак. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају

уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији `int`. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована директним повезивањем прекидачких мрежа. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са спајањем корака и једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 132 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим бајтом а старији бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишој локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је млађи бајт операнда дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач PC<sub>15...0</sub> и програмска статусна реч PSW<sub>15...0</sub>, затим се у разреде PSWI и PSWT програмске статусне речи PSW<sub>15...0</sub> уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра PSW<sub>15...0</sub> уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра IVTP<sub>15...0</sub> (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub>, респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра IVTP<sub>15...0</sub> и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар PC<sub>15...0</sub>.

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 133 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим бајтом а старији бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишој локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је млађи бајт операнда дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чему линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде PSWI и PSWT програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхрона са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 134 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим бајтом а млађи бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишеј локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С

удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватавају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 135 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно са померајем адресирање (regindpom), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског директног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код регистарског индиректног са померајем адресирања трећи и четврти бајт инструкције садрже 16 битни померај који је дат као целобројна величина са знаком, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат трећим бајтом а млађи бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 136 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији, а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о меморијском директном (memdir), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код меморијског адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим а млађи бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Бездресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија

$\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $\text{PC}_{15\ldots 0}$  и програмска статусна реч  $\text{PSW}_{15\ldots 0}$ , затим се у разреде  $\text{PSWI}$  и  $\text{PSWT}$  програмске статусне речи  $\text{PSW}_{15\ldots 0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $\text{PSWL1}$  и  $\text{PSWL0}$  регистра  $\text{PSW}_{15\ldots 0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $\text{IVTP}_{15\ldots 0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $\text{IVTP}_{15\ldots 0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $\text{PC}_{15\ldots 0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са два типа микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 137 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind), респективно. Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе меморијске локације дат другим а старији бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом без спајања корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 138 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкција инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно са померајем адресирање (regindpom), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског директног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код регистарског индиректног са померајем адресирања трећи и четврти бајт инструкције садрже 16 битни померај који је дат као целобројна величина са знаком, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат трећим бајтом а млађи бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 139 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно адресирање (regind), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom). Код регистарског директног и регистарског индиректног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код меморијског директног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код регистарског индиректног са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је три бајта.

Стек расте према низим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 140 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишеј локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о меморијском директном (memdir), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код меморијског адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим а млађи бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 141 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0], R[1], R[2] и R[3] специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о непосредном (immed), РС релативном са померајем (pcrel), меморијском директном (memdir) или меморијском индиректном (memind) адресирању специфицираном вредностима битова 1 и 0. Код непосредног адресирања други и трећи бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат другим а млађи бајт податка трећим бајтом инструкције. Дужина инструкције је три бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим а млађи бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удељено за једно место (ASR), инструкција логичког померања садржаја акумулатора удељено за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чему линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде PSWI и PSWT програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 142 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно адресирање (regind), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom). Код регистарског директног и регистарског индиректног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код меморијског директног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код регистарског индиректног са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је три бајта.

Стек расте према низим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја

акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији imm. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 143 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишијој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим бајтом а млађи бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишијој локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је старији бајт операнда дат другим а млађи бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чему линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде PSWI и PSWT програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхрона са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 144 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине један бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Бит 2 има вредност 0 за регистарско директно и регистарско индиректно адресирање, а вредност 1 за непосредно, РС релативно са померајем, меморијско директно и меморијско индиректно адресирање. Уколико бит 2 има вредност 0, тада се вредностима 0 и 1 бита 1 одређује регистарско директно (regdir) и регистарско индиректно адресирање (regind), респективно, а битом 0 специфицира регистар опште намене R[0] или R[1] који се користе за ова два адресирања. Дужина инструкције је 1 бајт. Уколико бит 2 има вредност 1, тада битови 1 и 0 одређује непосредно (immed), РС релативно са померајем (pcrel), меморијско директно (memdir) и меморијско индиректно адресирање (memind), респективно. Код непосредног адресирања други бајт инструкције садржи 8 битни податак. Дужина инструкције је 2 бајта. Код РС релативног са померајем адресирања други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је 2 бајта. Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе меморијске локације дат другим а млађи бајт трећим бајтом. Дужина инструкције је 3 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја акумулатора удеосно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом без спајања корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 145 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој локацији а старији бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 16 битна целобројна величина са знаком дата другим и трећим бајтом инструкције, при чему је млађи бајт дат другим а старији трећим бајтом инструкције. Дужина инструкције је три бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања трећи и четврти бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат трећим бајтом а старији бајт адресе четвртим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишој локацији. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи бајт инструкције садржи 8 битни податак. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на последњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржаја акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати ожиченом реализацијом без спајања корака.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 146 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: непосредно адресирање (immed), меморијско директно адресирање (memdir), регистарско индиректно са померајем адресирање (regindrom) и регистарско директно адресирање (regdir). Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је млађи бајт операнда дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код меморијског директног адресирања 16 битна адреса меморијске локације је дата другим и трећим бајтом инструкције, при чему је млађи бајт адресе дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта. Код регистарског индиректног адресирања са померајем 8 битни померај је целобројна величина са знаком у другом комплементу дата другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 2 бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удеосно за једно место (ASR), инструкција логичког померања садржаја

акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15...0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15...0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15...0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чему линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији  $\text{intm}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде PSWI и PSWT програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхрона са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 147 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим бајтом а старији бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишој локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је млађи бајт операнда дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чему линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде PSWI и PSWT програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 148 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 2 бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се млађи бајт налази на нижој а старији бајт на вишој адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је млађи бајт адресе скока дат другим бајтом инструкције а старији бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је млађи бајт адресе дат другим бајтом а старији бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је млађи бајт адресе налази на нижој а старији бајт адресе на вишој локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 16 битни операнд је дат другим и трећим бајтом инструкције, при чему је млађи бајт операнда дат другим а старији бајт трећим бајтом. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 3 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на задњу заузету меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора

удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                     |
|-------------|-------------------------------------------|---------------------------|
| BEQL        | скок на једнако                           | $Z = 1$                   |
| BNEQ        | скок на неједнако                         | $Z = 0$                   |
| BNEG        | скок на $N = 1$                           | $N = 1$                   |
| BNNG        | скок на $N = 0$                           | $N = 0$                   |
| BOVF        | скок на $V = 1$                           | $V = 1$                   |
| BNVF        | скок на $V = 0$                           | $V = 0$                   |
| BCR         | скок на $C = 1$                           | $C = 1$                   |
| BNCR        | скок на $C = 0$                           | $C = 0$                   |
| BGRT        | скок на веће него (са знаком)             | $(N \oplus V) \vee Z = 0$ |
| BGRE        | скок на веће него или једнако (са знаком) | $N \oplus V = 0$          |
| BLSS        | скок на мање него (са знаком)             | $(N \oplus V) = 1$        |
| BLEQ        | скок на мање него или једнако (са знаком) | $(N \oplus V) \vee Z = 1$ |
| BGRTU       | скок на веће него (без знака)             | $C \vee Z = 0$            |
| BGREU       | скок на веће него или једнако (без знака) | $C = 0$                   |
| BLSSU       | скок на мање него (без знака)             | $C = 1$                   |
| BLEQU       | скок на мање него или једнако (без знака) | $C \vee Z = 1$            |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама  $\text{intr}_3$  до  $\text{intr}_1$ . Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи  $\text{PSW}_{15\ldots 0}$  налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра  $\text{PSW}_{15\ldots 0}$  уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама  $\text{intr}_3$  до  $\text{intr}_1$  се могу селективно маскирати разредима 3 до 1 регистра маске  $\text{IMR}_{15\ldots 0}$ . Прекиди који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$  уређени су по приоритетима при чemu линија  $\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде PSWI и PSWT програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде PSWL1 и PSWL0 регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузета магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 149 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине 1 бајт. Адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој а млађи бајт на вишеј адреси.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0000 за све инструкције условног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 0001 за све инструкције безусловног скока Битовима 3 до 0 првог бајта инструкције специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Битови 7, 6, 5 и 4 првог бајта инструкције су 1111 за безадресне инструкције. Битовима 3 до 0 првог бајта инструкције специфицира код операције за безадресне инструкције. Дужина инструкција је један бајт.

Битови 7, 6, 5 и 4 првог бајта инструкције у опсегу вредности 0010 до 1110 специфицирају код операције за адресне инструкције. Дужина инструкција је 1, 2, или 3 бајта и зависи од специфицираног начина адресирања.

Начини адресирања су специфицирани битовима 3 и 2 првог бајта инструкције. Процесор поседује следеће начине адресирања: меморијско директно адресирање (memdir), меморијско индиректно адресирање (memind), регистарско директно адресирање (regdir) и непосредно адресирање (immed). Код меморијског директног и меморијског индиректног адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим бајтом а млађи бајт адресе трећим бајтом. Код меморијског индиректног адресирања адреса дужине 16 бита заузима две суседне меморијске локације, при чему је старији бајт адресе налази на нижој а млађи бајт адресе на вишеј локацији. Битови 1 до 0 другог бајта инструкције се не користе. Дужина инструкција је три бајта. Код регистарског директног адресирања битови 1 и 0 првог бајта инструкције се користе за адресирање једног од регистара опште намене R[0] до R[3]. Дужина инструкција је 1 бајт. Код непосредног адресирања 8 битни операнд је дат другим бајтом инструкције. Битови 1 и 0 првог бајта инструкције се не користе. Дужина инструкција је 2 бајта.

Стек расте према вишим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С

удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора С улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора AW у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора AW у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса 8 битне величине у акумулатор AB (LD), инструкција преноса 16 битне величине у акумулатор AW (LDW), инструкција преноса 8 битне величине из акумулатора AB (ST), инструкција преноса 16 битне величине из акумулатора AW(STW), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спљашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спљашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чему линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватавају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15..0}$  и програмска статусна реч  $PSW_{15..0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15..0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15..0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15..0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15..0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15..0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са две магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са вертикалним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.

# 150 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за инструкције скока, при чему бит 6 првог бајта инструкције има вредност 0 за инструкција условног скока и 1 за инструкције безусловног скока. Битовима 5 до 0 првог бајта инструкције специфицира код операције за инструкције условног скока. Инструкције условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата другим бајтом инструкције. Дужина инструкције је два бајта. Битовима 5 до 0 првог бајта инструкције се специфицира код операције за инструкције безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата другим и трећим бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је три бајта.

Бит 7 првог бајта инструкције има вредност 1 за безадресне и адресне инструкције, при чему бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и 1 за адресне инструкције. Битовима 5 до 0 првог бајта инструкције специфицира се код операције за безадресне инструкције. Дужина безадресних инструкције инструкција је један бајт. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за адресне инструкције. Дужина инструкција је два, три или четири бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 7 и 6 другог бајта инструкције специфицира начина адресирања. Процесор поседује следеће начине адресирања: регистарско директно адресирање (regdir), регистарско индиректно са померајем адресирање (regindpom), РС релативно са померајем (pcrel) и непосредно адресирање (immed). Код регистарског директног адресирања се користе неки од регистара опште намене R[0] до R[63] специфициран битовима 5 до 0 другог бајта инструкције. Дужина инструкција је два бајта. Код регистарског индиректног са померајем адресирања трећи и четврти бајт инструкције садрже 16 битни померај који је дат као целобројна величина са знаком, при чему је старији бајт адресе дат трећим бајтом а млађи бајт адресе четвртим бајтом. Један од регистара опште намене R[0] до R[63] који се користи специфициран је битовима 5 до 0 другог бајта инструкције. Дужина инструкција је четири бајта. Код РС релативно са померајем адресирања трећи бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је три бајта. Код непосредног адресирања трећи и четврти бајт инструкције садрже 16 битни податак, при чему је старији бајт податка дат трећим бајтом а млађи бајт податка четвртим бајтом. Битови 4 до 0 другог бајта инструкције се не користе. Дужина инструкција је четири бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Безадресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржај акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чиму линија intr<sub>3</sub> има највиши, а линија intr<sub>1</sub> најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спољашњи немаскирајући захтев за прекид долази по линији int. Унутрашњи прекиди су прекид због

грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $PC_{15...0}$  и програмска статусна реч  $PSW_{15...0}$ , затим се у разреде  $PSWI$  и  $PSWT$  програмске статусне речи  $PSW_{15...0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $PSWL1$  и  $PSWL0$  регистра  $PSW_{15...0}$  уписује ниво приоритета прекидне рутине на коју се скаче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $IVTP_{15...0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $intr_3$  до  $intr_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спољашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $IVTP_{15...0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $PC_{15...0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са мешовитим кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на [jjordjevic@etf.rs](mailto:jdjordjevic@etf.rs).

# 151 ЗАДАТАК

Посматра се део рачунара који чине меморија, процесор и магистрала.

Меморија је капацитета  $2^{16}$  бајтова. Ширина меморијске речи је 1 бајт.

Процесор је са једноадресним форматом инструкција. Подаци су целобројне величине са знаком и без знака дужине два бајта. Подаци и адресе у меморији заузимају две суседне меморијске локације, при чему се старији бајт налази на нижој локацији, а млађи бајт на вишој локацији.

У процесору постоје безадресне инструкције, инструкције условног скока, инструкције безусловног скока и адресне инструкције.

Бит 7 првог бајта инструкције има вредност 0 за безадресне инструкције и инструкције скока, док бит 6 првог бајта инструкције има вредност 0 за безадресне инструкције и вредност 1 за инструкције скока. Битовима 5 до 0 првог бајта инструкција специфицира се код операције за безадресне инструкције. Дужина инструкција је 1 бајт. Бит 5 првог бајта инструкције има вредност 0 за инструкције условног скока и 1 за инструкције безусловног скока. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција условног скока. Инструкција условног скока се реализују као релативни скок у односу на текућу вредност програмског бројача РС, а померај је 8 битна целобројна величина са знаком дата 2. бајтом инструкције. Дужина инструкција је 2 бајта. Битовима 4 до 0 првог бајта инструкција специфицира се код операције за инструкција безусловног скока. Инструкције безусловног скока се реализују као апсолутни скокови, а адреса скока је дата 2. и 3. бајтом инструкције, при чему је старији бајт адресе скока дат другим бајтом инструкције а млађи бајт адресе скока трећим бајтом инструкције. Дужина инструкција је 3 бајта.

Бит 7 првог бајта инструкције има вредност 1 за адресне инструкције. Битовима 6 до 3 првог бајта инструкција специфицира се код операције. Дужина инструкција је 1, 2 или 3 бајта и зависи од специфицираног начина адресирања.

За адресне инструкције се битовима 2, 1 и 0 првог бајта инструкције специфицира начин адресирања и регистар опште намене уколико се користи у задатом начину адресирања. Уколико бит 2 има вредност 0, ради се о регистарском директном адресирању (regdir) код кога се користи један од регистара опште намене R[0] и R[1], или базни регистар BR<sub>15...0</sub> или индексни регистар XR<sub>15...0</sub> што је специфициран вредностима 00, 01, 10 и 11 битова 1 и 0. Дужина инструкције је један бајт. Уколико бит 2 има вредност 1, ради се о меморијском директном (memdir), базном адресирању са померајем (base), индексном адресирању са померајем (index) или о базно индексном адресирању са померајем (baseindex) специфицираном вредностима битова 1 и 0. Код меморијског адресирања други и трећи бајт инструкције садрже адресу меморијске локације, при чему је старији бајт адресе дат другим а млађи бајт адресе трећим бајтом инструкције. Дужина инструкције је три бајта. Код базног адресирања са померајем имплицитно се користи базни регистар BR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код индексног адресирања са померајем имплицитно се користи индексни регистар XR<sub>15...0</sub>, док други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкције је два бајта. Код базно индексног адресирања са померајем имплицитно се користе регистри BR<sub>15...0</sub> и XR<sub>15...0</sub>, а други бајт инструкције садржи 8 битни померај који је дат као целобројна величина са знаком. Дужина инструкција је 2 бајта.

Стек расте према нижим меморијским локацијама, а регистар SP указује на прву слободну меморијску локацију.

Бездресне инструкције су инструкција повратка из потпрограма (RTS), инструкција повратка из прекидне рутине (RTI), инструкција аритметичког померања садржаја акумулатора удесно за једно место (ASR), инструкција логичког померања садржаја акумулатора удесно за једно место (LSR), инструкција ротирања садржаја акумулатора удесно за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C удесно за једно место (RORC), инструкција аритметичког померања садржаја акумулатора улево за једно место (ASL), инструкција логичког померања садржаја акумулатора улево за једно место (LSR), инструкција ротирања садржаја акумулатора улево за једно место (ROR), инструкција ротирања садржаја акумулатора и индикатора C улево за једно место (RORC), инструкција постављања индикатора I на 1 (INTE), инструкција постављања индикатора I на 0 (INTD), инструкција постављања индикатора T на 1 (TRPE), инструкција постављања индикатора T на 0 (TRPD), инструкција преноса садржаја акумулатора A у регистар IVTP (STIVTP) и инструкција преноса садржај акумулатора A у регистар SP (STSP).

Инструкције условног скока су:

| Инструкција | Значење                                   | Услов                       |
|-------------|-------------------------------------------|-----------------------------|
| BEQL        | скок на једнако                           | Z = 1                       |
| BNEQ        | скок на неједнако                         | Z = 0                       |
| BNEG        | скок на N = 1                             | N = 1                       |
| BNNG        | скок на N = 0                             | N = 0                       |
| BOVF        | скок на V = 1                             | V = 1                       |
| BNVF        | скок на V = 0                             | V = 0                       |
| BCR         | скок на C = 1                             | C = 1                       |
| BNCR        | скок на C = 0                             | C = 0                       |
| BGRT        | скок на веће него (са знаком)             | (N $\oplus$ V) $\vee$ Z = 0 |
| BGRE        | скок на веће него или једнако (са знаком) | N $\oplus$ V = 0            |
| BLSS        | скок на мање него (са знаком)             | (N $\oplus$ V) = 1          |
| BLEQ        | скок на мање него или једнако (са знаком) | (N $\oplus$ V) $\vee$ Z = 1 |
| BGRTU       | скок на веће него (без знака)             | C $\vee$ Z = 0              |
| BGREU       | скок на веће него или једнако (без знака) | C = 0                       |
| BLSSU       | скок на мање него (без знака)             | C = 1                       |
| BLEQU       | скок на мање него или једнако (без знака) | C $\vee$ Z = 1              |

Инструкције безусловног скока су инструкција безусловног скока (JMP) и инструкција скока на потпрограм (JSR).

Инструкција скока је и инструкција прекида (INT). Број улаза у табелу са адресама прекидних рутина је 8-мо битна целобројна величина без знака дата 2. бајтом инструкције. Дужина инструкције је 2 бајта.

Адресне инструкције су инструкција преноса у акумулатор (LD), инструкција преноса из акумулатора (ST), аритметичка инструкција сабирања (ADD), аритметичка инструкција одузимања (SUB), логичка инструкција И (AND), логичка инструкција ИЛИ (OR), логичка инструкција ексклузивно ИЛИ (XOR), логичка инструкција инвертовања (NOT).

Спољашњи маскирајући захтеви за прекид долазе од 3 улазно/излазна уређаја по линијама intr<sub>3</sub> до intr<sub>1</sub>. Ови прекиди се називају спољашњи прекиди јер долазе од уређаја ван процесора, као и маскирајући прекиди, јер су дозвољени или маскирани и процесор на њих реагује или не реагује у зависности од тога да ли се у разреду PSWI регистра програмске статусне речи PSW<sub>15...0</sub> налази вредност 1 или 0, респективно. Дозвољавање и маскирање прекида се реализује програмским путем извршавањем инструкција INTE и INTD којима се у разред PSWI регистра PSW<sub>15...0</sub> уписују вредности 1 или 0, респективно. Захтеви за прекид по линијама intr<sub>3</sub> до intr<sub>1</sub> се могу селективно маскирати разредима 3 до 1 регистра маске IMR<sub>15...0</sub>. Прекиди који долазе по линијама intr<sub>3</sub> до intr<sub>1</sub> уређени су по приоритетима при чemu линија

$\text{intr}_3$  има највиши, а линија  $\text{intr}_1$  најнижи ниво приоритета. Захтеви за прекид се прихватају уколико је њихов ниво виши од нивоа приоритета текућег програма. Спљашњи немаскирајући захтев за прекид долази по линији  $\text{int}$ . Унутрашњи прекиди су прекид због грешке у коду операције, прекид због грешке у адресирању и прекид због задатог режима рада прекид после сваке инструкције.

Опслуживање захтева за прекид се састоји из две групе корака.

У оквиру прве групе корака на стеку се чувају програмски бројач  $\text{PC}_{15\ldots 0}$  и програмска статусна реч  $\text{PSW}_{15\ldots 0}$ , затим се у разреде  $\text{PSWI}$  и  $\text{PSWT}$  програмске статусне речи  $\text{PSW}_{15\ldots 0}$  уписују вредности 0 и у случају маскирајућих прекида у разреде  $\text{PSWL1}$  и  $\text{PSWL0}$  регистра  $\text{PSW}_{15\ldots 0}$  уписује ниво приоритета прекидне рутине на коју се скоче. У оквиру друге групе корака утврђује се адреса прекидне рутине. Утврђивање адресе прекидне рутине се реализује на основу садржаја табеле адреса прекидних рутина, која се обично назива IV табела (*Interrupt Vector Table*), и броја улаза у IV табелу. Стога је у поступку иницијализације целог система у меморији, почев од адресе на коју указује садржај регистра  $\text{IVTP}_{15\ldots 0}$  (*Interrupt Vector Table Pointer*), креирана IV табела са 8 улаза, тако да се у улазима 7 до 5 налазе адресе прекидних рутина за сваки од прекида који долазе по линијама  $\text{intr}_3$  до  $\text{intr}_1$ , респективно. Адресе прекидних рутина за прекид због грешке у коду операције, грешке у адресирању, спљашњи немаскирајући прекид и прекид због задатог режима рада прекид после сваке инструкције, налазе се у улазима 3, 2, 1 и 0 табеле са адресама прекидних рутина. Како је меморијска реч 8 битна величина, а адреса прекидне рутине 16 битна величина, то сваки улаз у IV табели заузима по две суседне меморијске локације. Због тога се најпре број улаза множењем са два претвара у померај, па затим померај сабира са садржајем регистра  $\text{IVTP}_{15\ldots 0}$  и на крају добијена вредност користи као адреса са које се чита адреса прекидне рутине и уписује у регистар  $\text{PC}_{15\ldots 0}$ .

Магистрала је асинхронна са атомским циклусима читања и уписа. Користи се паралелни арбитратор са 4 паре линија за захтев и потврду. Процесор и меморија имају посебне сигнале такта, а постоји и посебан сигнал такта магистрале. Постоји и сигнал заузећа магистрале.

Реализовати процесор, меморију и арбитратор магистрале. Операциона јединица треба да буде реализована са три магистрале. Управљачку јединицу процесора реализовати микропрограмском реализацијом са хоризонталним кодирањем управљачких сигнала са једним типом микроинструкција.

#### НАПОМЕНА:

1. Постављање индикатора N, Z, C и V у инструкцијама ASR, LSR, ROR, RORC, ASL, LSR, ROR, RORC, LD, ADD, SUB, AND, OR, XOR, NOT треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja**.
2. Реализација процесора треба да буде урађена на исти начин као што је то урађено у случају процесора датог у документу **Šablon izveštaja** едитовањем текста из документа **Šablon izveštaja** и Visio слика датих у архиви **slike**.
3. За све нејасноће око спецификације архитектуре процесора и начина реализације процесора јавити се на **jdjordjevic@etf.rs**.