

## Interrupt and its -types

Program Interrupt :- Program interrupt refers to the transfer of control from a currently running program to another service program as a result of an external or internal generated request.

- \* Control returns to the original program after the service program is executed.
- \* When an interrupt is initiated, the state of CPU containing following information is saved.
  - 1) Content of program counter (PC)
  - 2) Content of all CPU register.
  - 3) Content of status bit conditions (PSW)
- \* CPU does not respond to the interrupt until the execution of currently running instruction ends.



## Transfer of Program Control via Interrupt

\* Before going to next fetch cycle, It checks for an interrupt signal, If there is an interrupt.

- (1) Save CPU state (PC, CPU register, PSW), in memory stack
- (2)  $PC \leftarrow$  interrupt branch address  
 $PSW \leftarrow$  Status bits of interrupt device program.
- (3) Last instruction of service program is return from interrupt.
- (4)  $PSW \leftarrow$  old PSW,  $PC \leftarrow$  old PC,  
 CPU register  $\leftarrow$  old CPU register

### Types of program Interrupts.

D) External Interrupts :- External interrupts are generated by input output devices, by a timing device, from a circuit monitoring the power supply or from any external source. They are "asynchronous".

Eg:- (i) I/O device requesting transfer of data.

(ii) I/O device finished transfer of data.

(iii) Timeout interrupt is generated from program that goes into endless loop.

(iv) power failure circuit also causes interrupt

② Internal Interrupt :- Internal interrupts are generated from illegal or erroneous use of an instruction also called "Traps".

- Eg:-
- (i) Due to register overflow error.
  - (ii) Divide by zero error.
  - (iii) Invalid operation code (opcode).
  - (iv) Stack overflow.

Internal interrupts are "synchronous" with the program.

" Both External and internal interrupts are initiated from signal that occurs in the hardware of the CPU".

③ Software Interrupt :- Software interrupt is a special case instruction that behaves like an interrupt rather than a subroutine call.

- \* It is initiated by executing an instruction.
- \* It is used by the programmer to initiate an interrupt procedure at any desired point in the program.

Eg:- Supervisor Call instruction generates a software interrupt to switch

from user mode to supervisor mode.

### Instruction Cycle

- An instruction cycle specifies the various steps required during the processing of an instruction.



(Basic Instruction Cycle)



(Basic Instruction cycle with Interrupt)

## Instruction cycle State diagram.





AR = Address Register

IR = Instruction Register

SC = Sequence Counter

VR = 1 bit flip flop

EN = Interrupt Enable

PC = Program Counter

I = 1 bit flip flop

TR = Temporary Register

T<sub>0</sub>, T<sub>1</sub>, T<sub>2</sub>, T<sub>3</sub>... = timing signal



Main Memory



Save PC at memory 0 & interrupt address at memory 1

|   |                   |
|---|-------------------|
|   | Save PC           |
| 1 | Interrupt Address |
|   |                   |
|   |                   |

(a) M  $\rightarrow$  DR 0  $\rightarrow$  2A

I  $\rightarrow$  4

→ find 0

→ find 2A

→ stack

program ready

→ find 4

2A

ab330

2A

2A

## RISC vs CISC

| RISC (Reduced Instruction Set Computer)              | CISC (Complex Instruction set computer) |
|------------------------------------------------------|-----------------------------------------|
| 1. Simple Instructions                               | 1. Complex Instructions                 |
| 2. Less no. of instruction                           | 2. Large no. of instructions            |
| 3. Hardwired Control Unit                            | 3. Microprogrammed control unit         |
| 4. $\approx 1$ cycle/instruction                     | 4. 2 or more cycles/instruction.        |
| 5. Fixed Instruction format.                         | 5. Variable Instruction format.         |
| 6. High pipelined.                                   | 6. Sequential / less pipelined.         |
| 7. Fewer addressing modes                            | 7. More addressing modes.               |
| 8. Only load & store instructions can access memory. | 8. Many instructions can access memory. |
| 9. Uses more registers                               | 9. Uses less registers.                 |
| 10. Used in mobile phones and tablets.               | 10. Used in desktop & laptops.          |

## Microprogrammed Control Unit

- \* A microprogrammed control unit is a control unit in which control signals are stored in binary form (0 & 1) as control word in a ROM chip called control memory.
- \* Each control word consists of micro-instructions.
- \* Each microinstruction when executed, generates sequence of micro-operations to fetch instruction from memory, calculate effective address, fetch operand etc.
- \* A set of ~~instructions~~ microinstructions is called a microprogram.
- \* A set of microinstructions belonging to a machine instruction is called a micro routine.
- \* A microinstruction is a control word stored in control memory (ROM chip).
- \* A control memory is a ROM chip which stores microinstructions as control words in it.
- \* Microprogramming is the art of writing microprogram (micro-code) for the control unit in a CPU.





Next Address Information

### General Configuration of Microprogrammed Control Unit

1. Microprogram sequence:- It is also called next address generator as it determines the address of next microinstruction that is read from control memory.
2. Control Address Register:- It holds the microinstruction in the control memory. It is represented by CAR.
3. Control Memory:- The control memory is actually a ROM chip where all the microinstructions are stored.
4. Control data Register:- It stores the microinstruction after reading from control memory. The microinstruction when executed, perform a set of micro-operations along with providing the next address.

Microprogram Sequences :- It is called next address generator

Can generate the next address of the microinstruction in control memory using 4 methods.

- (i) Increment the control address Register.
- (ii) Unconditional / conditional branch depending on ~~state~~ status bit flags.
- (iii) Subroutine call & return.
- (iv) Mapping from machine instruction to microinstruction address.

Mapping from machine instruction to micro-instruction address

| Instruction Register (IR) | Mode<br>1 bit               | opcode<br>3 bits              | address<br>11 bits |
|---------------------------|-----------------------------|-------------------------------|--------------------|
|                           | 15      14      11 0      0 | Mode      opcode      address |                    |

Mapping Logic       $CAR(0, 1, 6) \leftarrow 0$   
 $CAR(2-5) \leftarrow IR(11-14)$

Let  $CAR = 7$  bits

$IR = 16$  bits

$IR = [0 \ 0111 \ 10 \ 11 \ 0100 \ 101]$   
 15    14    11 0    0    bit no.

↓ mapping logic

$CAR = [0 \ 0 \ 1 \ 1 \ 1 \ 0 \ 0]$   
 6    5    4    3    2    1    0    Bit No.

## Micro-instruction format

|                |                |                |        |        |        |
|----------------|----------------|----------------|--------|--------|--------|
| F <sub>1</sub> | F <sub>2</sub> | F <sub>3</sub> | CD     | BR     | AD     |
| 3 bits         | 3 bits         | 3 bits         | 2 bits | 2 bits | 7 bits |

F<sub>1</sub>, F<sub>2</sub>, F<sub>3</sub> → micro-operation fields.  
 CD → Condition for branching.  
 BR → Branch field.  
 AD → Address field.

F<sub>1</sub> (3 bits) → specify a total of 8 micro-operations (including No-operation)

F<sub>2</sub> (3 bits) → specify a total of 8 micro-operations (including No-operation).

F<sub>3</sub> (3 bits) → specify a total of 8 micro-operations (including No-operation).

$$\text{Total micro-operations} = 2^4(2^1 + 3(\text{No-op}))$$

### CD (Condition field)

| CD | Condition  | Symbol | Comments             |
|----|------------|--------|----------------------|
| 00 | Always = 1 | U      | Unconditional Branch |
| 01 | JR (15)    | I      | Direct Addr bit      |
| 10 | AC (15)    | S      | C15 bit of AC        |
| 11 | AC = 0     | Z      | zero value in AC     |

## BR (Branch field)

| BR | Symbol | Function                                                                                                      |
|----|--------|---------------------------------------------------------------------------------------------------------------|
| 00 | JMP    | CAR $\leftarrow$ AD, if condition = 1<br>CAR $\leftarrow$ CAR + P, if condition = 0                           |
| 01 | CALL   | CAR $\leftarrow$ AD, SBR $\leftarrow$ CAR + P, if condition = 1<br>CAR $\leftarrow$ CAR + P, if condition = 0 |
| 10 | RET    | CAR $\leftarrow$ SBR (Return from subroutine)                                                                 |
| 11 | MAP    | CAR(2,5) $\leftarrow$ JR(11-14), CAR(0,1,6) $\leftarrow$ 0                                                    |

BR[5]

| B R T | S, S <sub>0</sub> L |
|-------|---------------------|
| 0 0 0 | 0 0 0               |
| 0 0 1 | 0 1 0               |
| 0 1 0 | 0 0 0               |
| 0 1 1 | 0 1 1               |
| 1 0 X | 1 0 0               |
| 1 1 X | 1 1 0               |



Design of microprogrammed control Unit

## ~~States & Codes~~ Hardwired Control Unit

- \* In hardwired control unit, the control signals are generated using logic circuit (gates, flip-flops & decoder) in the hardware. Hardwired control unit is faster because control signals are generated using logic circuit.

Block diagram of hardwired control unit consists of :-

- 1) Instruction Register :- used to store the instruction fetched from the memory.
- 2) Decoder :- used to decode (interpret) the operation code of the instruction.
- 3) Clock - used to generate a sequence of timing signals using timing generators.
- 4) Flags :- condition codes/ status flags are used to specify the status of previous ALU operation.

Generation of control signals :- An example of how the control signals are generated is as shown :-



Consider C<sub>5</sub> : MBR  $\leftarrow$  Memory

| Cycle           | No. of operations                              | control signals |
|-----------------|------------------------------------------------|-----------------|
| Fetch           | t <sub>1</sub> : MAR $\leftarrow$ PC           | C <sub>2</sub>  |
| PQ=00           | t <sub>2</sub> : MBR $\leftarrow$ memory       | C <sub>5</sub>  |
| Indirect        | t <sub>1</sub> : MAR $\leftarrow$ IR (address) | C <sub>8</sub>  |
| PQ=01           | t <sub>2</sub> : MRR $\leftarrow$ memory       | C <sub>5</sub>  |
| Interrupt cycle | t <sub>1</sub> : MBR $\leftarrow$ PC           | C <sub>4</sub>  |
| PQ=10           | t <sub>2</sub> : MBR $\leftarrow$ memory       | C <sub>5</sub>  |

execute cycle PQ=11

$$C_5 = \bar{P} \bar{Q} t_2 + P \bar{Q} t_2 + P Q' t_3$$

Let only LOA, ADD, AND instruction read from memory

$$C_5 = \bar{P} \bar{Q} t_2 + P \bar{Q} t_2 + P \bar{Q} t_3 + P Q (LOA + ADD + AND) t_2$$

## Horizontal vs Vertical Microprogramming.

- \* The process of writing micro code for the control memory of control unit in the CPU is called microprogramming.
- \* Control memory stores micro program.
- \* Microprogram is a set of microinstructions.
- \* Each line (location) of control memory stores a microinstruction (MI). Microinstructions specify one or more micro operations.

### Organisation of microinstructions.

- (1) horizontal microprogramming microinstruction.
- (2) vertical microinstruction.

#### Horizontal microinstruction.

- \* Each horizontal microinstruction uses 1 bit/ control signal (decoded).
- (8 bits for 8 control signals).
- (Horizontal implies long microinstruction).



Vertical Microinstruction: Each vertical microinstruction represents control signals in encoded form.  
 i.e. (3 bits for 8 control signals)  
 If  $m$  is the no. of control signals  
 then  $(\log_2 m)$  bits are required.

(Vertical implies short microinstruction)



### Horizontal Microprogramming      Vertical Microprogramming

|                                     |                                      |
|-------------------------------------|--------------------------------------|
| 1. Long microinstruction            | 1. Short microinstruction            |
| 2. No encoding of control signals   | 2. Encoding of control signals       |
| 3. High degree of parallelism.      | 3. Low degree of parallelism.        |
| 4. No additional hardware           | 4. Additional hardware required.     |
| 5. Faster (fast execution)          | 5. Slower (slow execution)           |
| 6. Less use of ROM (control memory) | 6. More use of ROM (control memory). |
| 7. Optimize performance             | 7. Optimize programming.             |
| 8. Little or no control logic       | 8. Complex control logic             |

Pipelining :- Pipelining is a technique of decomposing a sequential process into a no. of subprocesses with each subprocess being executed in a special dedicated segment that operates concurrently with all other segments.

### Features of pipelining :-

- 1) The partial result obtained from the computation in each segment is transferred to the next segment in the pipeline and so on.
- 2) The final result is obtained after the data have passed through all segments.
- 3) Several computation can be performed in different segments at the same time.

### General structure of 4-segment pipeline.

- \* A 4 segment pipeline consists of 4-segments.
- \* The segments are separated by registers.
- \* Registers are used to hold intermediate results. while Segments consists of combinational circuit.



Segments =  $S_1, S_2, S_3, S_4$

Registers =  $R_1, R_2, R_3, R_4$

Space-time diagram :- is a diagram that shows the segment utilization as function of time.

Let no. of segments = 4

No. of tasks = 6

| seq.<br>No. | 1     | 2     | 3     | 4     | 5     | 6     | 7     | 8     | 9     |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| $S_1$       | $T_1$ | $T_2$ | $T_3$ | $T_4$ | $T_5$ | $T_6$ |       |       |       |
| $S_2$       |       | $T_1$ | $T_2$ | $T_3$ | $T_4$ | $T_5$ | $T_6$ |       |       |
| $S_3$       |       |       | $T_1$ | $T_2$ | $T_3$ | $T_4$ | $T_5$ | $T_6$ |       |
| $S_4$       |       |       |       | $T_1$ | $T_2$ | $T_3$ | $T_4$ | $T_5$ | $T_6$ |

$$\text{Speed up ratio} = \frac{4 \times 6}{4+5} = \frac{24}{9} = 2.67$$

### Instruction pipeline

- \* An instruction pipeline reads consecutive instructions from memory while previous instruction are executed in various segments of pipeline

Example :- 4-segment Instruction pipeline.

The process of each instruction is divided into 4-segments.

- 1) FI is the segment that fetches an instruction.
- 2) DA is the segment that decode instruction and calculate effective address.
- 3) FO is the segment that fetches the operand.
- 4) EX is the segment that executes the instruction.

| I | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 1 | FI | DA | FO | EX |    |    |    |    |    |    |    |    |    |
| 2 |    | FI | DA | FO | EX |    |    |    |    |    |    |    |    |
| 3 |    |    | FI | DA | FO | EX |    |    |    |    |    |    |    |
| 4 |    |    |    | FI | —  | —  | FI | DA | FO | EX |    |    |    |
| 5 |    |    |    |    |    |    |    | FI | DA | FO | EX |    |    |
| 6 |    |    |    |    |    |    |    |    | FI | DA | FO | EX |    |
| 7 |    |    |    |    |    |    |    |    |    | FI | DA | FO | EX |

Timing diagram at Instruction pipeline

(R)

### Pipeline Hazards (Data Dependency)

- \* Data dependency occurs when an instruction depends on the result of the previous instruction, but this result is not yet available.

Let instruction  $i: x = y + z$

instruction  $i+1: x_1 = x + 1$

| <del>I</del>          | 1  | 2  | 3  | 4  | 5  | 6 |
|-----------------------|----|----|----|----|----|---|
| Inst <sup>n</sup> i   | FI | DA | FO | EX |    |   |
| Inst <sup>n</sup> i+1 |    | FI | DA | FO | EX |   |

Solutions (Hardware & Software Method)

↓  
Hardware  
Interlock

↓  
operand  
forwarding

(i) Hardware Interlock :- Hardware interlock is a circuit that

detects instructions where source operands are destinations of instruction farther up in the system. Detection of such situation causes the instruction whose source is not available to be delayed by enough clock cycles to resolve the conflict.

(ii) Operand forwarding :- They use special hardware to detect a conflict and then avoid it by routing the data through special paths between pipeline segments.

(iii) Software Method :- In the software method, the compiler is designed to detect a data conflict and reorder instructions as necessary to delay the loading of the conflicting data by inserting "No-operation" instruction. This

method is called "Deny Load".

Instruction Pipeline conflicts :- Pipeline conflicts causes instruction pipeline to deviate from its normal operation.

### Types of conflicts

- ① Resource conflict (Structural Hazards)
- ② Data dependency (Data Hazards)
- ③ Branch Bifurcacy (Control Hazards)

#### ① Resource conflicts (Structural Hazards)

- \* Resource conflict is a situation when more than one instruction tries to access the same hardware resource in the same cycle.
- \* A resource can be a register, memory or ALU.
- \* It is also called structural hazards.
- \* Let an instruction has 4 pipeline segments

- ① Fetch instruction (FI)
- ② Decode instruction & calculate effective address (DA)
- ③ Fetch operands (FO)
- ④ Execute instruction (Ex)



Resource conflicts (Structural hazards)

### Solution to Resource Conflicts

- ① Use of separate data memory & instruction memory resolves most of the conflicts.
- ② Use of pipeline stall (It is delay in the execution of an instruction in order to resolve a hazard)



### Branch difficulties

- \* Branch difficulties occur in branch instructions (conditional/unconditional jump instructions) in which the branch target address is not known until the branch instruction is decoded.





① Prefetch Branch Target Instruction :- When a conditional branch is recognized, the target instruction is fetched in advance along with the instruction following the branch.

② Branch type Target Buffer (BTB) :- It is an associative memory included in the fetch segment of the pipeline.

- \* Each entry in BTB consists of address of previously executed branch instruction and its target instruction.
- \* When the branch instruction is decoded, it is first searched in BTB and if it is found, the instruction is available directly else the pipeline shifts to new instruction & store the target instruction in the BTB.

③ Delayed Branch :- The compiler detects the branch instructions and rearrange (Re-order) the instructions.

Original Order

- ① Add R<sub>2</sub>, R<sub>3</sub>
- ② Decrement R<sub>1</sub>
- ③ If R<sub>1</sub> = 0, goto 40

(40)

Re-order

- ① Decrement R<sub>1</sub>
- ② If R<sub>1</sub> = 0, goto 40
- ③ Add R<sub>2</sub>, R<sub>3</sub>

(40)

Q) Loop buffer :- A loop buffer is a small, very high speed memory maintained in the FI (Fetch Instruction) stage.

- \* It contained the most recent fetched instruction.
- \* If a branch is taken, first the target instruction is searched in the load buffer
- \* If exist, it is fetched from the buffer to save time.