# UNIT III PROCESSOR AND PIPELINING

Fundamental concepts – Execution of a complete instruction – Multiple bus organization – Hardwired control – **Micro programmed control** – Pipelining: Basic concepts – Data hazards – Instruction hazards – Influence on Instruction sets – Data path and control consideration.





## **Recap the previous Class**



A.Aruna / AP / IT / SEM 2 / COA



- Control signals are generated by a program similar to machine language programs.
- Control Word (CW); microroutine; microinstruction

| Micro -<br>instruction | <br>PCin | PC <sub>out</sub> | MAR in | Read | <b>MDR</b> out | IR <sub>in</sub> | Y <sub>in</sub> | Select | Add | Z <sub>in</sub> | Zout | R1 <sub>out</sub> | R1 <sub>in</sub> | R3out | WMFC | End |  |
|------------------------|----------|-------------------|--------|------|----------------|------------------|-----------------|--------|-----|-----------------|------|-------------------|------------------|-------|------|-----|--|
| 1                      | 0        | 1                 | 1      | 1    | 0              | 0                | 0               | 1      | 1   | 1               | 0    | 0                 | 0                | 0     | 0    | 0   |  |
| 2                      | 1        | 0                 | 0      | 0    | 0              | 0                | 1               | 0      | 0   | 0               | 1    | 0                 | 0                | 0     | 1    | 0   |  |
| 3                      | 0        | 0                 | 0      | 0    | 1              | 1                | 0               | 0      | 0   | 0               | 0    | 0                 | 0                | 0     | 0    | 0   |  |
| 4                      | 0        | 0                 | 1      | 1    | 0              | 0                | 0               | 0      | 0   | 0               | 0    | 0                 | 0                | 1     | 0    | 0   |  |
| 5                      | 0        | 0                 | 0      | 0    | 0              | 0                | 1               | 0      | 0   | 0               | 0    | 1                 | 0                | 0     | 1    | 0   |  |
| 6                      | 0        | 0                 | 0      | 0    | 1              | 0                | 0               | 0      | 1   | 1               | 0    | 0                 | 0                | 0     | 0    | 0   |  |
| 7                      | 0        | 0                 | 0      | 0    | 0              | 0                | 0               | 0      | 0   | 0               | 1    | 0                 | 1                | 0     | 0    | 1   |  |

A.Aruna / AP / IT / SEM 2 / COA

### **Control sequence for the instruction**

#### Add (R3),R2

Step Action

INSTITUTIONS

#### **Conditional branch**

|   |                                                                             | Addres | s Microinstruction                                                          |
|---|-----------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------|
| 1 | PC <sub>out</sub> , MAR <sub>in</sub> , Read, Select4, Add, Z <sub>in</sub> |        |                                                                             |
| 2 | Zout PCin Yin WMEC                                                          | 0      | PC <sub>out</sub> , MAR <sub>in</sub> , Read, Select4, Add, Z <sub>in</sub> |
| - |                                                                             | 1      | $ m Z_{out}$ , PC $_{ m in}$ , Y $_{ m in}$ , WMF C                         |
| 3 | MDR <sub>out</sub> , IR in                                                  | 2      | MDR <sub>out</sub> , IR <sub>in</sub>                                       |
| 4 | R3 <sub>out</sub> , MAR in , Read                                           | 3      | Branch to starting address of appropriate                                   |
| 5 | R1out , Yin , WMFC                                                          |        |                                                                             |
| 6 | MDR <sub>out</sub> , SelectY, Add, Z <sub>in</sub>                          | 25     | If N=0, then branch to microinstruction                                     |
| 7 | Z <sub>out</sub> , R1 <sub>in</sub> , End                                   | 26     | Offset-field-of-IR <sub>out</sub> , SelectY, Add, Z <sub>in</sub>           |
|   |                                                                             | 27     | Z <sub>out</sub> , PC <sub>in</sub> , End                                   |

. . . . . . . . . . . . . . . . .

# Basic organization of a microprogrammed control unit



A.Aruna / AP / IT / SEM 2 / COA

INSTITUTIONS



- A straightforward way to structure microinstructions is to assign one bit position to each control signal.
- However, this is very inefficient.
- The length can be reduced: most signals are not needed simultaneously, and many signals are mutually exclusive.
- All mutually exclusive signals are placed in the same group in binary coding.

LE SISSING INSTITUTIONS

## **Microinstructions**

Microinstruction

|                                                                                        | F1                                                                                                                                                                                                     | F2                                                                                                   | F3                                                                                                                      | F4                                                         | F5                                     |
|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|----------------------------------------|
| F1 (4                                                                                  | bits)                                                                                                                                                                                                  | F2 (3 bits)                                                                                          | F3 (3 bits)                                                                                                             | F4 (4 bits)                                                | F5 (2 bits)                            |
| 0000:<br>0001:<br>0010:<br>0011:<br>0100:<br>0101:<br>0110:<br>0111:<br>1010:<br>1011: | No transfer<br>PC <sub>ut</sub><br>MDR <sub>ut</sub><br>Z <sub>out</sub><br>RQ <sub>ut</sub><br>RQ <sub>ut</sub><br>RQ <sub>ut</sub><br>RQ <sub>ut</sub><br>TEMR <sub>ut</sub><br>Offset <sub>ut</sub> | 000: No transfer<br>001: PCn<br>010: IRn<br>011: Zin<br>100: R0n<br>101: R1n<br>110: R2n<br>111: R3n | 000: No transfer<br>001: MAR <sub>in</sub><br>010: MDR <sub>in</sub><br>011: TEMR <sub>in</sub><br>100: Y <sub>in</sub> | 0000: Add<br>0001: Sub<br>1111: XOR<br>16 ALU<br>functions | 00: No action<br>01: Read<br>10: Write |

| F6                       | F7                      | F8                    |  |
|--------------------------|-------------------------|-----------------------|--|
| F6 (1 bit)               | F7 (1 bit)              | F8 (1 bit)            |  |
| 0: SelectY<br>1: Select4 | 0: No action<br>1: WMFC | 0: Continue<br>1: End |  |

A.Aruna / AP / IT / SEM 2 / COA



#### Microprogram Sequencing

#### Add src, Rdst

Four addressing modes:

- Register,
- Autoincrement,
- Autodecrement
- Indexed (with indirect forms).

|                                       | 000                              |                  |               |                                         |
|---------------------------------------|----------------------------------|------------------|---------------|-----------------------------------------|
| MAR ← [PC]; Rea                       | d; Z ← [PC] + 4                  | Start            | 2             |                                         |
|                                       | 001                              |                  |               |                                         |
| PC, Y ← [Z                            | ; WMFC                           |                  |               | ·                                       |
|                                       |                                  |                  |               | 1 a                                     |
|                                       | 002                              |                  |               |                                         |
| $IR \leftarrow D$                     | ADR]                             |                  |               | · .                                     |
|                                       | 003                              |                  |               |                                         |
| Branch [Inst                          | Dec, OR)                         |                  | 1 IC 6.       | ÷                                       |
| · · · · · · · · · · · · · · · · · · · |                                  |                  |               | 1.1                                     |
| Indexed                               | Autodecrement                    | Autoincrem       | structions Re | eister indirect                         |
|                                       |                                  | . 1.             |               |                                         |
| 101                                   | 141                              |                  | 121           | . 1 1                                   |
| MAR ← [PC]; Read                      | $Z \leftarrow [Rsic] - 4$        | MAR ← [Rsrc]     | Read MAR      | t ← [Rsrc]; Read                        |
| 2+(rc)+4                              | 100                              | 2 ~ [Ksrc]       |               |                                         |
| 162                                   | 142                              |                  | 122           |                                         |
| $PC \leftarrow [Z]; WMFC$             | MAR, Rsrc $\leftarrow$ [Z]; Read | Rsrc ← [2        | [] Brar       | ch{171}; WMF                            |
| 163                                   |                                  |                  | 123           |                                         |
| Y + D(DP)                             | 1 8                              | Branch (170 OR)  | WMRC          |                                         |
|                                       | 194 a.                           | branch(170, OK), | what c        |                                         |
| 164                                   | . 1                              | 43               |               |                                         |
| Z ← [Y] + [Rsrc]                      | Branch [170, OR ]; WMF           | c                |               |                                         |
| 165                                   |                                  | -                | 1.1           | · .                                     |
| MAR + [Z]: Read                       |                                  | ~                |               |                                         |
| In all the fight to be                |                                  | +                |               | - C - C - C - C - C - C - C - C - C - C |
| 166                                   |                                  | 2 A              |               |                                         |
| ranch[170, OR]; WMPC                  |                                  |                  |               | 1                                       |
|                                       | α                                |                  | · ·           | 1. 1                                    |
|                                       | 170                              | -                |               |                                         |
| AR + [MDR]; Read; WM                  | FC                               |                  | 2.4           |                                         |
| 1                                     | -                                |                  | 1.14          |                                         |
| 171                                   |                                  |                  | 1             | 1. C                                    |
| $Y \leftarrow [MDR]$                  |                                  | n Registe        | r direct      | 101                                     |
|                                       | Branch(172)                      | Ĩſ               | Y (Ren)       |                                         |
| 172                                   | Diancin (172)                    |                  | 1 - firmel    |                                         |
| Z ← [Y] + [Rdst]                      |                                  |                  |               | est 18                                  |
|                                       |                                  |                  | 1 A A         |                                         |
|                                       |                                  |                  |               |                                         |
| 173                                   |                                  | _                |               |                                         |

A.Aruna / AP / IT / SEM 2 / COA



| Address<br>(octal) | Microinstruction                                                                                 |
|--------------------|--------------------------------------------------------------------------------------------------|
| 000                | PC <sub>out</sub> , MAR <sub>in</sub> , Read, Select 4, Add, Z <sub>in</sub>                     |
| 001                | Z <sub>out</sub> , PC <sub>in</sub> , Y <sub>in</sub> , WMFC                                     |
| 002                | MDR <sub>out</sub> , IR <sub>in</sub>                                                            |
| 003                | mBranch { mPC $\neg$ 101 (from Instruction decoder);                                             |
|                    | $mPC_{5,4} \neg [IR_{10,9}]; mPC_{3} \neg [I\overline{IR_{10}}] \times [IR_{9}] \times [IR_{8}]$ |
| 121                | $Rsrc_{out}$ , MAR <sub>in</sub> , Read, Select4, Add, Z <sub>in</sub>                           |
| 122                | Z <sub>out</sub> , Rsrc <sub>in</sub>                                                            |
| 123                | mBranch { mPC $\neg$ 170; mPC $_0 \neg$ [ $\overline{IR_8}$ ]}, WMFC                             |
| 170                | MDR <sub>out</sub> , MAR <sub>in</sub> , Read, WMFC                                              |
| 171                | MDR <sub>out</sub> , Y <sub>in</sub>                                                             |
| 172                | $\mathrm{Rdst}_{out}$ , SelectY , Add, Z in                                                      |
| 173                | Z <sub>out</sub> , Rdst <sub>in</sub> , End                                                      |

A.Aruna / AP / IT / SEM 2 / COA

## Microinstructions with Next-Address Field

• A powerful alternative approach is to include an address field as a

part of every microinstruction to indicate the location of the next

microinstruction to be fetched.



## **Implementation of the Microroutine**

| Octal<br>address                 | s F0                                              | F1                               | F2                       | F3                               | F4                               | F5                   | F6               | F7               | F8               | F9               | F10              |
|----------------------------------|---------------------------------------------------|----------------------------------|--------------------------|----------------------------------|----------------------------------|----------------------|------------------|------------------|------------------|------------------|------------------|
| 0 0 0<br>0 0 1<br>0 0 2<br>0 0 3 | 0 0 0 0 0 0 0 0 1<br>0 0 0 0 0 0 0 1 0<br>0 0 0 0 | 0 0 1<br>0 1 1<br>0 1 0<br>0 0 0 | 011<br>001<br>010<br>000 | 0 0 1<br>1 0 0<br>0 0 0<br>0 0 0 | 00000<br>00000<br>00000<br>00000 | 01<br>00<br>00<br>00 | 1<br>0<br>0<br>0 | 0<br>1<br>0<br>0 | 0<br>0<br>0<br>1 | 0<br>0<br>0<br>1 | 0<br>0<br>0<br>0 |
| 1 2 1<br>1 2 2                   | 0 1 0 1 0 0 1 0<br>0 1 1 1 1 0 0 0                | 100<br>011                       | 011<br>100               | 0 0 1<br>0 0 0                   | 0 0 0 0<br>0 0 0 0               | 01<br>00             | 1<br>0           | 0<br>1           | 0<br>0           | 0<br>0           | 0<br>1           |
| 1 7 0<br>1 7 1<br>1 7 2<br>1 7 3 | 0 1 1 1 1 0 0 1<br>0 1 1 1 1 0 1 0<br>0 1 1 1 1   | 010<br>010<br>101<br>011         | 000<br>000<br>011<br>101 | 0 0 1<br>1 0 0<br>0 0 0<br>0 0 0 | 00000<br>00000<br>00000<br>00000 | 01<br>00<br>00<br>00 | 0<br>0<br>0<br>0 | 1<br>0<br>0<br>0 | 0<br>0<br>0<br>0 | 0<br>0<br>0<br>0 | 0<br>0<br>0<br>0 |







A.Aruna / AP / IT / SEM 2 / COA