

## \* Priority Interrupt :-

DOMS

Page No.

Date

- There are number of I/O devices attached to the computers.
- They all are capable of generating the interrupt.
- When the interrupt is generated from more than one device simultaneously, Priority interrupt system is used to determine which is to be serviced first.  
"A priority interrupt is a system that establishes a priority over the various sources to determine which condition (interrupt) is to be serviced first when two or more requests arrive simultaneously."
- Devices with high speed transfers are given higher priority (eg: Harddisk)
- And slow devices are given lower priority (eg: Keyboard)
- When multiple devices interrupt CPU at the same time, the device with higher priority served first.



→ Establishing Priority of Simultaneous Interrupts  
2 ways

Using Software Method  
→ Polling

Using Hardware Method  
Serial connection  
Parallel connection

Serial conversion  
↓  
Daisy chaining  
Priority Interrupt  
(Serial Priority interrupt)

Lecture 5  
Date \_\_\_\_\_  
Parallel Priority  
Interrupt

## ⑥ by Software (Polling)



- Polling is a software method of establishing priority of simultaneous interrupts.
- In this method, when processor detects an interrupt, it branches to a common ISR whose job is to poll each P/O device to determine which device caused the interrupt.
- In this method.
  - . There is one common branch address for all interrupt.
  - . Branch address contain program code that polls the interrupt sources in sequence (i.e. checks each source whether they have generated the interrupt).
  - . Highest priority source is test first, if its interrupt signal is ON, control branches to a **ISR** for this source. Otherwise the next lower priority source is tested & so on.

Interrupt Service Routine.

which devices are polled) Page No. \_\_\_\_\_

Advantage : ① Flexible since established by software.

② Low cost since it need a very less hardware.

Disadvantage : ① Very slow

② Time overhead to handle many interrupt can be excessive.

Time required to poll many devices can exceed the time-slot available to service the I/O device.]

## o By hardware Method:

→ Requires a priority interrupt manager which accepts all the interrupt requests to determine the highest priority request.  
(Hardware Priority Interrupt Unit)

→ Fast since identification of highest priority interrupt request is identified by hardware.

→ To speed up the operation, each interrupt source has its own interrupt vector to access its own service routine directly.

→ True no polling is required because all decisions are established by the hardware priority interrupt unit.

→ Hardware priority function can be established by either serial or a parallel connect of interrupt lines.

# Instruction Formats

Page No.

Date / /

Program: A sequence of instructions

Instruction: It is a command given to the computer to perform a specific operation.

- An instruction is a group of bits (binary code) that instructs the computer to perform a specific operation.
- The purpose of an instruction is to specify both operation to be performed by CPU & the set of operands (or data)
  - Operation include add, sub, mul, shift etc. Operations are performed on data (operands).
  - Operands include the input data & the results that are produced.

## What is Instruction Format?

- An instruction format is a binary format which specifies a computer instruction.
- The bits of the instructions are divided into groups called fields.

[mode] opcode [Address or Operand]

Instruction format (with mode field)

The most common fields in instruction format are

DOMS

Page No.

Date

/ /

1. Opcode (Operation Code): An opcode (operation code) field specifies the operation to be performed such as add, sub, mul, shift, complement etc.
2. Address: An address field specifies a memory address or processor register, where operand is stored.
3. Mode: A mode field specifies the way the operand or the effective address of the operand is determined (or located).

## CPU Organization & Types Of Instructions

- Computers may have inst. of several diff. lengths containing varying number of addresses (address field may be 3, 2, 1, 0)
- The no. of address field in inst. format of a computer depends on the internal organization of its registers.
- Most computers fall into one of the three types of CPU organization.
  1. Single accumulator Organization
  2. General register
  3. Stack

## Type of inst. formats / Types of address insts.

Done

Page No.

Date

1. Three address inst. formats ) Single
2. Two      "      "      "      → general.
3. One      "      "      "      → short
4. Zero      "      "      "      → short

## \* Classification of inst. based on CPU organization.

### (i) Single accumulator organization:

All operations are performed on an implied Accumulator (AC) register.

- With one operand implicitly in the accumulator register minimizes the internal complexity of the machine & allows for short instructions.
- The Inst. format uses only one address field (i.e one - address inst. format).

e.g: LOAD X    // AC  $\leftarrow M[X]$

ADD X    // AC  $\leftarrow AC + M[X]$

STORE Y    // M[Y]  $\leftarrow AC$

### (ii) General Register Organization:

- It uses set of general purpose register (R0, R1, R2 ... ) one of the most widely accepted models for machine architecture today.
- Specifies all operands explicitly.
- The instruction format needs 2 or 3 address fields according to the operation (i.e two or three address instruction format).

eg: ADD R1, R2, R3. //  $R1 \leftarrow R2 + R3$

ADD R1, R2 //  $R1 \leftarrow R1 + R2$

Page No.

ADD R1, X //  $R1 \leftarrow R1 + M[X]$

- Each address field may specify a processor register or memory operand.

### Stack Organization:

- The operands are put into the stack and the operations are carried out on the top of the stack (TOS). The operands are implicitly specified on TOS.
- It does not use an address field for the instructions like ADD, MUL etc. (i.e zero-address instruction format).
- Push and Pop instructions are used to communicate with stack, which require an address field.

eg Push A ] Stack ch bona

Push B

Add — Add kerwata dona da

Pop C ] c ch pata / mtlb Stack  
cho fd lea.

Here ADD consist of only opcode and no address field. It has the effect of popping the top two numbers from the stack, adding them and pushing the sum onto the stack. Thus all the operands are implied to be in the stack.

Three address instruction

DOMS

Page No.

Date

/

/

[opcode | destination address | source address<sub>1</sub> | source address<sub>2</sub>]

- 3 address instruction format has three address fields.
- One address field is used for destination & two address fields for source.
- Each address field may specify a processor register or a memory operand.
- It is also called general registers organization.

e.g.: ADD R1, R2, R3      // R1  $\leftarrow$  R2 + R3  
ADD R1, A, B      // R1  $\leftarrow$  M[A] + M[B]

- Advantage: Results in short programs when evaluating arithmetic expression.
- Disadvantage: Binary coded inst. require too many bits to specify three address, complex

Ex: evaluate C = A + B [using 3 address inst.]

- The contents of memory location A & B are fetched from memory.
- Transformed into the processor where their sum is computed.
- The result is then sent back to the memory & stored in location.

ADD C, A, B      // M[C]  $\rightarrow$  M[A] + M[B]

## \* Two address Inst

2015

Page No.

Date

opcode | Destination Address / Source address

- Two address inst are most common in commercial computers.
- It has 2 address fields.
- Each address fields may specify a processor register or a memory operand.

Ex : ADD R<sub>1</sub>, R<sub>2</sub>    // R<sub>1</sub> ← R<sub>1</sub> + R<sub>2</sub>  
MOV R<sub>1</sub>, R<sub>2</sub>    // R<sub>1</sub> ← R<sub>2</sub>.

## \* One Address Instruction

Opcode | Operand Address (S/D) |

- It has only one address field. The operand specified in the instruction may be source or destination, depending on instruction.
- One address instructions use a implied ACCUMULATOR (AC) register for all data manipulation.
- Implied means that the CPU already knew that one operand is in accumulator so there is no need to specify it.
- All operations done between accumulator register & memory operand.
- It is also called Single Accumulator Organization.

Eg: ADD X

11AC ← AC + M[PC]

2015

Page No.

Date

/

Ex: Evaluate  $C = A + B$

Load A

[ AC ← M[IA] ]

Add B

AC ← AC + M[PB]

Store C

M[C] ← AC

Load & Store instruction: Used for transfer to and from memory to AC register

## \* Zero address instruction

[opcode] (zero address inst. format)

- In zero address inst. stack is used. Also called stack based organization.
- A stack based computer does not use an address field in the inst. (like add, mul)
- Push & pop inst. however, need an address field to specify the operand that communicate with stack.
- To evaluate a arithmetic expression first it is converted to Revere Polish Notation i.e Post fix Notation.
- The name "zero-address" is given to this type of computer of the absence of an address field in an inst.

Eg:  $C = A + B$

Push A

A Push B

Add

Pop C



✓ C

#

# Addressing Modes

DOMS

Page No.

Date / /

- ▷ Address Field: Contains the info. needed to determine the location of the operands & the result of an operation.
- ▷ Addressing Mode: Specifies how to interpret the info. within this address field, how to compute the actual or effective address of the data needed.

## Definitions:

- The different ways of specifying the location of an operand in an inst. are called as addressing modes.
- The addressing mode specifies a rule for interpreting or modifying the address field of the inst. before the operand is actually referenced.

## # Purpose of Using addressing mode:

- To give the programming versatility to the user.
- Pointers to memory, counters for loop, indexing of data, program relocation etc.
- To reduce the number of bits in addressing field of instruction.

## Instruction Cycle

DOMS

Page No.

- = Fetch the inst from memory  
and  $PC \leftarrow PC + 1$
- = Decode the inst
- = Execute the inst

## Program Counter

- = PC keeps track of the inst. in the program stored in memory.
- = PC holds the address of the next inst to be executed.
- = PC is incremented each time an inst is fetched from memory.

## Addressing mode of inst.

- = Distinct binary code: In some computers the addressing mode of the inst is specified with a distinct binary code, just like the operation code is specified.
- = ~~None~~
- = Single binary code: other computer else a single binary code that designates both the operation and the mode of inst.

Effective address (EA): EA is the actual address of the operand, where it is actually stored.

# Types of addressing modes

Page No.

Date

/ /

- 1. Implied / Implicit Mode
- 2. Immediate
- 3. Direct
- 4. Indirect
- 5. Register direct
- 6. Register Indirect
- 7. Auto Increment/Decrement
- PC 8. Relative addressing mode  
Indirect register
- 9. Indexed " "
- BR 10. Base register " "

- No address field is required
- 3,4 Address specifies memory location
- 5-7 Address of processor register
- 8-10 Address field + content of CPU register  
(These are called displacement addressing)
- 1. Operands are specified implicitly in the definition of inst.

Ex: CMA : Complement Accumulator  
a operand in AC is implied in the definition of the inst.

CLA : Clear accumulator  
operand in AC is implied in the definition of the inst.

Push : Stack Push

Operand is implied to be on top of the stack (TOS).

- All register reference inst. that use an accumulator, are implied - mode inst.

Zero address inst. in a stack organized computer are implied mode instructions since the operands are implied to be on top of the stack

## 2 Immediate Mode

- Operand is specified in the instruction itself.
- An immediate mode instruction has an operand field rather than the address field.
- Operand field contain the actual operand.
- Operand = Address.

| opcode | operand |
|--------|---------|
|--------|---------|

eg: Load #7      // Ac  $\leftarrow$  7  
Add #5            // Ac  $\leftarrow$  Ac + 5

## 3 ~~Acc~~ Direct Mode :

- The operand resides in memory & its address is given directly by the address field of inst.
- Address field of inst contains the effective address EA (or actual address) of operand
- EA = A (address field)

eg. ADD A      // AC  $\leftarrow$  AC + MEA  
Load B           // AC  $\leftarrow$  M[B]

- It is also called absolute addressing mode.

### Advantage:

- Simple, → Single memory reference to access data, → No additional calculations to work out effective address.

## Disadvantage:

- Address space is limited to the size of the address field.

DOMS

Date

Page No.



## 4. Indirect Mode.

- Address field of inst. specifies the address where the effective address of operand is stored in memory.
- $EA = (A)$  or  $EA = @A$  Look in A, find address (A) and look there for operand.

Opcode | Address A |



## \* Advantage :

- Larger address space is possible

$2^n$  where  $n = \text{word length}$ .

## \* Disadvantage :

- Multiple (two) memory reference to find the operand.
- Hence Slower.

5. Register Node :
- Operand is stored in the register. (Register resides within the CPU)
  - Address field of the inst refers to a CPU register that contains the Operand
  - $EA = R_1$
  - A  $k$ -bit field can specify any one of  $g^k$  registers.

opcode | Register address  $R_1$

Eg:  $MOV R_1, R_2$   
 $\quad \quad \quad // R_1 \leftarrow R_2$

No reference to memory is required to fetch the operand.

Registers

operand

#### \* Advantages :

- Due to limited no. of registers, very small address field.
- Shorter inst.
- No memory reference (access)
- Very fast execution.

#### \* Disadvantages :

- Very limited address space.
- Using multiple registers helps performance but it complicates the inst.

## 6. Register Indirect Mode :

DOMS

Page No.

Date

- The address field of inst specifies the register that contains the effective address of operand. The operand is in memory.
- The register contains the effective address of operand rather than the operand itself.
- $EA = R_i$



Ex : ADD (R<sub>1</sub>), R<sub>2</sub>      //  $M[R_1] \leftarrow M[R_1] + R_2$

### \* Advantage :

- Address field of inst uses fewer bits to select a memory address.
- Large address space :  $2^n$
- One fewer memory access than indirect addressing.

### \* Disadvantages :

- Extra memory reference

7. Auto increment / decrement mode
- Similar to register indirect mode (effective address of operand is the content of register specified in the inst) except that
- In Auto increment: The register is incremented after its value is used to access memory.
- $EA = (R_i) +$
- In auto decrement: The register is decremented before its value is used to access memory.
- $EA = - (R_i)$
- It is used when address stored in the register refers to a table of data in memory, it is necessary to increment or decrement the register after every access to the table.

Ex: Auto increment

$ADD R_1, (R_2) + \quad // R_1 \leftarrow R_1 + M[R_2], R_2 \leftarrow R_2 + 1$

Ex: Auto decrement

$ADD R_1, - (R_2) \quad // R_2 \leftarrow R_2 - 1, R_1 \leftarrow R_1 + M[R_2]$

## 8. Displacement Addressing

- Few addressing modes require that the address field of inst be added to the content of a specific register in the CPU.
- Effective address = Address part of inst + Content of CPU register (PC/XE/R)
- $EA = A + CR$

- Address field hold two values  
 → A = base value  
 → R = Register that holds displacement/offset  
 or Vice Versa.  
 → R = Base Value  
 → A = Register that holds displacement/offset

\* Advantage: flexibility

\* Disadvantage: complexity



3 versions of displacement addressing:

1. Relative addressing ( $EA = PC + A$ )
2. Indexed      "      ( $EA = A + XR$ )
3. Base register    "      ( $EA = Ri + A$ )

#### 8- Relative Addressing Mode

- Register = Program Counter (PC)
- The content of PC is added to the address part of the inst to obtain the effective address of operand.

Effective address = content of PC + address part of inst.

$$EA = (PC) + A$$

Ex: Load \$A or Load A(PC) ( $A \leftarrow M[R+PC]$ )

opcode | Address A |

DOMS Date / /  
memory Page No.

[PC] → X +

operand

### 9. Indexed addressing Mode.

→ Register = Index Register.

→ The content of index register is added to the address part of the inst to obtain the effective address of operand.

effective address = Content of XR + Address part of inst.

$$EA = A + (XR) \text{ or } EA = A + (R_i)$$

→ A contains the Constant Value in inst.

→ XR/Ri is the name of register involved holds index value.

→ Index register used here is either a special CPU register (XR) provided for this purpose or commonly, it may be anyone of a set of general purpose registers ( $R_i$ ) in the processor; that contain an index value.

Ex: ADD R1, 20(R2) //  $R_1 \leftarrow R_1 + M[20+R_2]$   
ADD R1, 100(XR) //  $R_1 \leftarrow R_1 + M[100+XR]$

- Index register holds a index no. that is relative to address part of the inst.
- Used for accessing arrays



## 10 Base Register Addressing Mode

- Similar to indexed addressing except that the register is now called a base register.
- Register = Base register
- The content of base register is added to the address part of the inst. to obtain the effective address of operand.

Effective Address = Content of BR + Address part of inst.

$$EA = (R_i) + A$$

$R_i$  is base register that hold base address  
 $A$  holds a displacement relative to this base address.

Same diagram for Constant value  
 $R_i$  for displacement  $A$  in.

Ex: Load A( $R_1$ ) //  $R_1 \leftarrow M[R_1+A]$

Add  $R_1, 20(R_2)$  //  $R_1 \leftarrow R_1 + M[R_2+20]$

- Useful in Computers to facilitate the execution of programs in memory.