



# CS & IT ENGINEERING

COMPUTER ORGANIZATION  
AND ARCHITECTURE

CPU & Control Unit

Lecture No.- 02



By- Vishvadeep Gothi sir



# Recap of Previous Lecture



Topic

CPU

Topic

CPU Cycle

Topic

CPI

# Topics to be Covered



Topic

Datapath

Topic

Control Unit

Topic

RISC vs CISC



## Topic : Datapath



Collection of functional units such as arithmetic logic units or multipliers

Perform data processing operations



## Topic : Datapath



Instruction fetch :-

$AR \leftarrow PC$       1  
 $DR \leftarrow M[AR]$       4  
 $IR \leftarrow DR, PC \leftarrow PC + 1$       1

Total 6 cycles

---

operation :-

$R1 \leftarrow R2 + R3$   
 $S \leftarrow R2$   
 $T \leftarrow R3$   
 $AC \leftarrow S + T$   
 $R1 \leftarrow AC$

4 cycles

ques) each micro-operation except mem. access  $\Rightarrow$  1 CPU cycle  
mem. access  $\Rightarrow$  4 CPU cycles

---

write a micro-operation sequence for a function call "inst" execution phase?

$S \leftarrow SP$   
 $AC \leftarrow S + 1$   
 $SP \leftarrow AC, AR \leftarrow AC$   
 $DR \leftarrow PC$   
 $M[AR] \leftarrow DR$   
 $PC \leftarrow \text{Target add.}$



## Topic : Control Unit

It generates control signals and sends them to all components.

Components perform respective operation accordingly.

$AR \leftarrow PC$

$DR \leftarrow M[AR]$

$IR \leftarrow DR, PC \leftarrow PC + 1$

$PC_{out}, AR_{in}$

$AR_{out}, Memory_{read}, DR_{in}$

$DR_{out}, IR_{in}, PC_{inc}$

Control variable :-

Names of control signals

Control words :-

Collection of all the control signals generated at once by control unit.



each control word is responsible  
for atleast one micro-operation.

| S      | T      | AC     | ALU                                 | GPRS   | PC     | AR     | DR     | IR     | SP     | Mem        |
|--------|--------|--------|-------------------------------------|--------|--------|--------|--------|--------|--------|------------|
| In out | In out | In out | function<br><small>(4-bits)</small> | In out | Read write |

1.

$$AR \leftarrow PC$$

control word



$$2. DR \leftarrow M[AR]$$





## Topic : Control Unit Organization



How control unit is designed to generate control words.

1. Hardwired C.U.
2. microprogrammed C.U.



## Topic : Hardwired Control Unit



Control logic is implemented with Gates, flip-flops, decoders and other digital circuits.

**Advantage:** Can be optimized to produce a faster mode of operation.

**Disadvantage:**

1. Rearranging the wires among various components is difficult.
2. Difficult to change the control logic
3. Difficult to design for complex computers



# Topic : Hardwired Control Unit



# Table design

|             | $T_1$ | $T_2$            |                          |
|-------------|-------|------------------|--------------------------|
| $inst^{ns}$ | $I_1$ | $I_{18}, I_{20}$ | $I_{21}, I_{22}, I_{28}$ |
| $I_2$       |       |                  |                          |
| $I_3$       |       |                  |                          |
| $I_4$       |       |                  |                          |
| :           |       |                  |                          |
| :           |       |                  |                          |
| $I_n$       |       |                  |                          |

#Q. A hardwired CPU uses 10 control signals S1 to S10, in various time steps T1 to T5, to implement 4 instructions I1 to I4 as shown below:

|    | T1         | T2          | T3         | T4     | T5     |
|----|------------|-------------|------------|--------|--------|
| I1 | S1, S3, S5 | S2, S4, S6  | S1, S7     | S10    | S3, S8 |
| I2 | S1, S3, S5 | S8, S9, S10 | S5, S6, S7 | S6     | S10    |
| I3 | S1, S3, S5 | S7, S8, S10 | S2, S6, S9 | S10    | S1, S3 |
| I4 | S1, S3, S5 | S2, S6, S7  | S5, S10    | S6, S9 | S10    |

Which of the following pairs of expressions represent the circuit for generating control signals S5 and S10 respectively?

$$\begin{aligned}
 S_5 &= I_1 T_1 + I_2 T_1 + I_3 T_1 + I_4 T_1 + I_2 T_3 + I_4 T_3 \\
 &= (I_1 + I_2 + I_3 + I_4) T_1 + (I_2 + I_4) T_3 = T_1 + (I_2 + I_4) T_3
 \end{aligned}$$

**A**

$$S_5 = T_1 + I_2 \cdot T_3 \text{ and}$$

$$S_{10} = (I_1 + I_3) \cdot T_4 + (I_2 + I_4) \cdot T_5$$

**B**

$$S_5 = T_1 + (I_2 + I_4) \cdot T_3 \text{ and}$$

$$S_{10} = (I_1 + I_3) \cdot T_4 + (I_2 + I_4) \cdot T_5$$

**C**

$$S_5 = T_1 + (I_2 + I_4) \cdot T_3 \text{ and}$$

$$S_{10} = (I_1 + I_3 + I_4) \cdot T_2 + (I_2 + I_3) \cdot T_4 + (I_2 + I_4) \cdot T_5$$

**D**

$$S_5 = T_1 + (I_2 + I_4) \cdot T_3 \text{ and}$$

$$S_{10} = \underline{(I_2 + I_3) \cdot T_2} + \underline{I_4 \cdot T_3} + \underline{(I_1 + I_3) \cdot T_4} + \underline{(I_2 + I_4) \cdot T_5}$$



## Topic : Micro-Programmed Control Unit



Control logic is implemented with micro-programs.

### **Advantage:**

1. Updating the control logic is easy.
2. Designing for complexing computers is easy.

**Disadvantage:** Slower than hardwired control unit.



# Topic : Micro-Programmed Control Unit



Control unit





## Topic : Control Word Sequencing



# Topic : Control Word Sequencing

on each address in control memory a microinstruction.



standard format of microinstr

|              |            |         |
|--------------|------------|---------|
| Control word | MUX select | Address |
|--------------|------------|---------|

#Q. The microinstructions stored in the control memory of a processor have a width of 26 bits. Each microinstruction is divided into three fields: a micro-operation field of 13 bits, a next address field (X), and a MUX select field (Y). There are 8 status bits in the inputs of the MUX.

How many bits are there in the X and Y fields, and what is the size of the control memory in number of words?



A ✓10, 3, 1024

B 8, 5, 256

C 5, 8, 2048

D 10, 3, 512



$$\text{no. of words/microinstns in control memory} = 2^{10} = 1024$$

$$\text{Control mem. size} = 2^{10} * 26 \text{ bits} \\ = 26 \text{ k bits}$$



## Topic : Types of Microprogrammed Control Unit



Horizontal

→ for each signal, one bit stored  
in control word.

→ larger sized control word

Vertical

→ signals are divided into groups in such  
a way that from each group one  
signal can be active at a time.  
Group info's are stored in encoded  
form.

if any signal can not be  
the part of any group then  
it is stored as horizontal manner.

- smaller control word size
- decoders are used
- slower as compared to Horizontal

Horizontal



$s_0$  is active



$s_1$  is active

0010

$s_2$

0100

$s_3$

1000

vertical



$s_0$  is active





## Topic : Speed Comparison



fastest

Hardwired > Horizontal  
microprogrammed > Vertical  
microprogrammed

slowest

#Q. A control unit generates 120 control signals, which are divided into 6 groups of mutually exclusive signals as below:

$$\text{Group1} = 30 \Rightarrow 5 \text{ bits}$$

$$\text{Group2} = 13 \Rightarrow 4$$

$$\text{Group3} = 12 \Rightarrow 4$$

$$\text{Group4} = 3 \Rightarrow 2$$

$$\text{Group5} = 27 \Rightarrow 5$$

$$\text{Group6} = 35 \Rightarrow 6$$

$$\text{Horizontal} = 120 \text{ bits}$$

$$\text{vertical} = 26 \text{ bits}$$

$$\text{bits saved} = 94 \text{ bits}$$

Ans.

$$26$$

How many bits can be saved by using vertical micro-programmed control unit as compared to horizontal one?



## 2 mins Summary



**Topic**

**Datapath**

**Topic**

**Control Unit**

**Topic**

**RISC vs CISC**



# Happy Learning

## THANK - YOU