# 7. IZVEDBA UPRAVLJAČKE JEDINICE ZA RAČUNALO SA SKUPOM OD OSAM INSTRUKCIJA

- Skup instrukcija
- Organizacija računala
- Struktura upravljačke jedinice
- Komponente upravljačke jedinice: brojilo sekvenci, dekoder, PLA generator taktnog signala

# Skup instrukcija:

| Mnemonik             | Opis                               |  |  |  |  |
|----------------------|------------------------------------|--|--|--|--|
| ld X ; load X        | $AC \leftarrow M(X)$               |  |  |  |  |
| st X ; store X       | $M(X) \leftarrow AC$               |  |  |  |  |
| add X                | $AC \leftarrow AC + M(X)$          |  |  |  |  |
| and X                | $AC \leftarrow AC \wedge M(X)$     |  |  |  |  |
| jmp X ; jump X       | PC ← X                             |  |  |  |  |
| jmpz X; jump if zero | if $AC = 0$ then $PC \leftarrow X$ |  |  |  |  |
| com; 1's compl. AC   | $AC \leftarrow \overline{AC}$      |  |  |  |  |
| rsh ; shift right    | posmak sadržaja AC<br>udesno       |  |  |  |  |



"Spore" instrukcije (npr. add, st, ld) trebaju 8 vremenskih jedinica (8  $\Delta$ T) "Brze" instrukcije (npr. jmp) zahtijevaju samo 5 vremenskih jedinica (5  $\Delta$ T)



S. Ribarić, AIOR

## Izvedba nezavisne upravljačke točke:



## Sklop s tri stanja:

| Upravlj.<br>signal | Ulaz | Izlaz |
|--------------------|------|-------|
| 1                  | A    | A     |
| 1                  | A    | Ā     |
| 0                  | X    | Z     |



| $C_0$             | AC ← AC +DR                   |
|-------------------|-------------------------------|
| $C_1$             | $AC \leftarrow AC \wedge DR$  |
| $C_2$             | $AC \leftarrow \overline{AC}$ |
| $C_3$             | $DR \leftarrow M(AR)$         |
| $\mathrm{C}_4$    | $M(AR) \leftarrow DR$         |
| $\mathbf{C}_{5}$  | DR ← AC                       |
| $\mathbf{C}_6$    | AC ← DR                       |
| $\mathbf{C}_7$    | $AR \leftarrow DR(AR)$        |
| $\mathbf{C}_8$    | $PC \leftarrow DR(AR)$        |
| $C_9$             | PC = PC + 1                   |
| $\mathrm{C}_{10}$ | AR ← PC                       |
| $C_{11}$          | IR ← DR(OP)                   |
| $C_{12}$          | Right shift AC                |

/READ M/ / WRITE M/

S. Ribarić, AIOR



| $C_0$             | AC ← AC +DR                   |
|-------------------|-------------------------------|
| $C_1$             | $AC \leftarrow AC \wedge DR$  |
| $C_2$             | $AC \leftarrow \overline{AC}$ |
| $C_3$             | $DR \leftarrow M(AR)$         |
| $\mathrm{C}_4$    | $M(AR) \leftarrow DR$         |
| $\mathbf{C}_{5}$  | DR ← AC                       |
| $\mathbf{C}_6$    | AC ← DR                       |
| $\mathbf{C}_7$    | $AR \leftarrow DR(AR)$        |
| $\mathbf{C}_8$    | $PC \leftarrow DR(AR)$        |
| $C_9$             | PC = PC + 1                   |
| $\mathrm{C}_{10}$ | AR ← PC                       |
| $C_{11}$          | IR ← DR(OP)                   |
| $C_{12}$          | Right shift AC                |

/READ M/ / WRITE M/

S. Ribarić, AIOR





Upravljački signal  $C_i$  (i = 0, 1, 2, ..., 12) može se opisati logičkom jednadžbom:

$$\mathbf{C}_i = \sum_{j} \left( \Phi_j \bullet \sum_{m} I_m \right)$$

$$j = 1, 2, ..., 8$$
  
 $m = 1, 2, ..., 8$   
 $I_m$  – izlaz iz dekodera instrukcija

## Faza IZVRŠI:

Instrukcija ld: 
$$C_7 = \Phi_5 \cdot I_1$$

$$C_3 = \Phi_6 \cdot I_1 + \Phi_7 \cdot I_1$$

$$C_6 = \Phi_8 \cdot I_1$$

st: 
$$C_7 = \Phi_5 \cdot I_2$$
  
 $C_5 = \Phi_6 \cdot I_2$   
 $C_4 = \Phi_7 \cdot I_2 + \Phi_8 \cdot I_2$   
add:  $C_7 = \Phi_5 \cdot I_3$   

$$C_3 = \Phi_6 \cdot I_3 + \Phi_7 \cdot I_3$$

$$C_0 = \Phi_8 \cdot I_3$$
and:  $C_7 = \Phi_5 \cdot I_4$ 

$$C_3 = \Phi_6 \cdot I_4 + \Phi_7 \cdot I_4$$

 $C_1 = \Phi_8 \cdot I_4$  S. Ribarić, AIOR

## Faza IZVRŠI:

$$C_{3} = \Phi_{6} \cdot I_{1} + \Phi_{7} \cdot I_{1} + \Phi_{6} \cdot I_{3} + \Phi_{7} \cdot I_{3} + \Phi_{6} \cdot I_{4} + \Phi_{7} \cdot I_{4}$$

### Faza PRIBAVI i IZVRŠI:

$$C_3 = \Phi_2 + \Phi_3 + \Phi_6 (I_1 + I_3 + I_4) + \Phi_7 (I_1 + I_3 + I_4)$$

$$C_i = \sum_j \left( \Phi_j \bullet \sum_m I_m \right)$$



S. Ribarić, AIOR

jmp: 
$$C_8 = \Phi_5 \cdot I_5$$

j = 5 i nakon toga resetira se brojilo sekvenci!

jmpz: 
$$C_8 = \Phi_5 \cdot I_6$$
 ako je  $AC = 0$ 

Faza IZVRŠI za jmp  $(I_5)$  i jmpz  $(I_6)$ :



#### Faza PRIBAVI:

 $\Phi_1$ ; AR $\leftarrow$  PC;  $C_{10}$ 

 $\Phi_2$ ,  $\Phi_3$ ; Read M;  $C_3$ 

 $\Phi_4; PC \leftarrow PC+1; C_9$   $IR \leftarrow DR(OP); C_{11}$ 



S. Ribarić, AIOR

PLA – Programmable Logic Array

| A | В | С | $\mathbf{F}_{1}$ | $F_2$ |
|---|---|---|------------------|-------|
| 0 | 0 | 0 | 0                | 0     |
| 0 | 0 | 1 | 0                | 0     |
| 0 | 1 | 0 | 0                | 0     |
| 0 | 1 | 1 | 0                | 1     |
| 1 | 0 | 0 | 1                | 0     |
| 1 | 0 | 1 | 1                | 1     |
| 1 | 1 | 0 | 0                | 0     |
| 1 | 1 | 1 | 1                | 1     |

$$F_1 = \overline{AB} + AC$$
$$F_2 = AC + BC$$

# PLA (3 ulaza, 3 AND, 2 OR, 2 izlaza)





S. Ribarić, AIOR



S. Ribarić, AIOR



# Posmačni registar





# Dekoder



| ULAZI |   |   |   |                |                | IZL   | AZI   |       |       |                |                |  |
|-------|---|---|---|----------------|----------------|-------|-------|-------|-------|----------------|----------------|--|
|       | X | Υ | Z | D <sub>0</sub> | D <sub>1</sub> | $D_2$ | $D_3$ | $D_4$ | $D_5$ | D <sub>6</sub> | D <sub>7</sub> |  |
|       | 0 | 0 | 0 | 1              | 0              | 0     | 0     | 0     | 0     | 0              | 0              |  |
|       | 0 | 0 | 1 | 0              | 1              | 0     | 0     | 0     | 0     | 0              | 0              |  |
|       | 0 | 1 | 0 | 0              | 0              | 1     | 0     | 0     | 0     | 0              | 0              |  |
|       | 0 | 1 | 1 | 0              | 0              | 0     | 1     | 0     | 0     | 0              | 0              |  |
|       | 1 | 0 | 0 | 0              | 0              | 0     | 0     | 1     | 0     | 0              | 0              |  |
|       | 1 | 0 | 1 | 0              | 0              | 0     | 0     | 0     | 1     | 0              | 0              |  |
|       | 1 | 1 | 0 | 0              | 0              | 0     | 0     | 0     | 0     | 1              | 0              |  |
|       | 1 | 1 | 1 | 0              | 0              | 0     | 0     | 0     | 0     | 0              | 1              |  |

S. Ribarić, AIOR

## Izvedba dekodera





S. Ribarić, AIOR



S. Ribarić, AIOR

## Skraćivanje instrukcijskog ciklusa za "brze" instrukcije



S. Ribarić, AIOR

# Generator taktnog signala

