

## Computer

### Unit 3 CONTROL UNIT

#### INSTRUCTION TYPES

##### Data Movement Instructions

Data movement instructions are used to move data among the different units of the machine.

| Data movement operation | Meaning                                                                                           |
|-------------------------|---------------------------------------------------------------------------------------------------|
| MOVE                    | Move data (a word or a block) from a given source (a register or a memory) to a given destination |
| LOAD                    | Load data from memory to a register                                                               |
| STORE                   | Store data into memory from a register                                                            |
| PUSH                    | Store data from a register to stack                                                               |
| POP                     | Retrieve data from stack into a register                                                          |

##### Arithmetic and Logical Instructions

| Arithmetic operations | Meaning                                           |
|-----------------------|---------------------------------------------------|
| ADD                   | Perform the arithmetic sum of two operands        |
| SUBTRACT              | Perform the arithmetic difference of two operands |
| MULTIPLY              | Perform the product of two operands               |
| DIVIDE                | Perform the division of two operands              |
| INCREMENT             | Add one to the contents of a register             |
| DECREMENT             | Subtract one from the contents of a register      |

##### Sequencing Instructions

| Logical operation | Meaning                                                                            |
|-------------------|------------------------------------------------------------------------------------|
| AND               | Perform the logical ANDing of two operands                                         |
| OR                | Perform the logical ORing of two operands                                          |
| EXOR              | Perform the XORing of two operands                                                 |
| NOT               | Perform the complement of an operand                                               |
| COMPARE           | Perform logical comparison of two operands and set flag accordingly                |
| SHIFT             | Perform logical shift (right or left) of the content of a register                 |
| ROTATE            | Perform logical shift (right or left) with wraparound of the content of a register |

| Flag name    | Meaning                                                                                   |
|--------------|-------------------------------------------------------------------------------------------|
| Negative (N) | Set to 1 if the result of the most recent operation is negative, it is 0 otherwise        |
| Zero (Z)     | Set to 1 if the result of the most recent operation is 0, it is 0 otherwise               |
| Overflow (V) | Set to 1 if the result of the most recent operation causes an overflow, it is 0 otherwise |
| Carry (C)    | Set to 1 if the most recent operation results in a carry, it is 0 otherwise               |

*Input/output Instructions*

| Transfer of control operation | Meaning                                                   |
|-------------------------------|-----------------------------------------------------------|
| BRANCH-IF-CONDITION           | Transfer of control to a new address if condition is true |
| JUMP                          | Unconditional transfer of control                         |
| CALL                          | Transfer of control to a subroutine                       |
| RETURN                        | Transfer of control to the caller routine                 |

**Example 1** In this example, we would like to show a program segment that can be used to perform the task of adding 100 numbers stored at consecutive memory locations starting at location 1000. The results should be stored in memory location 2000.

|                                                      |                                                                |
|------------------------------------------------------|----------------------------------------------------------------|
| <i>CLEAR R<sub>0</sub>;</i>                          | <i>R<sub>0</sub> ← 0</i>                                       |
| <i>MOVE # 100, R<sub>1</sub>;</i>                    | <i>R<sub>1</sub> ← 100</i>                                     |
| <i>CLEAR R<sub>2</sub>;</i>                          | <i>R<sub>2</sub> ← 0</i>                                       |
| <i>LOOP: ADD 1000(R<sub>2</sub>), R<sub>0</sub>;</i> | <i>R<sub>0</sub> ← R<sub>0</sub> + M(1000 + R<sub>2</sub>)</i> |
| <i>INCREMENT R<sub>2</sub>;</i>                      | <i>R<sub>2</sub> ← R<sub>2</sub> + 1</i>                       |
| <i>DECREMENT R<sub>1</sub>;</i>                      | <i>R<sub>1</sub> ← R<sub>1</sub> - 1</i>                       |
| <i>BRANCH-IF &gt; 0 LOOP;</i>                        | <i>GO TO LOOP if contents of R<sub>1</sub> &gt; 0</i>          |
| <i>STORE R<sub>0</sub>, 2000;</i>                    | <i>M(2000) ← R<sub>0</sub></i>                                 |

In this example, use has been made of immediate (*MOVE #100, R<sub>1</sub>*) and indexed (*ADD 1000(R<sub>2</sub>), R<sub>0</sub>*) addressing.

## Unit 3 CONTROL UNIT

### Instruction cycles and sub cycles

Procedure for an instruction execution one by one sequentially inside CPU is called an instruction cycle.



#### Fetch Cycle:

It includes certain steps like:

1. Fetching Instruction to be executed
2. Decoding of instruction
3. Reading the operands to be

#### Execute Cycle:

It includes steps like:

1. Executing or processing the operands in ALU
2. Storing the result at the destination

### Execution of a complete instruction



## **Computer**

### **Unit 3 CONTROL UNIT**

1) Send the content of PC to MAR for memory reading and wait till Memory function is completed.  $\text{MAR} \leftarrow [\text{PC}]$

2) Increment PC

$$\text{PC} \leftarrow [\text{PC}] + 1$$

3) After memory read the instruction resides in

$$\text{MBR. IR} \leftarrow [\text{MBR}]$$

4) [IR] moves to decoder for decoding purpose.

5) Then the operation takes place according to the operand field of IR. In above steps,

Step 1 to 3 is termed as instruction fetch phase. Step 4 is known as decode phase

Step 5 is known as execute phase

## **CONTROL UNIT**

- The function of control unit is to generate relevant timing and control signals to all operations in the computer.
- It controls the flow of data between the processor and memory and peripherals

## **DESIGN OF CONTROL UNIT**

Control unit generates control signals using one of the two organizations:

- Hardwired Control Unit
- Micro-programmed Control Unit

## **HARDWIRED CONTROL UNIT**

- It is implemented as logic circuits (gates, flip-flops, decoders etc.) in the hardware.
- This organization is very complicated if we have a large control unit.
- In this organization, if the design has to be modified or changed, requires changes in the wiring among the various components. Thus the modification of all the combinational circuits may be very difficult.

## **ADVANTAGES**

- Hardwired Control Unit is fast because control signals are generated by combinational circuits.
- The delay in generation of control signals depends upon the number of gates.

## **DISADVANTAGES**

- More is the control signals required by CPU; more complex will be the design of control unit.

- Modifications in control signal are very difficult. That means it requires rearranging of wires in the hardware circuit.
- It is difficult to correct mistake in original design or adding new feature in existing design of control unit.



### MICRO-PROGRAMMED CONTROL UNIT

- A micro-programmed control unit is implemented using programming approach. a sequence of micro-operations are carried out by executing a program consisting of micro-instructions.
- Micro-program, consisting of micro-instructions is stored in the control memory of the control unit.
- Execution of a micro-instruction is responsible for generation of a set of control signals.
- A micro-instruction consists of: One or more micro-operations to be executed and address of next microinstruction to be executed.
- **Micro-Operations:** The operations performed on the data stored inside the registers are called micro-operations.
- **Micro-Programs:** Microprogramming is the concept for generating control signals using programs. These programs are called micro-programs.
- **Micro-Instructions:** The instructions that make micro-program are called micro-instructions.
- **Micro-Code:** Micro-program is a group of micro-instructions. The micro-program can also be termed as micro-code.

## Computer

### Unit 3 CONTROL UNIT

- **Control Memory:** Micro-programs are stored in the read only memory (ROM). That memory is called control memory.

#### ADVANTAGES

- The design of micro-program control unit is less complex because micro-programs are implemented using software routines.
- The micro-programmed control unit is more flexible because design modifications, correction and enhancement is easily possible.
- The new or modified instruction set of CPU can be easily implemented by simply rewriting or modifying the contents of control memory.
- The fault can be easily diagnosed in the micro-program control unit using diagnostics tools by maintaining the contents of flags, registers and counters.

#### DISADVANTAGES

- The micro-program control unit is slower than hardwired control unit. That means to execute an instruction in micro-program control unit requires more time.
- The micro-program control unit is expensive than hardwired control unit in case of limited hardware resources.
- The design duration of micro-program control unit is more than hardwired control unit for smaller CPU.

## ARCHITECTURE OF MICRO-PROGRAMMED CONTROL UNIT



## COMPARISON BETWEEN HARDWIRED AND MICRO-PROGRAMMED CONTROL UNIT

| Attributes                                    | Hardwired Control                                     | Micro-programmed Control                       |
|-----------------------------------------------|-------------------------------------------------------|------------------------------------------------|
| <b>Speed</b>                                  | Fast                                                  | Slow                                           |
| <b>Cost of Implementation</b>                 | More                                                  | Cheaper                                        |
| <b>Flexibility</b>                            | Not flexible, difficult to modify for new instruction | Flexible, new instructions can easily be added |
| <b>Ability to Handle Complex Instructions</b> | Difficult                                             | Easier                                         |
| <b>Decoding</b>                               | Complex                                               | Easy                                           |
| <b>Applications</b>                           | RISC Microprocessor                                   | CISC Microprocessor                            |
| <b>Instruction Set Size</b>                   | Small                                                 | Large                                          |
| <b>Control Memory</b>                         | Absent                                                | Present                                        |
| <b>Chip Area Required</b>                     | Less                                                  | More                                           |

### Microinstruction sequencing

- Microinstructions are usually stored in groups where each group specifies a routine, where each routine specifies how to carry out an instruction.
- Each routine must be able to branch to the next routine in the sequence.
- An initial address is loaded into the CAR when power is turned on; this is usually the address of the first microinstruction in the instruction fetch routine.
- Next, the control unit must determine the effective address of the instruction.
- The next step is to generate the micro operations that executed the instruction.
  - This involves taking the instruction's opcode and transforming it into an address for the instruction's micro program in control memory. This process is called mapping.
  - While microinstruction sequences are usually determined by incrementing the CAR, this is not always the case. If the processor's control unit can support subroutines in a micro program, it will need an external register for storing return addresses.

## MICROINSTRUCTION SEQUENCING



### Microinstructions with the next-address field

- Several branch microinstructions are required to enable sharing of common code.
- The branch microinstructions do not perform any useful operation related to data.
- They are required to determine the address of the next microinstruction.
- They slow down the execution of the instruction.
- The address field indicates the location of the next microinstruction to be fetched.
- In effect, every microinstruction becomes a branch microinstruction in addition to its other function.

### Prefetching microinstructions

To achieve faster operation, the next microinstruction can be prefetched while the current one is being executed. Execution time can be overlapped with the fetch time.

- Prefetching microinstructions presents some difficulties:
- Status flags and the results of the current microinstruction that is being executed are necessary to determine the address of the next microinstruction.
- Straightforward Prefetching may occasionally fetch a wrong instruction.
- Fetch must be repeated.

### Microinstruction Format

**Microinstructions are commonly divided into two types :**

- (1) Horizontal microinstructions
- (2) Vertical microinstructions

#### (1) Horizontal microinstructions :

In the horizontal microinstruction each bit of the microinstruction represents a control signal. A Horizontal microinstruction has the following general attributes :

1. long format
2. high degree of parallelism
3. little encoding of control information



The format of a horizontal microinstruction is as follows :

- There is one bit for each internal control line.
- There is one bit for each system bus control line.
- There is condition field for each condition for conditional branching.
- Address field that stores the address of the microinstruction to be executed next when a branch is taken.



#### (2) Vertical microinstructions :

A vertical microinstruction allows encoding of control information. Vertical microinstructions are characterized by :

- Short formats

### Unit 3 CONTROL UNIT

- Limited ability to express parallel micro-operations.
- Considerable encoding of the control information.



#### Grouping of control signals

The design of an encoded microinstruction format with distinct groups can be stated as below :

- Organize the format into independent fields. Each field depicts a set of actions (control signals). Control signals from different fields can be activated simultaneously.
- Actions from fields are mutually exclusive. Only one action specified for a given field could occur at a time.

For a hypothetical machine, control signals can be grouped as shown below :



Field definition:

1. Register Transfer
2. Memory operation
3. Sequencing operation
4. ALU operation
5. Register selection
6. Constant

## Computer

### Unit 3 CONTROL UNIT

#### Numericals

A computer has 32-bit instructions and 12-bit addresses. If there are 250 two-address instructions, how many one-address instructions can be formulated?

**Ans.** : For two address instructions, the instruction format from the given information is as shown in the Fig. 5.56.



Fig. 5.56

Opcode is 8-bit and remaining 24-bits represent two address fields. If the address is 12-bit, we can have opcode field of 20-bit. Thus we can formulate  $2^{20} = 1\text{ M}$  one address instructions with 12-bit address and 32-bit instruction length.

A computer has 16 registers, an ALU with 32 operations and a shifter with eight operations, all connected to a common bus system.

i) Formulate a Control Word for a micro-operation.

ii) Specify the number of bits in each field of the control word and give a general encoding scheme.

iii) Show the bits of the control word that specify the micro-operation  $R_4 \leftarrow R_5 + R_6$ .

**Ans.** : The Control Word is formed with following fields :

A : Register input 1 : 4-bits

B : Register input 2 : 4-bits

D : Register Destination : 4-bits

F : ALU Functions : 5-bits

H : Shifter Operations : 3-bits

#### Control Word



Fig. 5.57

Let us assume function code for addition operation is 00001 and H field with 00 indicates no shift. Then the Control Word that specifies the micro-operation  $R_4 \leftarrow R_5 + R_6$  is



Show how a 9-bit micro-operation field in microinstruction can be divided into subfields to specify 46 micro-operation. How many micro-operation can be specified in one micro-instruction ?

**UPTU 2003-20**

**Solution :**

A 9-bit microoperation field can generate  $2^9$  possible control field patterns. This is case when we go for pure vertical format.

In practice, a microoperation field is divided into subfields. This helps in combining functionally unrelated signals for maximum parallelism.

Following divisions are possible to specify 46 microoperation :

- (1) Pure vertical format (no division)



46 micro-operation can be used out of  $2^9 - 1$ .

- (2) First subfield of 5 bits and the second subfield of 4 bits.



$$\begin{array}{ll}
 1 & 2^4 - 1 \\
 2^5 - 1 & = 15 \\
 & = 31
 \end{array}$$

The first subfield will generate  $2^5 - 1 = 31$  microoperation, whereas the second subfield will generate  $2^4 - 1 = 15$  microoperation. Both the subfields together will generate 46 microoperation.

Number of micro – operation in a macro instruction =  $2^n - 1$ , where n is the length of the micro-instruction.

Formulate a mapping procedure that provides eight consecutive microinstruction for each routine. The operation code has six bits and the control memory has 2048 words.

**UPTU 2005-20**

### Unit 3 CONTROL UNIT

**Solution :**

In the design given below, two address fields have been provided in each microinstruction.

$$\text{Number of bits required to address a word} = \log_2 2048 = \log_2 2^{11} = 11 \text{ bits.}$$

*/ Length of the microinstruction*

$$\begin{aligned} &= 6 \text{ (Operation code)} + 2 \times 11 \text{ (two address fields of 11 bits each)} \\ &= 28 \text{ bits} = 4 \text{ words.} \end{aligned}$$

$$\text{Number of micro-instructions, that can be stored in the control memory} = \frac{2048}{4} = 512$$

*Number of routines, that can be stored in the control memory*

$$(8 \text{ instructions per routine}) = \frac{512}{8} = 64 = 2^6$$

**Microinstruction format :**

|  |                   |              |              |
|--|-------------------|--------------|--------------|
|  | 6                 | 11           | 11           |
|  | Operation<br>code | address<br>s | address<br>s |

**Control memory organisation :**

$$\text{Instruction size} = 4 \text{ words} = 28 \text{ bits}$$

$$\text{Routine size} = 8 \text{ instructions} = 8 \times 4 = 32 \text{ words}$$

$$\text{Number of routines} = 64$$

\*\*\*\*End Of Unit 2\*\*\*\*