| 1. međuispit iz Arhitekture računala 1 Prezime i ime (velikim slovima):                                                                                                                  | JMBAG:                                 | 25. travnja 2014.             |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|-------------------------------|
| Izjavljujem da tijekom izrade ove zadaće neću od drugoga primiti niti drugo<br>Ove su radnje teška povreda Kodeksa ponašanja te mogu uzrokovati i dozvoljava pisanje ove zadaće. Potpis: |                                        |                               |
| Dozvoljeno je koristiti isključivo službeni šalabahter (popis naredaba FRI programa. Sve zadatke rješavati na ovaj papir. Međuispit traje 120 minuta.                                    | SC-a). Programe treba pisati uredno    | i komentirati pojedine cjelin |
| <b>1a. (3 boda)</b> U memoriju čije riječi su široke 8 bita podatci se uj                                                                                                                | pisuju u redoslijedu <b>1</b>          | 00                            |
| little-endian. Od adrese 100 <sub>16</sub> upišite redom sljedeće podatke (tablicu popunite u <u>heksadekadskoj</u> brojevnoj bazi):                                                     |                                        | 01                            |
|                                                                                                                                                                                          |                                        | 02                            |
|                                                                                                                                                                                          | 1                                      | 03                            |
| -1030 <sub>10</sub> u 32-bitom formatu 2'k.                                                                                                                                              | 1                                      | 04                            |
| 1030 <sub>10</sub> u 32-bitnom formatu NBC,                                                                                                                                              | 1                                      | 05                            |
| broj 41 <sub>10</sub> u 16-bitnom formatu 2'k,                                                                                                                                           | 1                                      | 06                            |
| 41 <sub>10</sub> u 8-bitnom formatu s bitom za predznak,                                                                                                                                 |                                        | 07                            |
| -41 <sub>10</sub> u 8-bitnom formatu s bitom za predznak.                                                                                                                                | 1                                      | 08                            |
| MORA SE VIDJETI POSTUPAK PRETVORBE A NE SAMO REZULT                                                                                                                                      | 'ATI                                   | 09                            |
| WORKS SE VIDIETT FOSTOFAR FRETVORDE A NE SAINO REZOLT                                                                                                                                    |                                        | 0A                            |
|                                                                                                                                                                                          | 10                                     | 0B                            |
| Rastući brid CLOCK-a: Ras                                                                                                                                                                | zina izvođenja:<br>stući brid CLOCK-a: |                               |
| Padajući brid CLOCK-a:Padajući brid CLOCK-a:                                                                                                                                             | dajući brid CLOCK-a:                   |                               |
|                                                                                                                                                                                          |                                        |                               |
| 1c. (0,5 boda) Naredba LOAD efektivno traje ciklusa (uz pre                                                                                                                              | etpostavku da je memorija brza).       | Ovaj hazard naziva se         |
| <b>1d. (1 bod)</b> Čitanje iz brze memorije traje takt(ova) CL memoriju traje takt(ova). Ako je spojene na njegov priključak, kojega FRISC ispitutrenutku).                              | memorija spora, to javlja FRISC-ι      | ı preko sabirničke linije     |
| <b>1e. (1 bod)</b> Smjerovi FRISC-ovih priključaka su: READ je  ADR je                                                                                                                   | , WRITE je                             | , WAIT je                     |
| <b>1f. (1 bod)</b> Napišite koje se vrste <u>procesorskog adresiranja</u> kor<br>Naredba MOVE 30, R1 ima dvije vrste adresiranja:                                                        | (30) i                                 |                               |
| U naredbi JP (R3) koristi se                                                                                                                                                             | adre                                   | esiranje.                     |
| Adresiranje u drugom operandu naredbe LOAD R1,(LABELA) n<br>Adresiranje u drugom operandu naredbe LOAD R1,(SP+4) nazi                                                                    | aziva seiva se                         | ·                             |
| <b>1g. (1 bod)</b> Općenita 4-bitna (ne FRISC-ova) aritmetičko-logička<br>Nakon operacije će biti: prijenos =, posudba =, pre                                                            |                                        |                               |

Potrebno je napisati postupak rješenja, a ne samo rezultate.

## Rješenja zadatka 1a-1g 100 FA 1a. (3 boda) U memoriju čije riječi su široke 8 bita podatci se upisuju u redoslijedu 101 FB little-endian. Od adrese 100<sub>16</sub> upišite redom sljedeće podatke (tablicu popunite u 102 FF **<u>heksadekadskoj</u>** brojevnoj bazi): 103 FF 104 06 -1030<sub>10</sub> u 32-bitom formatu 2'k. FF FF 11111011 11111010 = FF FF FB FA 105 04 1030<sub>10</sub> u 32-bitnom formatu NBC, 00000100 00000110 = 00 00 04 06 **106** 00 00000000 00101001 = 00 29 broj 41<sub>10</sub> u 16-bitnom formatu 2'k, 107 00 41<sub>10</sub> u 8-bitnom formatu s bitom za predznak, 00101001 = 29108 **29** -41<sub>10</sub> u 8-bitnom formatu s bitom za predznak. 10101001 = A9 109 00 10A **29** MORA SE VIDJETI POSTUPAK PRETVORBE A NE SAMO REZULTATI !!! 10B **A9**

1b. (2,5 boda) Na prazne crte upišite korake koje FRISC obavlja prilikom izvođenja naredbe LOAD RO, (R1+300).

| Razina dohvata:                                                                                                    | Razina izvodenja:                                                                                                                                                                                                     |
|--------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rastući brid CLOCK-a:                                                                                              | Rastući brid CLOCK-a:                                                                                                                                                                                                 |
| PC -> AR                                                                                                           | ALU zbraja                                                                                                                                                                                                            |
| Padajući brid CLOCK-a:                                                                                             | <u>ALU -&gt; AR</u>                                                                                                                                                                                                   |
| (AR) -> IR, dekodiranje                                                                                            | Padajući brid CLOCK-a:                                                                                                                                                                                                |
| PC + 4 -> PC                                                                                                       | (AR) -> DR                                                                                                                                                                                                            |
| ext 300 i R1 -> ALU                                                                                                | DR -> R0                                                                                                                                                                                                              |
| onemogući razinu dohvata                                                                                           | omogući razinu dohvata                                                                                                                                                                                                |
| <b>1c. (0,5 boda)</b> Naredba LOAD efektivno traje _ strukturni .                                                  | ciklusa (uz pretpostavku da je memorija brza). Ovaj hazard naziva se                                                                                                                                                  |
| memoriju traje <u>2 ili više</u> takt(ova). Ako                                                                    | <u>1</u> takt(ova) CLOCK-a, a pisanje traje <u>1</u> takt(ova). Pisanje u sporu je memorija spora, to javlja FRISC-u preko sabirničke linije spojene na FRISC ispituje <u>na padajući brid signala CLOCK</u> (u kojem |
| <b>1e. (1 boda) <u>Smjerovi</u></b> FRISC-ovih priključaka s<br>ADR je <u>izlazni</u> , DATA je <u>ulazno/izla</u> | su: READ je <u>izlazni</u> , WRITE je <u>izlazni</u> , WAIT je <u>ulazni</u> ,<br>azni (ili dvosmjerni) .                                                                                                             |
| <b>1f. (1 bod)</b> Napišite koje se vrste <b>procesorsko</b>                                                       | a adresirania koriste u sliedećim naredhama:                                                                                                                                                                          |
| Naredba MOVE 30, R1 ima dvije vrste adresii<br>U naredbi JP (R3) koristi se <u>registarsk</u>                      | ranja: <u>neposredno</u> (30) i <u>registarsko</u> (R1).                                                                                                                                                              |
|                                                                                                                    | AD R1,(SP+4) naziva se <u>registarsko indirektno s odmakom (ili s</u>                                                                                                                                                 |
| - · · · · · · · · · · · · · · · · · · ·                                                                            | ritmetičko-logička jedinica oduzima binarne brojeve $0110 - 1101$ .<br>dba = $_{1}$ , preljev = $_{1}$ , ništica = $_{0}$ , predznak = $_{1}$ .<br>samo rezultate.                                                    |

**2. (6 bodova)** U memoriji na adresama  $A000_{16}$  i  $ABCD1234_{16}$  se nalaze dva bloka sa po  $200_{16}$  podataka u svakom bloku. Prvi blok sadrži 8-bitne podatke u formatu 1'k. Drugi blok sadrži 16-bitne podatke u formatu s bitom za predznak. Treba zbrajati podatke iz prvog bloka s podatcima u drugom bloku i spremati rezultate u 32-bitnom formatu 2'k u treći blok memorije na adresi  $C000_{16}$  na sljedeći način: prvi podatak iz prvog bloka zbraja se sa zadnjim podatkom iz drugog bloka, zatim drugi podatak iz prvog bloka s predzadnjim podatkom iz drugog bloka i tako dalje dok se ne zbroje svi podatci.

```
`ORG 0
GLAVNI MOVE
            0A000, R0
                                ; adresa 1. bloka
      LOAD R1, (ADR_2_BLOKA) ; učitaj adresu 2. bloka
            R1, 400, R1
                               ; izračunaj adresu zadnjeg podatka u 2. bloku
      ADD
            R1, 2, R1
      SUB
           0C000, R2
      MOVE
                               ; adresa rezultantnog bloka
            200, R7
      MOVE
                                ; brojač za petlju
PETLJA LOADB R3, (R0)
                                ; učitaj podatak iz 1. bloka
            R3, 80, R5
      AND
                               ; pretvori ga u 32-bitni 2'k format
      JR Z
            POZ 1
                               ; ispitaj predznak
NEG_1 SHL
            R3, %D24, R3
                               ; proširi 1'k sa 8 na 32 bita
            R3, %D24, R3
      ASHR
            R3, 1, R3
                                ; pretvori u 2'k
      ADD
POZ_1 ; broj je već OK jer je pozitivan
      LOADH R4, (R1)
                                ; učitaj podatak iz 2. bloka
            R4, 8000, R5
                                ; pretvori ga u 32-bitni 2'k format
      AND
            POZ_2
      JR_Z
                                ; ispitaj predznak
            R3, OFFFF7FFF, R3 ; briši bit za predznak
NEG_2 AND
            R3, OFFFFFFFF, R3; operacija dvojnog komplementa
      XOR
      ADD
            R3, 1, R3
POZ_2 ; broj je već OK jer je pozitivan
ZBROJI ADD
            R3, R4, R5
                                ; zbroji brojeve u 32-bitnom formatu 2'k
      STORE R5, (R2)
                                ; spremi u rezultantni blok
            R0, 1, R0
                                ; pomakni pokazivače na blokove
      ADD
      SUB
            R1, 2, R1
            R2, 4, R2
      ADD
      SUB
            R7, 1, R7
                                ; smanjivanje i provjera brojača petlje
      JR NZ PETLJA
      HALT
ADR_2_BLOKA DW 0ABCD1234
                                ; adresa drugog bloka
      `ORG 0A000
                                ; prvi blok
      DB ...
      `ORG 0C000
                                ; rezultantni blok
      DW ...
      `ORG 0ABCD1234
                                ; drugi blok
      DH ...
```

**3. (7,5 bodova)** Napisati potprogram SUB\_DBL za oduzimanje dva NBC broja u dvostrukoj preciznosti. Parametri i rezultat se prenose registrima na sljedeći način:

|   | R1 | R0 | prvi podatak  |
|---|----|----|---------------|
| _ | R3 | R2 | drugi podatak |
|   | R1 | R0 | rezultat      |

Napisati potprogram DIV\_DBL koji (koristeći potprogram SUB\_DBL) dijeli dva NBC broja u dvostrukoj preciznosti metodom uzastopnog oduzimanja. Ostatak pri dijeljenju se zanemaruje. Parametri su adrese dvaju podataka i te adrese se šalju pomoću stoga u potprogram. Rezultat dijeljenja vraća se u registrima R4 (niži dio) i R5 (viši dio).

Napisati glavni program koji pozivom potprograma DIV\_DBL dijeli brojeve  $5555666677778888_{16}$  i  $1111222233334444_{16}$  koji su spremljeni u memoriji na adresama  $200_{16}$  i  $208_{16}$  i pohranjuje rezultat na adresu  $210_{16}$  (ovi brojevi i mjesto za rezultat trebaju također biti napisani u rješenju).

```
ORG 0
               10000, SP
                              ; inicijalizacija stoga
GLAVNI MOVE
       MOVE
               200, R0; adresa 1. broja
       PUSH
       MOVE
               208, R0; adresa 2. broja
       PUSH
       CALL
               DIV_DBL; dijeljenje
       ADD
               SP, 8, SP
                             ; čisti stog od parametara
       STORE
              R4, (210)
                              ; spremi niži dio rezultata
       STORE
              R5, (214)
                              ; spremi viši dio rezultata
       HALT
SUB_DBL ; potprogram za oduzimanje, nema konteksta
              R0, R2, R0
       SUB
       SBC
               R1, R3, R1
                              ; C je postavljen za ispitivanje u pozivatelju
       RET
DIV_DBL ; potprogram za dijeljenje
       PUSH
              R0
                              ; spremi kontekst
       PUSH
               R1
              R2
       PUSH
       PUSH
              R3
               R4, (SP+%D20) ; učitaj 2. parametar
       LOAD
       LOAD
               R5, (SP+%D24) ; učitaj 1. parametar
       LOAD
               RO, (R5)
                              ; učitaj prvi broj
       LOAD
               R1, (R5+4)
       LOAD
               R2, (R4)
                              ; učitaj drugi broj
              R3, (R4+4)
       LOAD
       MOVE
               0, R4
                              ; rezultat je inicijalno 0
       MOVE
              0, R5
PETLJA CALL
               SUB_DBL
                              ; ako je negativan broj, djeljenje je gotovo
       JR_C
               VAN
POZIT
       ADD
               R4, 1, R4
                              ; ako je pozitivan broj, povećaj rezultat
       ADC
               R5, 0, R5
                              ; za 1 (u dvostrukoj preciznosti)
               PETLJA
       JR
               R3
VAN
       POP
       POP
               R2
       POP
               R1
       POP
               R0
       RET
       `ORG 200
               77778888, 55556666
       DW
                                      ; prvi broj
               33334444, 11112222
       DW
                                      ; drugi broj
       DW
               0,0
                                      ; mjesto za rezultat
```

**4. (8,5 bodova)** FRISC prima 32-bitne NBC podatke koje mu šalje prekidna jedinica PVJ1 (spojena na INT1). Primljeni podatci spremaju se kao bajtovi u memorijski blok na adresi 1000<sub>16</sub>. Ako primljeni podatak ne stane u 8-bita, treba prekinuti sa spremanjem i nakon toga zaustaviti glavni program. Ako se primi ništica, ona se ne sprema u memoriju, a primljene ništice treba prebrajati. Zanemarite mogućnost prepunjenja bloka podataka.

Glavni program cijelo vrijeme dojavljuje uvjetnoj jedinici UVJ broj ništica primljenih sa PVJ1.

Na INT3 spojena je i PVJ3 koja ima IACK. Podatak koji se pročita iz PVJ3 treba poslati bezuvjetnoj jedinici BVJ.

Adrese vanjskih jedinica odaberite sami.

```
BVJ
       `EQU
             OFFFF0000
UVJ_D
      `EQU
             0FFFF0050
UVJ_S `EQU
             0FFFF0054
PVJ1 D `EQU
             0FFFF1000
PVJ1 S `EQU
             OFFFF1004
PVJ1_E `EQU
             0FFFF1008
PVJ2 D `EOU
             0FFFF2000
PVJ2_S `EQU
             0FFFF2004
PVJ2_E `EQU
             0FFFF2008
PVJ3_D `EQU
             OFFFF3000
PVJ3_E `EQU
             0FFFF3008
       `ORG
             0
       MOVE
             10000, SP
                           ; inicijalizacija stoga
       JΡ
             GLAVNI
       `ORG
             8
                           ; prekidni vektor
       DW
             100
       `ORG
             0C
                           ; prekidni potprogram za INT3
       PUSH
             R0
             RO, (PVJ3_D); pročitaj podatak sa PVJ3 i...
       LOAD
             RO, (BVJ)
                        ; ... pošalji ga bezuvjetnoj BVJ
       STORE
       STORE RO, (PVJ3_E); dojavi kraj posluživanja PVJ3
       POP RO
       RETN
GLAVNI MOVE %B 10100000, SR
                                  ; dozvoli prekide INT1
CEKAJ LOAD
             R0, (UVJ_S)
                                  ; čekaj spremnost uvjetne UVJ
       OR
             R0, R0, R0
       JR_Z
             CEKAJ
             RO, (NISTICE); pošalji uvjetnoj broj zanemarenih podataka
       TIOAD
       STORE RO, (UVJ_D)
                                  ; briši status uvjetnoj jedinici
       STORE RO, (UVJ_S)
       LOAD
             RO, (STANI)
                                  ; provjeri treba li zaustaviti glavni program
       OR
             R0, R0, R0
       JR_Z
             CEKAJ
KRAJ
      HALT
; varijable razne
NISTICE
             DW
                    Ω
                           ; brojač zanemarenih ništica
ADR_POD
             DW
                    1000
                           ; adresa za spremanje u blok
STANI
             DW
                           ; zastavica za zaustavljanje glavnog programa
```

```
100
      `ORG
                    ; prekidni potprogram za PVJ1
            R0
      PUSH
            R1
      PUSH
      MOVE
            SR, R0
      PUSH
            R0
      STORE R0, (PVJ1_S) ; dojavi prihvat prekida PVJ1
      LOAD RO, (PVJ1_D) ; pročitaj podatak sa PVJ1
             RO, OFFFFFF00, R1 ; provjeri 8-bitni opseg podatka
      AND
      JR_NZ STOP
                   ; provjeri ništicu
      CMP
           R0, 0
      JR_EQ NULA
SPREMI LOAD R1, (ADR_POD); učitaj adresu za pohranu u blok
      STOREB RO, (R1) ; pohrani primljeni podatak u blok
ADD R1, 1, R1 ; povećaj adresu za pohranu i spremi je natrag
      STORE R1, (ADR_POD)
      JR
            VAN
NULA
     LOAD RO, (NISTICE); povećati brojač zanemarenih ništica
           R0, 1, R0
      STORE RO, (NISTICE)
            VAN
      MOVE 1, RO
STOP
      STORE RO, (STANI)
      JΡ
             VAN2
VAN
      STORE RO, (PVJ1_E) ; dojavi kraj obrade prekida PVJ1
VAN2
      POP
             R0
      MOVE R0, SR
      POP
             R1
      POP
             R0
      RETI
```