

---

---

# CENTRAL PROCESSING UNIT

UNIT - IV



---

# CONTENT

1. General register organization
2. Stack organization
3. Instruction format
4. Addressing modes
5. Data transfer and manipulation instructions
6. Program control
7. RISC, and CISC



# 1. GENERAL REGISTER ORGANIZATION

# INTRODUCTION

The central processing unit is where all the calculations and logic operations take place.

CPU performs data-processing operations.

Main parts of the CPU are:

Arithmetic Logic Unit (ALU)

Control Unit (CU)

Registers



# INTRODUCTION

The **registers set** stores intermediate data used during the execution of the instructions.

The **ALU** performs the required micro-operations for executing the instructions.

The **Control unit** supervises the transfer of information among the registers and instructs the ALU as to which operation to perform.



---

## GENERAL REGISTER ORGANIZATION

Registers are more convenient and efficient to **store pointers, return addresses, counters, temporary results**, etc.

In Basic Computer, there is only one general-purpose register, the Accumulator (A), but in modern CPUs, there are many general-purpose registers.

It is advantageous to have many registers:

Transfer between registers within the processor is relatively fast.

Going “off the processor” to access memory is much slower.

---

## GENERAL REGISTER ORGANIZATION

When a **large number of registers** are included in the CPU it is efficient to connect them through a **common system bus**.

Because registers communicate with each other not only for direct data transfers but also while performing various microoperations.

# A BUS ORGANIZATION FOR SEVEN CPU REGISTERS

The control unit directs the information flow through ALU by

Selecting various components in the system.

Selecting the Function of ALU.  
**Example:**  $R1 \leftarrow R2 + R3$

1. MUX A selector (SEL<sub>A</sub>): BUS A  $\leftarrow$  R<sub>2</sub>.
2. MUX B selector (SEL<sub>B</sub>): BUS B  $\leftarrow$  R<sub>3</sub>.
3. ALU operation selector (OPR): ALU to ADD.
4. Decoder destination selector (SEL<sub>D</sub>):  $R1 \leftarrow$  Out Bus

The entire information is passed through the Control Word.



# CONTROL WORD FORMAT

The control word is determined by the sum of the binary selection inputs.

It is divided into four sections.

SELA, SELB, and SELD each have three bits,

the OPR field has five bits.

For a total of 14 bits in the control word.



# CONTROL WORD FORMAT



Register Selection Field

| Binary Code | SELA  | SELB  | SELD |
|-------------|-------|-------|------|
| 000         | Input | Input | None |
| 001         | R1    | R1    | R1   |
| 010         | R2    | R2    | R2   |
| 011         | R3    | R3    | R3   |
| 100         | R4    | R4    | R4   |
| 101         | R5    | R5    | R5   |
| 110         | R6    | R6    | R6   |
| 111         | R7    | R7    | R7   |

ALU operations encoding

| OPR Select | Operation      | Symbol |
|------------|----------------|--------|
| 00000      | Transfer A     | TSFA   |
| 00001      | Increment A    | INCA   |
| 00010      | Add A + B      | ADD    |
| 00101      | Subtract A - B | SUB    |
| 00110      | Decrement A    | DECA   |
| 01000      | AND A and B    | AND    |
| 01010      | OR A and B     | OR     |
| 01100      | XOR A and B    | XOR    |
| 01110      | Complement A   | COMA   |
| 10000      | Shift right A  | SHRA   |
| 11000      | Shift left A   | SHLA   |

# MICRO-OPERATIONS AT ALU

|       |       |       |     |
|-------|-------|-------|-----|
| 3     | 3     | 3     | 5   |
| SEL A | SEL B | SEL D | OPR |

Control Word Format

| Micro-operation                | SEL A | SEL B | SEL D | OPR  | Control Word      |
|--------------------------------|-------|-------|-------|------|-------------------|
| $R1 \leftarrow R2 - R3$        | R2    | R3    | R1    | SUB  | 010 011 001 00101 |
| $R4 \leftarrow R4 \vee R5$     | R4    | R5    | R4    | OR   | 100 101 100 01010 |
| $R6 \leftarrow R6 + 1$         | R6    | -     | R6    | INCA | 110 000 110 00001 |
| $R7 \leftarrow R1$             | R1    | -     | R7    | TSFA | 001 000 111 00000 |
| Output $\leftarrow R2$         | R2    | -     | None  | TSFA | 010 000 000 00000 |
| Output $\leftarrow$ Input      | Input | -     | None  | TSFA | 000 000 000 00000 |
| $R4 \leftarrow \text{shl } R4$ | R4    | -     | R4    | SHLA | 100 000 100 11000 |
| $R5 \leftarrow 0$              | R5    | R5    | R5    | XOR  | 101 101 101 01100 |



## 2. STACK ORGANIZATION

## STACK ORGANIZATION

A stack is an ordered linear list in which all insertions and deletions are made at one end, called the top.

It uses the Last In First Out (LIFO) access method which is the most popular access method in most of the CPUs.

A **register is used to store the address** of the topmost element of the stack which is known as a **Stack Pointer(SP)** because its value always points at the top of the stack.

The main two operations that are performed on the operands of the stack are:

**Push Operation:** The operation of inserting an item onto a stack is called push operation.

**Pop Operation:** The operation of deleting an item onto a stack is called pop operation.



---

## STACK IN COMPUTER ARCHITECTURE

There are two types of stack organization that are used in computer architecture:

**Register stack:** It is built using a register.

**Memory stack:** It is the logical part of memory allocated as the stack. The logically partitioned part of RAM is used to implement the stack.

## REGISTER STACK ORGANIZATION

A stack can be organized as a collection of a finite number of memory words or **registers**.

In the figure, there are 64 registers used to make a register stack. The numbers 0,1,2,3,..... 63 denote the address of different registers (Binary address representation is 000000 ... 111111).

SP is a pointer that points to the top of the stack i.e. it currently points to the item at the top (in this figure SP contains a 6-bit address).

In a 64-word stack, the stack pointer contains 6 bits because  $2^6=64$ .

Since SP has only 6 bits, **it cannot exceed a number greater than 63(111111 in binary)**. When 63 is incremented by 1 the result is 0 since  $111111+1=1000000$ , but SP can accommodate only the six least significant bits → SP points to the 000000 address register which implies the stack is full.



# REGISTER STACK ORGANIZATION

The two more registers called **FULL** and **EMPTY** are used. These are made up of **flip-flops** also known as **flags**. It indicates whether the stack is full or not.

If **FULL** = 1, then **EMPTY** = 0 → stack is full.

If **FULL** = 0, then **EMPTY** = 1 → stack is empty.

**DR** is the **data register** through which data is transferred to and from the stack.

**Zero address** instructions are used in registers stack organization i.e. the instruction that does not contain the address of the operands.



# REGISTER STACK ORGANIZATION

## PUSH Operation

For the PUSH operation initially,

$SP \leftarrow 0$

$Full \leftarrow 0$

$EMTY \leftarrow 1$

$SP \leftarrow SP+1$   
pointer

Increment stack

$M[SP] \leftarrow DR$   
stack

Write on top of the

If ( $SP = 63$ ) then ( $FULL \leftarrow 1$ )  
Check if the stack is full

$EMTY \leftarrow 0$

Stack is not empty

## POP Operation

$DR \leftarrow M[SP]$   
stack

Read from the top of the

$SP \leftarrow SP-1$   
pointer

Decrement the stack

If ( $SP=0$ ) then ( $EMTY \leftarrow 1$ ) Check if the stack is empty

$FULL \leftarrow 0$  Stack is not full

# MEMORY STACK ORGANIZATION

A stack may be implemented in a computer's random access memory (RAM).

A stack is implemented in the CPU by allocating a portion of memory to a stack operation and utilizing a processor register as a stack pointer. The stack pointer is a CPU register that specifies the stack's initial memory address.

The RAM is divided into three logical parts:

Program: The logical part of RAM where programs are stored.

Data: It is the logical part of the RAM where data(operands) are stored.

Stack: It is the part of RAM used to implement stack.



# MEMORY STACK ORGANIZATION

## PUSH Operation

$SP \leftarrow SP - 1$   
pointer  
 $M[SP] \leftarrow DR$

Decrement stack  
Write on top of the stack

## POP Operation

$DR \leftarrow M[SP]$   
stack  
 $SP \leftarrow SP + 1$   
pointer

Read from the top of the stack  
Increment the stack

The upper limit register and lower limit register are used to check the stack's overflow (Full) and underflow (Empty).

Most computers do not provide hardware to check stack overflow (full stack) or underflow (empty stack). It must be done in the software

# REVERSE POLISH NOTATION

## Introduction

The stack organization is very effective in evaluating the arithmetic expression.

Computers found difficulties in evaluating common arithmetic mathematical expressions because they are represented in “Infix notation” (Eg. A+B\*C+D).

The Polish mathematician Lukasiewicz demonstrated that arithmetic expressions can be represented in prefix or postfix notations.

## Types of Notations

Infix notation (Eg. A+B)

Prefix notation or Polish notation (Eg. +AB)

Postfix notations or Reverse Polish Notation (Eg. AB+)

Used by general  
register  
organization

Used by stack  
organization

## REVERSE POLISH NOTATION

Reverse Polish notation (RPN) is a method for conveying mathematical expressions without the use of separators such as brackets and parentheses.

In this notation, the operators follow their operands, hence removing the need for the brackets to define evaluation priority.

The operation is read from left to right but execution is done every time an operator is reached.

This notation is suited for computers and calculators since there are fewer characters to track and fewer operations to execute.

Reverse Polish notation is also known as postfix notation

Example:

$(A+B)*(C*(D+E)+F)$

RPN is  $AB+CDE+*F+*$

# EVALUATION OF ARITHMETIC EXPRESSION

Let us consider an arithmetic expression:  $(3*4) + (5*6)$ .

In Reverse Polish Notation:  $34*56*+$

## Rules

In RPN, the numbers and operators are listed one after another, and an operator always acts on the most recent number in the list.

The numbers can be thought of as forming a stack, and the most recent number goes on the top of the stack.

An operator takes the appropriate number of arguments from the top of the stack and replaces them with the result of the operation.

# EVALUATION OF ARITHMETIC EXPRESSION

Let us consider an arithmetic expression:  $(3*4) + (5*6)$ .

In Reverse Polish Notation: 34\*56\*+

Stack representation



# PROCESSOR ORGANIZATION

In general, most processors are organized in one of three ways:

Single register (Accumulator) organization

Basic Computer is a good example

Accumulator is the only general-purpose register

General register organization

Used by most modern computer processors

Any of the registers can be used as the source or destination for computer operations

Stack organization

All operations are done using the hardware stack

For example, an OR instruction will pop the two top elements from the stack, do a logical OR on them, and push the result on the stack



### **3. INSTRUCTION FORMAT**

## INSTRUCTION FORMAT

In computer architecture, the **instruction format** is defined as a standard machine instruction format that can be directly decoded and executed by the central processing unit ( CPU ).

The instruction format is simply a sequence of bits ( binary 0 or 1 ) contained in a machine instruction that defines the layout of the instruction.

The machine instruction contains the number of bits (patterns of 0 and 1 ). These bits are grouped together and called fields.

Each field of the machine instruction provides specific information to the CPU regarding the operation to be performed and the location of the data.

An instruction is of various lengths depending upon the number of addresses it contains. Generally, CPU organizations are of three types on the basis of the number of address fields:

1. Single Accumulator organization
2. General register organization`
3. Stack organization

# CPU ORGANIZATION

## 1. Single Accumulator Organization

All the operations on a system are performed with an implied accumulator register. The instruction format in this type of computer uses one address field.

For example, the instruction for arithmetic addition is defined by an assembly language instruction ‘ADD.’ Where X is the operand’s address, the ADD instruction results in the operation.

$$AC \leftarrow AC + M[X].$$

AC is the accumulator register, and M[X] symbolizes the memory word located at address X.

# CPU ORGANIZATION

## 2. General Register Organization

The general register type computers employ two or three address fields in their instruction format. Each address field specifies a processor register or a memory.

An instruction symbolized by ADD R1, X specifies the operation  $R1 \leftarrow R1 + M[X]$ .

This instruction has two address fields: register R1 and memory address X.

# CPU ORGANIZATION

## 3. Stack Organization

A computer with a stack organization has PUSH and POP instructions that require an address field. Hence, the instruction PUSH X pushes the word at address X to the top of the stack. The stack pointer updates automatically.

In stack-organized computers, the operation type instructions don't require an address field as the operation is performed on the two items on the top of the stack.

# INSTRUCTION FORMAT REPRESENTATION

Instruction format is a sequence of bits contained int the machine instruction that defines the layout of an instruction.



---

## INSTRUCTION FORMAT TYPE

The set of instructions that manages the operation codes is called the format of instruction. The design of bits in instruction is supported by the format of instruction.

The length of instruction is generally preserved in multiples of character, which is 8 bits. Depending upon the number of addresses, the format of instruction is of variable length.

**Types of instruction format include:**

1. Zero(0) Address Instruction format
2. One(1) Address Instruction format
3. Two(2) Address Instruction format
4. Three(3) Address Instruction format

# 1. ZERO (0) ADDRESS INSTRUCTION FORMAT

This instruction does not have an operand field, and the location of operands is implicitly represented.

The stack-organized computer system supports these instructions.

To evaluate the arithmetic expression, it is required to convert it into reverse Polish notation.

- Example: Consider the below operations, which show how  $X = (A + B) * (C + D)$  expression will be written for a stack-organized computer.

| MODE                  | OPCODE                             |
|-----------------------|------------------------------------|
| TOS: Top of the Stack |                                    |
| PUSH                  | A      TOS $\leftarrow A$          |
| PUSH                  | B      TOS $\leftarrow B$          |
| ADD                   | TOS $\leftarrow (A + B)$           |
| PUSH                  | C      TOS $\leftarrow C$          |
| PUSH                  | D      TOS $\leftarrow D$          |
| ADD                   | TOS $\leftarrow (C + D)$           |
| MUL                   | TOS $\leftarrow (C + D) * (A + B)$ |
| POP                   | X      M [X] $\leftarrow TOS$      |

## 2. ONE (1) ADDRESS INSTRUCTION FORMAT

The instruction format in which the instruction uses only one address field is called the one address instruction format.

In this type of instruction format, one operand is in the accumulator and the other is in the memory location

It has only one operand

It has two special instructions LOAD and STORE

Example: The program to evaluate  $X = (A + B) * (C + D)$  is as follows:

- LOAD: This is used to transfer the data to the accumulator.
- STORE: This is used to move the data from the accumulator to the memory.
  - $M[ ]$  is any memory location.
  - $M[T]$  addresses a temporary memory location for storing the intermediate result.

| MODE | OPCODE | OPERAND |
|------|--------|---------|
|------|--------|---------|

|       |   |                           |
|-------|---|---------------------------|
| LOAD  | A | $AC \leftarrow M[A]$      |
| ADD   | B | $AC \leftarrow AC + M[B]$ |
| STORE | T | $M[T] \leftarrow AC$      |
| LOAD  | C | $AC \leftarrow M[C]$      |
| ADD   | D | $AC \leftarrow AC + M[D]$ |
| MUL   | T | $AC \leftarrow AC * M[T]$ |
| STORE | X | $M[X] \leftarrow AC$      |

### 3. TWO (2) ADDRESS INSTRUCTION FORMAT

The instruction format in which the instruction uses only two address fields is called the two-address instruction format

This type of instruction format is the most commonly used instruction format

As in one address instruction format, the result is stored in the accumulator only, but in the two addresses instruction format the result can be stored in different locations

This type of instruction format has two operands

It requires shorter assembly language instructions

- Example: The program to evaluate  $X = (A + B) * (C + D)$  is as follows:
  - The MOV instruction transfers the operands to the memory from the processor registers. R1, R2 registers.

| MODE | OPCODE | OPERAND 1 | OPERAND 2 |
|------|--------|-----------|-----------|
|------|--------|-----------|-----------|

|     |        |                           |
|-----|--------|---------------------------|
| MOV | R1, A  | $R1 \leftarrow M[A]$      |
| ADD | R1, B  | $R1 \leftarrow R1 + M[B]$ |
| MOV | R2, C  | $R2 \leftarrow M[C]$      |
| ADD | R2, D  | $R2 \leftarrow R2 + M[D]$ |
| MUL | R1, R2 | $R1 \leftarrow R1 * R2$   |
| MOV | X, R1  | $M[X] \leftarrow R1$      |

## 4. THREE (3) ADDRESS INSTRUCTION FORMAT

The instruction format in which the instruction uses the three address fields is called the three-address instruction format.

The format of a three-address instruction requires three operand fields. These three fields can be either memory addresses or registers.

It requires shorter assembly language instructions

| MODE | OPCODE | OPERAND<br>1 | OPERAND<br>2 | OPERAND<br>3 |
|------|--------|--------------|--------------|--------------|
|------|--------|--------------|--------------|--------------|

- Example: The program to evaluate  $X = (A + B) * (C + D)$  is as follows:
  - Two processor registers, R1 and R2.
  - The symbol M [A] denotes the operand at memory address symbolized by A. The operand1 and operand2 contain the data or address that the CPU will operate. Operand 3 contains the result's address.

|     |           |                             |
|-----|-----------|-----------------------------|
| ADD | R1, A, B  | R1 $\leftarrow M[A] + M[B]$ |
| ADD | R2, C, D  | R2 $\leftarrow M[C] + M[D]$ |
| MUL | X, R1, R2 | M[X] $\leftarrow R1 * R2$   |



## 4. ADDRESSING MODES

## Review

\* Instruction :-



→ Perform  $OP^n \rightarrow$  Write Back

## Addressing modes

Q1  
1

### (a) Implied/Semantic Am :-

- \* Operand is available inside the OPcode.

Ex:



②

## Immediate AM:-

- \* The operand is available inside the instrn.

Ex:



$$\text{LOAD } \#1000 \equiv \text{LDI } 1000$$



$$\begin{aligned} & AC \leftarrow AC + 2000 \\ & AC \leftarrow 1000 + 2000 \end{aligned}$$

LOAD [1000] → Address of Operand

LDS [1000] → Immediate value

LOAD #1000

AC ← M[1000]

AC ← 2000

AC ← 1000

AC [1000]



3.

## Register Addressing mode :-

- \* Operands are available Inside the Registers
- L Register is Specified Inside the Inst?

Ex:-



MOV R<sub>1</sub>

$$R_1 \leftarrow [R] + [R_2]$$

$$R_1 \leftarrow 50 + 100$$



(3) RA

④

## Direct / Absolute Addressing

- \* Operands are available in main memory
- + the Address of Operand (EA) is given in the address part of Reg.

Ex:



EA = Address [Inst]

$Act - M[1000] \Rightarrow [Act 20]$



Ex:

ADD  $1000, 2000$   
 $s_1, D$   $s_2$

$$M[1000] \leftarrow \underline{M[1000]} + \underline{M[2000]}$$

$$M[1000] \leftarrow \underline{100} + \underline{200}$$

$$\boxed{M[1000] \leftarrow 300}$$



(5)

## Indirect AM :-

- a. Register Indirect AM
- b. Memory Indirect AM

### Register Indirect AM :-

- a.\* The Register Contains the address of the Operand & this Register is specified Inside the Instruction.

Ex:

LOAD  $\oplus R_1$

LOAD  $R_1$

$\Rightarrow$  Indirect AM

$R_{V1}$

1000

1 RA + 1 MA



Ex:

ADD

1000, @2000  
S1, S2, D

$m[m[2000]] \leftarrow$

(1)

$m[1000] + m[m[2000]]$

(1)

(2)

$100 + m[3000]$

$\leftarrow 100 + 200$

$m[3000]$

4 mA

100 1000  
3000 2000  
200 3000  
mm

S.b.

Memory Indirect AM:-

LOAD @ 1000

$m[m[1000]] \rightarrow AC$

1 mA



$m[2000] \rightarrow AC$

$100 \rightarrow AC$



6

## Auto Increment / Auto Decrement Address



$$\ast(a) = 10$$

$$\begin{aligned} a[0] &= 10 \\ \ast a &= a[0] \end{aligned}$$

$$*(a+1) = \underline{a[1]},$$

$$*(a+2) = \underline{a[2]}$$



$a[4][3]$

$a \rightarrow$  first row address

$$a = 1000$$

$$a+1 = 1012$$

$$a+2 = 1024$$

$$a+3 = 1036$$



$$Q = 1000$$

$$\begin{aligned} \alpha a &= 1000 \\ **a &= 1 \end{aligned}$$

# ADDRESSING MODES

The operation field of an instruction specifies the operation to be performed. This operation will be executed on some data which is stored in computer registers or the main memory.

Addressing modes define the rules and mechanisms by which the processor calculates the effective memory address or operand location for data operations.

The way any operand is selected during the program execution is dependent on the addressing mode of the instruction. The purpose of using addressing modes is as follows:

1. To give the programming versatility to the user.
2. To reduce the number of bits in addressing the field of instruction.

## Types of Addressing Modes

- 1 Implied/Implicit Addressing Modes
- 2 Immediate Addressing Modes
- 3 Register Direct Addressing Modes
- 4 Register Indirect Addressing Modes
- 5 Auto-Increment Addressing Modes
- 6 Auto-Decrement Addressing Modes
- 7 Direct Addressing Modes
- 8 Indirect Addressing Modes
- 9 Displacement Addressing Modes
- 10 Relative Addressing Modes
- 11 Indexed Addressing Modes
- 12 Base Register Addressing Modes
- 13 Stack Addressing Modes

1 Implied/Implicit Addressing Modes  
2 Immediate Addressing Modes

3 Register Direct Addressing Modes

4 Register Indirect Addressing Modes

5 Auto-Increment Addressing Modes

6 Auto-Decrement Addressing Modes

7 Direct Addressing Modes

8 Indirect Addressing Modes

9 Displacement Addressing Modes

10 Relative Addressing Modes

11 Indexed Addressing Modes

12 Base Register Addressing Modes

13 Stack Addressing Modes

## 1. Implied/Implicit Addressing Modes:

Address of the operands is specified implicitly in the definition of the instruction.

All registers, reference the instructions that use an accumulator, and Zero-address instructions in a stack-organized computer are implied addressing mode instructions.

$EA = AC$ , or  $EA = \text{Stack}[SP]$

Example: CMA, CLA, PUSH, POP, etc.

|             |
|-------------|
| Instruction |
| OPCODE      |

## 2. Immediate Addressing Modes

The operand is defined in the instruction itself which is used to perform a specified operation.

Instruction has an operand field instead of an address field.  
Help initialize registers to a constant value.

Example: ADD 8 will increment the value stored in the accumulator by 8.

|             |         |
|-------------|---------|
| Instruction |         |
| OPCODE      | OPERAND |

- 1 Implied/Implicit Addressing Modes
- 2 Immediate Addressing Modes
- 3 Register Direct Addressing Modes**
- 4 Register Indirect Addressing Modes
- 5 Auto-Increment Addressing Modes
- 6 Auto-Decrement Addressing Modes
- 7 Direct Addressing Modes
- 8 Indirect Addressing Modes
- 9 Displacement Addressing Modes
- 10 Relative Addressing Modes
- 11 Indexed Addressing Modes
- 12 Base Register Addressing Modes
- 13 Stack Addressing Modes

### 3. Register Direct Addressing Modes:

Address specified in the instruction is the register address.  
 Designated operand need to be in a register.  
 Shorter address than the memory address. Faster to acquire an operand than the memory addressing.  
 Saving address field in the instruction.  
 $EA = IR(R)$  ( $IR(R)$ : Register field of IR)



**Example: MOV R1, 35H**

### 4. Register Indirect Addressing Modes

The instruction defines a register in the CPU that stores the effective address of the operand in memory.  
 Only one reference to the memory is required to fetch the operand. The specified register contains the address of the operand instead of the operand.

**Example: MOV R1, [R2]**



1 Implied/Implicit Addressing Modes

2 Immediate Addressing Modes

3 Register Direct Addressing Modes

4 Register Indirect Addressing Modes

5 Auto-increment Addressing Modes

6 Auto-Decrement Addressing Modes

7 Direct Addressing Modes

8 Indirect Addressing Modes

9 Displacement Addressing Modes

10 Relative Addressing Modes

11 Indexed Addressing Modes

12 Base Register Addressing Modes

13 Stack Addressing Modes

## 5. Auto-Increment Addressing Modes:

When the address in the register is used to access memory, the value in the register is incremented by 1 automatically. It follows a post-increment approach.  
EA = content of the register

Example: EA = 178



## 6. Auto-Decrement Addressing Modes

When the address in the register is used to access memory, the value in the register is decremented by 1 automatically. It follows a pre-decrement approach.  
EA = content of the register

Example: EA = 399



INC  $A_1$

```
[for (i=0; i<n; i++)  
    a[i]++;]
```



⑧

Displacement Am :-



LOAD 1000, R<sub>1</sub>

$$EA = 1000 + [R_1]$$

EA = 1010



⑧ Relative Adr: / PC Relative Adr: -

I<sub>1</sub>: LOAD 17 1000

I<sub>2</sub>: ADD R<sub>1</sub> D<sub>2</sub> 1004 ← PC



$$EA = PC + 17$$

$$EA = 1004 + 17$$

EA = 1021



1 Implied/Implicit Addressing Modes

2 Immediate Addressing Modes

3 Register Direct Addressing Modes

4 Register Indirect Addressing Modes

5 Auto-Increment Addressing Modes

6 Auto-Decrement Addressing Modes

7 Direct Addressing Modes

8 Indirect Addressing Modes

9 Displacement Addressing Modes

10 Relative Addressing Modes

11 Indexed Addressing Modes

12 Base Register Addressing Modes

13 Stack Addressing Modes

## 7. Direct Addressing Modes:

The effective address of the operand resides in the address field of the instruction.

The operand resides in the memory, and the address field of the instruction gives its address.

One reference to the memory is required to fetch the operand.

Also known as absolute addressing mode.

**Example: ADD, [1000H]**

## 8. Indirect Addressing Modes

The address field of the instruction gives the address of the memory location that contains the effective address of the operand.

Two references to the memory are required to fetch the operand

This addressing mode slows down the execution as it requires multiple memory lookups to find the operand.

**Example: ADD [[1000H]]**



1 Implied/Implicit Addressing Modes

2 Immediate Addressing Modes

3 Register Direct Addressing Modes

4 Register Indirect Addressing Modes

5 Auto-Increment Addressing Modes

6 Auto-Decrement Addressing Modes

7 Direct Addressing Modes

8 Indirect Addressing Modes

9 Displacement Addressing Modes

10 Relative Addressing Modes

11 Indexed Addressing Modes

12 Base Register Addressing Modes

13 Stack Addressing Modes

## 9. Displacement Addressing Modes:

The displacement is added to the instruction's address part to obtain the effective address of the operand.

$EA = A + (R)$  Here, the address field holds two values, A: Base value R: displacement value.

Example:

MOV R1, [Address Field+09H]



## 10. Relative Addressing Modes

This mode is another version of the displacement address mode. The program counter's content is added to the instruction's address part to obtain the effective address.

$EA = A + (PC)$  Here, EA: Effective address, PC: program counter

Example: MOV R1, [PC + Address Field]

The instruction's address is usually a signed number



- 1 Implied/Implicit Addressing Modes
- 2 Immediate Addressing Modes
- 3 Register Direct Addressing Modes
- 4 Register Indirect Addressing Modes
- 5 Auto-increment Addressing Modes
- 6 Auto-Decrement Addressing Modes
- 7 Direct Addressing Modes
- 8 Indirect Addressing Modes
- 9 Displacement Addressing Modes
- 10 Relative Addressing Modes
- 11 Indexed Addressing Modes**
- 12 Base Register Addressing Modes**
- 13 Stack Addressing Modes

## 11. Indexed Addressing Modes:

The index register's content is added to the instruction's address to obtain the effective address.

$$EA = \text{content of index register (XI)} + \text{Instruction address part}$$

**Example: MOV R1, [XI + Address Field].**



## 12. Base Register Addressing Modes

This mode is another version of the displacement address mode. To obtain the effective address, the base register's content is added to the instruction's address.

$$EA = A + (R)$$

A: Instruction address,  
R: Pointer to the base address.

**Example: MOV R1, [BX + Address Field]**



10

Indexed A.M:-

1000 R<sub>i</sub>

LOAD R<sub>i+1</sub> 10

$$EA = R_i + 10$$

$$EA = 1000 + 10 = 1010$$



(ii)

Base Amo —

LOAD BR, 10



$$AC \leftarrow m [BR + 10]$$

$$AC \leftarrow m [2000 + 10]$$



- 1 Implied/Implicit Addressing Modes
- 2 Immediate Addressing Modes
- 3 Register Direct Addressing Modes
- 4 Register Indirect Addressing Modes
- 5 Auto-increment Addressing Modes
- 6 Auto-Decrement Addressing Modes
- 7 Direct Addressing Modes
- 8 Indirect Addressing Modes
- 9 Displacement Addressing Modes
- 10 Relative Addressing Modes
- 11 Indexed Addressing Modes
- 12 Base Register Addressing Modes
- 13 Stack Addressing Modes

### 13. Stack Addressing Modes:

In this mode, the operand is at the top of the stack.

For example: ADD, this instruction will POP the top two items from the stack, add them, and will then PUSH the result to the top of the stack.

It helps in reducing the number of bits in the instruction's addressing field.

It facilitates pointers, indexing of data, and counters for loop controls.

# APPLICATIONS OF ADDRESSING MODES

| Addressing Mode                                                  | Applications                                                                                           |
|------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| Immediate Addressing Mode                                        | Initialize the register to a constant value.                                                           |
| Direct Addressing Modes<br>Register Direct Addressing Mode       | Helps access static data and implement variables.                                                      |
| Indirect Addressing Modes<br>Register Indirect Addressing Mode   | Helps implement pointers and pass arrays as parameters.                                                |
| Relative Addressing Mode                                         | Helps in program relocation at runtime. And in changing the sequence of instructions during execution. |
| Index Addressing Mode                                            | Helps in the array and record implementation.                                                          |
| Base Register Addressing Mode                                    | Helps in writing relocatable code and handling recursive procedures.                                   |
| Auto-Increment Addressing Mode<br>Auto-Decrement Addressing Mode | Helps implements loops and stacks.                                                                     |

## ADVANTAGES OF ADDRESSING MODES

They improve **performance** by efficiently utilizing the **CPU cache** and reducing the **memory read latency**.

Addressing Modes are used for implementing **complex data structures in memory** as they provide mechanisms such **as indexing**.

Program sizes can be reduced drastically as the code can be compacted which allows faster execution of instructions.

Addressing modes give you the flexibility to use **different ways of specifying the address of operands** in your instructions.

# EXAMPLE: ADDRESSING MODES

To show the differences between the various modes, we will show the effect of the addressing modes on the instruction defined in Fig.

The two-word instruction at addresses 200 and 201 is a "load to AC" instruction with an address field equal to 500.

The first word of the instruction specifies the operation code and mode, and the second word specifies the address part.

PC has the value 200 for fetching this instruction. The content of processor register R1 is 400, and the content of an index register or base register XR is 100.

AC receives the operand after the instruction is executed. The figure lists a few pertinent addresses and shows the memory content at each of these addresses.

|            |
|------------|
| $PC = 200$ |
| $R1 = 400$ |
| $XR = 100$ |
| $AC$       |

| Address | Memory               |
|---------|----------------------|
| 200     | Load to AC      Mode |
| 201     | Address = 500        |
| 202     | Next instruction     |
| 399     | 450                  |
| 400     | 700                  |
| 500     | 800                  |
| 600     | 900                  |
| 702     | 325                  |
| 800     | 300                  |

# EXAMPLE: ADDRESSING MODES

| Addressing Mode                              | Instruction                 | Effective Address | Content of AC |
|----------------------------------------------|-----------------------------|-------------------|---------------|
| Immediate AM                                 | MOV A, 500                  |                   |               |
| Register AM                                  | MOV A, R1                   |                   |               |
| Register Indirect AM                         | MOV A, [R1]                 |                   |               |
| Auto-Increment AM                            | INR A, [R1]                 |                   |               |
| Auto-Decrement AM                            | DCR A, [R1]                 |                   |               |
| Direct AM                                    | MOV A, 500                  |                   |               |
| Indirect AM                                  | MOV A, [[500]]              |                   |               |
| Relative AM (EA=PC + Address Field)          | MOV A, [PC + Address Field] |                   |               |
| Base Register AM (EA=XR + Address Field)     | MOV A, [XR + Address Field] |                   |               |
| Indexed Register AM (EA=XR + Address Field/) | MOV A, [XR + Address Field] |                   |               |

PC = 200  
R1 = 400  
XR = 100  
AC

| Address | Memory            |
|---------|-------------------|
| 200     | Load to AC   Mode |
| 201     | Address = 500     |
| 202     | Next instruction  |
| 399     | 450               |
| 400     | 700               |
| 500     | 800               |
| 600     | 900               |
| 702     | 325               |
| 800     | 300               |

# EXAMPLE: ADDRESSING MODES

| Addressing Mode                              | Effective Address | Content of AC |
|----------------------------------------------|-------------------|---------------|
| Immediate AM                                 | 201               | 500           |
| Register AM                                  | --                | 400           |
| Register Indirect AM                         | 400               | 700           |
| Auto-Increment AM                            | 400               | 700           |
| Auto-Decrement AM                            | 399               | 450           |
| Direct AM                                    | 500               | 800           |
| Indirect AM                                  | 800               | 300           |
| Relative AM (EA=PC + Address Field)          | 702               | 325           |
| Base Register AM (EA=XR + Address Field/)    | 600               | 900           |
| Indexed Register AM (EA=XR + Address Field/) | 600               | 900           |

PC = 200  
R1 = 400  
XR = 100  
AC

| Address | Memory            |
|---------|-------------------|
| 200     | Load to AC   Mode |
| 201     | Address = 500     |
| 202     | Next instruction  |
| 399     | 450               |
| 400     | 700               |
| 500     | 800               |
| 600     | 900               |
| 702     | 325               |
| 800     | 300               |

# EXAMPLE: ADDRESSING MODES

Consider a 16-bit processor in which the following contents appear in main memory, starting at location 200:

The first part of the first instruction indicates that this instruction loads a value into an accumulator. The mode field specifies the addressing mode and, if appropriate a source register; assume that when used, the source register is R1, which has a value of 400. There is also a base register that contains the value 100. The value 500 in location 201 may be part of the address calculation. Assume that location 399 contains the value 999, location 400 contains a value 1000, and so on. Determine the effective address and operand to be loaded for the following address modes: Direct, Indirect, Immediate, Register Direct, and Register Indirect

|     |                  |      |
|-----|------------------|------|
| 200 | Load AC          | Mode |
| 201 | 500              |      |
| 202 | Next Instruction |      |

Figure 1: Three locations of main memory.

# EXAMPLE: ADDRESSING MODES

Base register, used as displacement has value = 100.  $R_1$  has value 400. memory location 399 has value 999, 400 has value 1000, ...,  $x$  has value  $x + 600$ .



Figure 2: EA and Operand Computation.

- i. Direct: EA=500, operand=1100
  - ii. Indirect: EA=1100, operand=1700
  - iii. Immediate: EA=201, operand=500
- v. Register: EA=Register  $R_1$ , operand=400
- vi. Register Indirect: EA=400, operand=1000

Inst<sup>n</sup>:



Instr<sup>n</sup> Cycle : Fetch Cycle, Execution Cycle

→ D → PO  
Decode Operand

Fetch

Inst<sup>n</sup> formats:



① Zero Address



② One "



③ Two "



④ Three "



CPV Org<sup>n</sup>: —

- ① Stack Org<sup>n</sup>: —
- ② Single Register (AC) Org<sup>2</sup>
- ③ General Registers Org<sup>n</sup>.

## Addressing modes

- 1 Effective Address / Address of operand
- ① Implicit Am
- ② Immediate Am
- ③ Register Am
- ④ Direct/Absolute Am
- opcode      + + +  
Ind Reg mem

- (5) Indirect Am
- (6) Auto Inc/Dec Am
- (7) Displacement Am
- (8) Relative Am
- (9) Indexed Am
- (10) Base Am

:



## 5. DATA TRANSFER AND MANIPULATION

# INTRODUCTION

**Opcode:** Operation codes are known as opcodes. The first component of an instruction, known as an opcode, instructs the computer on what task to carry out.

**Operand:** The second component of an instruction, known as an operand, instructs the computer where to locate or store the data or instructions.





---

# TYPES OF INSTRUCTIONS

There are certain basic operations included in every computer's instructions set. The computer instructions are classified into three categories:

1. Data Transfer Instructions
2. Data Manipulation Instructions
3. Program Control Instructions

# DATA TRANSFER INSTRUCTIONS

Data transfer instructions move data from one location to another, without changing the binary information content. They are also called **copy instructions**.

Typically the transfers are between **memory** and **processor registers**, between **processor registers** and **input and output registers**, and among the **processor registers themselves**.

| Name     | Mnemonic |
|----------|----------|
| Load     | LD       |
| Store    | ST       |
| Move     | MOV      |
| Exchange | XCH      |
| Input    | IN       |
| Output   | OUT      |
| Push     | PUSH     |
| Pop      | POP      |

## STORE:

Ex:

ST 1000

ST @1000

ST \$ 1000

AC  $\rightarrow$  M[1000]

AC  $\rightarrow$  M[M[1000]]

AC  $\rightarrow$  M[PCT+1000]

MOV

Ex:

MV

MV R<sub>1</sub> R<sub>2</sub>



# DATA TRANSFER INSTRUCTIONS

With different Addressing Modes: Eight addressing modes for Load instruction

| Mode              | Assembly Convention | Register Transfer                           |
|-------------------|---------------------|---------------------------------------------|
| Direct address    | LD ADR              | $AC \leftarrow M[ADR]$                      |
| Indirect address  | LD @ADR             | $AC \leftarrow M[M[ADR]]$                   |
| Relative address  | LD \$ADR            | $AC \leftarrow M[PC + ADR]$                 |
| Immediate operand | LD #NBR             | $AC \leftarrow NBR$                         |
| Index addressing  | LD ADR(X)           | $AC \leftarrow M[ADR + XR]$                 |
| Register          | LD R1               | $AC \leftarrow R1$                          |
| Register indirect | LD (R1)             | $AC \leftarrow M[R1]$                       |
| Autoincrement     | LD (R1)+            | $AC \leftarrow M[R1], R1 \leftarrow R1 + 1$ |
| Autodecrement     | LD -(R1)            | $R1 \leftarrow R1 - 1, AC \leftarrow M[R1]$ |

1.  $LD \ 1000 \sqrt{2} \text{ mA} \ AC \leftarrow M[1000] \sqrt{AC=2000}$

2.  $LD \ #1000 \sqrt{0} \text{ mA} \ AC \leftarrow 1000 \quad AC = 1000$

3.  $LD @1000 \rightarrow 2 \text{ mA} \ AC \leftarrow M[m[1000]]$   
+ immediate  
 $\Rightarrow AC \leftarrow M[2000]$

4.  $LD \$1000$   
 $\hookrightarrow$  Relative Address



Ex:  $\underline{I_1} = \underline{I_2} = \underline{3000}$   $\underline{LD} = \$1000$   $AC \leftarrow m[PC + 1000]$

$$PC = 3002$$

↳ Relative

$$AC \leftarrow m[PC + 1000]$$

$$\leftarrow m[3002 + 1000]$$

$$AC \leftarrow m[4002]$$

$$AC \leftarrow 30$$



Displacement Am:



$$EA = [R_1] + 10$$

$$EA = 1000 + 10 = 1010$$

$$AC \leftarrow m[R_1 + 10] \Rightarrow m[1010]$$

$$\cancel{AC \leftarrow m[1010]}$$

\* Relative Addr:



LD 10

$$EA = PC + Address$$



$$= 1000 + 10 = 1010$$

Ans  $m[1010]$  ✓

\* Indexed Addr —

LD  $R_i$  10

$$EA = R_i + 10$$



\* Base Addr

LD  $BR$  10

$$EA = [BR + 10]$$



Ex:

$$LD @1000$$

$$A \leftarrow m[m[1000]]$$

1mA

$$A \leftarrow m[2000]$$

[A \leftarrow 50] 1mA



Ex: LD 19 1002

Relative Address

1004 ← PC

$$EA = 1004 + 19 = \boxed{1023}$$

PC  
1004

Ex:

$$LD \underbrace{I}_{\checkmark} 1000 \Rightarrow \boxed{A \leftarrow 1000}$$

$$LD \underbrace{\#1000}_{\checkmark} \Rightarrow A \leftarrow 1000$$

Ex:



$LD (R_1) +$

$AC \leftarrow M[R_1]$

$AC \leftarrow M[1005]$

$R_1 \leftarrow R_1 + 1$

|     |      |
|-----|------|
| 10  | 1000 |
| 20  | 1004 |
| 30  | 1005 |
| 40  | 1006 |
| :   |      |
| 100 | 1006 |



Ex:

ADD @1000, R<sub>1</sub>

↓

Indirect  
AM

→ Register  
AM

(2)



1 MA

M[2000]

---

# DATA MANIPULATION INSTRUCTIONS

Data manipulation instructions are those instructions that manipulate or change the content of the data/registers/memory.

It performs operations on data and provides the computational capabilities of the Computer.

Data manipulation instructions can be categorized into three parts:

1. Arithmetic instruction
2. Logical and bit manipulation instructions
3. Shift instructions

# 1. ARITHMETIC INSTRUCTIONS

Arithmetic instructions include increment, decrement, add, subtract, multiply, divide, add with Carry, subtract with Borrow, and negate that is (2's) two's complement. If there's a negative number, it is considered as negate (so two's complement).

| Name                 | Mnemonic |
|----------------------|----------|
| Increment            | INC      |
| Decrement            | DEC      |
| Add                  | ADD      |
| Subtract             | SUB      |
| Multiply             | MUL      |
| Divide               | DIV      |
| Add with carry       | ADDC     |
| Subtract with borrow | SUBB     |

$\text{ADD } R_1 \quad R_2 \quad R_1 \leftarrow R_1 + R_2 \quad R_1$

$, D, S_1$

$S_2$

$\text{ADD} \quad \begin{array}{r} 1100 \\ 0101 \\ \hline 1100 \end{array}$

$\begin{array}{r} 1 \\ 00100110 \end{array}$

$R_1$

$\begin{array}{r} 0010 \\ 0110 \end{array}$

$\begin{array}{r} 1100 \\ 1010 \end{array}$

$R_2$

$\begin{array}{r} 0101 \\ 1100 \end{array}$

$CY$

$\begin{array}{r} 1 \end{array}$



$$A = \begin{array}{r} 1001\ 0011 \\ 0101\ 1011 \\ \hline 1110\ 1110 \end{array}$$

**C=0**

$$A = \begin{array}{r} 1011\ 0110 \\ 1001\ 0101 \\ \hline 0100\ 1011 \end{array}$$

**①**

+1

$$\begin{array}{r} \cancel{C4=1} \\ 0100\ 1100 \end{array}$$

## 2. LOGICAL AND BIT MANIPULATION INSTRUCTIONS

These logical instructions consider each operand bit individually and treat it as a Boolean variable.

Basically, logical instructions help perform binary operations on strings of bits stored in registers.

| Name              | Mnemonic |   |
|-------------------|----------|---|
| Clear             | CLR      | ✓ |
| Complement        | COM      | ✓ |
| AND               | AND      | ✓ |
| OR                | OR       | ✓ |
| Exclusive-OR      | XOR      | ✓ |
| Clear carry       | CLRC     | ✓ |
| Set Carry         | SETC     | ✓ |
| Complement Carry  | COMC     | ✓ |
| Enable Interrupt  | EI       | ✓ |
| Disable Interrupt | DI       |   |



$R_1 = 1100\ 1010$

① CLR  $R_1$



② Com  $R_1$



③ AND  $R_1$

AC ← AC AND  $A_1$

④ OR  $R_1$



⑤



$R_1 =$

$Ac =$

$Pc =$

$f_1 =$

$\vdots$

$\vdots$

$\vdots$

$\vdots$

$\vdots$

H1

$A_1 =$

$Ac$

$Pc =$

$R_1$

1011 0110

CLR  $R_1$

0000 0000

### 3. SHIFT INSTRUCTIONS

Shift instructions allow the bits of a memory byte or register to be shifted one-bit place to the right or the left.

There are basically two types of shift instructions – arithmetic and logical.

Arithmetic shifts consider the contents of the memory byte or register to be a signed number. So, when the shift is made, the number is arithmetically divided by two (right shift) or multiplied by two (left shift).

Logical shifts consider the contents of the register or memory byte to be just a bit pattern when the shift is made.

| Name                       | Mnemonic |
|----------------------------|----------|
| Logical Shift Right        | SHR      |
| Logical Shift Left         | SHL      |
| Arithmetic Shift Right     | SHRA ✓   |
| Arithmetic Shift Left      | SHLA ✓   |
| Rotate Right               | ROR ✓    |
| Rotate Left                | ROL ✓    |
| Rotate Right through carry | RORC ✓   |
| Rotate Left through carry  | ROLC ✓   |

Shift op<sup>n</sup>



\* Logical Shift:-

(a) Left (LSL):

LSL R<sub>1</sub>

Right (LSR)

LSR R<sub>1</sub>







Rotate without carry



Rotate with carry





## 6. PROGRAM CONTROL

# Program Execution Sequence

Sequential

Transfer of Control

PC → 1000       $f_1$   
↓  
PC → 1002       $f_2$   
↓  
PC → 1004       $f_3$   
↓  
PC → 1006       $f_4$   
↓  
PC → 1008       $f_5$   
↓  
PC → 1010       $f_6$   
↓  
..



if-else

loops

labels & goto

fun" call

$a = b + c;$

if ( $a > 10$ )

{ —

  | a--;

  |

else if ( $a == 10$ )

{ —

  | a++;

  |

else { —

  |

do    while {  
    while }

$a = b + c;$

$a = 10$

→ while(  $a > 0$  )  
    {

$a--;$

$c = a++;$

}

    doint( " " );

Label L<sub>i</sub>: printf("I am a label"); ↵



# PROGRAM CONTROL INSTRUCTIONS

Program control instructions modify or change the flow of a program.

It is the instruction that alters the sequence of the program's execution, which means it changes the value of the program counter, due to which the execution of the program changes.

Features:

These instructions cause a change in the sequence of the execution of the instruction.

This change can be through a condition or sometimes unconditional.

Flags represent the conditions.

Flag-Control Instructions.

Control Flow and the Jump Instructions include jumps, calls, returns, interrupts, and machine control instructions.

Subroutine and Subroutine-Handling Instructions.

Loop and Loop-Handling Instructions.

# Program Execution Sequence

Sequential

$\downarrow$

$\text{L1} : \text{PC} = 1000$

$\text{L2} : \text{PC} = 1002$

$\text{L3} : \text{PC} = 1004$

$\text{L4} : \text{PC} = 1006$

$\text{L5} : \text{PC} = 1008$

$\text{HLT} : \text{PC} = 1010$

Transfer of Control

$2000 \quad \text{L1} \quad \text{PC} = 2000$

$2002 \quad \text{L2} \quad \text{Jump} \quad \text{PC} = 2008$

$2004 \quad \text{L3}$

$2006 \quad \text{L4}$

$2008 \quad \text{L5} \quad \text{Jump} \quad \text{PC} = 2010$

$2010 \quad \text{L6}$





```
int main( )
```

```
{
```

```
int a,b,c;
```

```
a=10; b=20;
```

```
Swap(&a, &b);
```

```
printf("%d %d", a,b);
```

```
printf("%d", c=a+b);
```

```
return 0;
```

```
Void Swap (int *x, int *y)
```

```
{
```

```
: int temp;
```

```
: temp = *x;
```

```
: *x = *y;
```

```
: *y = temp;
```

```
}
```

Program

$I_1 \downarrow$   
 $I_2 \downarrow$   
 $I_3 \downarrow$   
 $I_4 \downarrow$   
 $I_5 \downarrow$   
 $I_6 \downarrow$

Program



# PROGRAM CONTROL INSTRUCTIONS



# Program Control Instruction

Conditional

Ex: JNZ, JZ, JC, JS

Unconditional

Ex: CALL

if ( $a > 10$ )  
  {  
    Jmp if Non-zero



else {  
   $z = q$



# PROGRAM CONTROL INSTRUCTIONS

| Program Control Instructions | Description                                                                                                                                                                                                                                                                                                                                                     |
|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Branch (BR)                  | Branches are conditional and are used to provide logic to the program and make it do different things. Branches require several bits in the machine code instruction for the condition so they have less bits to use for the location of the branch. That's why branches use a specified offset from the current program counter and can't go as far as a jump. |
| Skip (SKP)                   | Skip instructions is used to skip one(next) instruction. It can be conditional or unconditional. It does not need an address field. In the case of conditional skip instruction, the combination of conditional skip and an unconditional branch can be used as a replacement for the conditional branch.                                                       |
| Jump (JMP)                   | The jump instruction transfers the program sequence to the memory address given in the operand based on the specified flag.<br>For a larger distance.                                                                                                                                                                                                           |
| Compare (CMP)                | The Compare instruction performs a comparison via a subtraction, with difference not retained. CMP compares register sized values, with one exception.                                                                                                                                                                                                          |
| CALL and RETURN              | The CALL and RETURN instructions interrupt the flow of a program by passing control to an internal or external subroutine. An external subroutine is another program. The RETURN instruction returns control from a subroutine back to the calling program and optionally returns                                                                               |

SKP:

$I_1 - \frac{SKP}{I_2}$   
 $PC \rightarrow I_2 x$   
 $\curvearrowleft PC \rightarrow I_3$



$I_0$   
 $Z$



# STATUS BIT CONDITIONS/ FLAG, PROCESSOR STATUS WORD

To check different conditions for branching instructions like CMP (compare) or TEST can be used. Certain status bit conditions are set as a result of these operations.

|   |   |   |   |
|---|---|---|---|
| V | Z | S | C |
|---|---|---|---|

Status bits mean that the value will be either 0 or 1 as it is a bit. We have four status bits:

"V" stands for Overflow: based on certain bits, i.e., if extra bits are generated into our operation.

"Z" stands for Zero: If the output of the ALU(Arithmetic Logic Unit) is 0, then the Z flag is set to 1, otherwise, it is set to 0.

"S" stands for the Sign bit: If the number is positive, the Sign(S) flag is 0, and if the number is negative, the Sign flag is 1.

"C" stands for Carry: if the output of the ALU operation generates Carry, then C is set to 1, else C is set to 0.

# STATUS BIT CONDITIONS/ FLAG, PROCESSOR STATUS WORD



4 bit  $\rightarrow$  Nibble

Ex:



- {
- Zero Flag (Z) = 1
  - Sign flag (S) = 0
  - Overflow Flag (V) = 0
  - Carry flag (C) = 1
  - Auxiliary Carry (AC) = 1
  - Parity flag (P) = if # 1's are odd = 1
- }

# 1. CONDITIONAL BRANCH INSTRUCTIONS

A conditional branch instruction is basically used to examine the values that are stored in the condition code register to examine whether the specific condition exists and to branch if it does.

Each conditional branch instruction tests for a different combination of Status bits for a condition.

| Mnemonic                                   | Branch condition           | Tested condition |
|--------------------------------------------|----------------------------|------------------|
| BZ                                         | Branch if zero             | Z = 1            |
| BNZ                                        | Branch if not zero         | Z = 0            |
| BC                                         | Branch if carry            | C = 1            |
| BNC                                        | Branch if no carry         | C = 0            |
| BP                                         | Branch if plus             | S = 0            |
| BM                                         | Branch if minus            | S = 1            |
| BV                                         | Branch if overflow         | V = 1            |
| BNV                                        | Branch if no overflow      | V = 0            |
| <i>Unsigned compare conditions (A - B)</i> |                            |                  |
| BHI                                        | Branch if higher           | A > B            |
| BHE                                        | Branch if higher or equal  | A ≥ B            |
| BLO                                        | Branch if lower            | A < B            |
| BLOE                                       | Branch if lower or equal   | A ≤ B            |
| BE                                         | Branch if equal            | A = B            |
| BNE                                        | Branch if not equal        | A ≠ B            |
| <i>Signed compare conditions (A - B)</i>   |                            |                  |
| BGT                                        | Branch if greater than     | A > B            |
| BGE                                        | Branch if greater or equal | A ≥ B            |
| BLT                                        | Branch if less than        | A < B            |
| BLE                                        | Branch if less or equal    | A ≤ B            |
| BE                                         | Branch if equal            | A = B            |
| BNE                                        | Branch if not equal        | A ≠ B            |



## 2. SUBROUTINE CALL AND RETURN

Subroutine is a self-contained sequence of instructions that performs a given computational task.

It may be called many times at various points in the main program.

When called, branches to 1<sup>st</sup> line of the subroutine and at the end, returned to the main program.

Different names for the instruction that transfers program control to a subroutine

Call subroutine

Jump to subroutine

Branch to a subroutine

Branch and save the return address

# Program



---

## 2. SUBROUTINE CALL AND RETURN

Two Most Important Operations are Implied:

Branch to the beginning of the Subroutine - Same as the Branch or Conditional Branch.

Save the Return Address to get the address of the location in the Calling Program upon exit from the Subroutine

Locations for storing Return Address

Fixed Location in the subroutine (Memory)

Fixed Location in memory

In a processor Register

In memory stack - most efficient way

## 2. SUBROUTINE CALL AND RETURN

In Memory Stack



### 3. PROGRAM INTERRUPT

An interrupt is a signal emitted by a device attached to a computer or from a program within the computer.

An interrupt temporarily stops or terminates a service or a current process.

Types of Interrupts:

External interrupts

Internal interrupts

Software interrupts



Transfer Control Via Interrupts

### 3. PROGRAM INTERRUPT



### 3. INTERRUPT PROCEDURE

Step 1 – First device issues interrupt to CPU.

Step 2 – Then, the CPU finishes the execution of the current instruction.

Step 3 – CPU tests for pending interrupt requests. If there is one, it sends acknowledgment to the device which removes its interrupt signal.

Step 4 – CPU saves program status word onto the control stack.

Step 5 – CPU loads the location of the interrupt handler into the PC register

Step 6 – Save the contents of all registers from the control stack into memc

Step 7 – Find out the cause of interrupt, or interrupt type, or invokes appropriate routine.

Step 8 – Restore saved registers from the stack.

Step 9 – Restore the PC to dispatch the original process



**Instruction Cycle with Interrupts**



## 7. RISC, AND CISC

# REDUCED INSTRUCTION SET COMPUTER PROCESSOR (RISC)

RISC is a microprocessor architecture that uses a simple set of instructions that can be substantially modified.

It is designed to reduce the time it takes for instructions to execute by optimizing and reducing the number of instructions. It means that each instruction cycle has only one clock per cycle, and each cycle consists of three parameters: fetch, decode, and execute.

The RISC processor can also combine multiple complex instructions into a simple one. RISC chips require several transistors, making them less expensive to develop and reducing instruction execution time.



RISC Architecture

Examples of RISC processors are PowerPC, Microchip PIC, SUN's SPARC, RISC-V.

# FEATURES OF RISC PROCESSOR

RISC processors **use one clock per cycle (CPI)** to execute each instruction in a computer. Each CPI also comprises the methods for fetching, decoding, and executing computer instructions.

Multiple **registers in RISC processors** allow them to hold instructions, reply fast to the computer, and interact with computer memory as little as possible.

The RISC processors use the pipelining technique to execute multiple parts or stages of instructions to perform more efficiently.

RISC has a simple addressing mode and fixed instruction length for the pipeline execution.

It uses LOAD and STORE instructions to access the memory location.

# COMPLEX INSTRUCTION SET COMPUTER (CISC)

Intel developed the CISC processor.

It has an extensive collection of complex instructions that range from simple to very complex and specializes in the assembly language level, which takes a long time to execute the instructions.

CISC approaches reducing the number of instructions on each program and ignoring the number of cycles per instruction.

It emphasizes building complex instructions directly in the hardware because the hardware is always faster than the software.

CISC chips are relatively slower than RISC chips but use little instructions.



CISC Architecture

Examples of CISC processors are AMD, Intel x86, and the System/360.

---

## FEATURES OF CISC PROCESSOR

CISC may take longer than a single clock cycle to execute the code.

The length of the code is short, so it requires minimal RAM.

It provides more accessible programming in assembly language.

It focuses on creating instructions on hardware rather than software because they are faster to develop.

It comprises fewer registers and more addressing nodes, typically 5 to 20.

# DIFFERENCE BETWEEN RISC AND CISC

|    | RISC                                                                                                                  | CISC                                                                                                                                  |
|----|-----------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 1  | <b>Instructions of a fixed size</b>                                                                                   | Instructions of <b>variable size</b>                                                                                                  |
| 2  | Most instructions take <b>same time to fetch</b> .                                                                    | Instructions have <b>different fetching times</b> .                                                                                   |
| 3  | Instruction set <b>simple and small</b> .                                                                             | Instruction set <b>large and complex</b> .                                                                                            |
| 4  | <b>Less addressing modes</b> as most operations are register based.                                                   | <b>Complex addressing modes</b> as most operations are memory based.                                                                  |
| 5  | <b>Compiler design is simple</b>                                                                                      | <b>Compiler design is complex</b>                                                                                                     |
| 6  | <b>Total size of program is large</b> as many instructions are required to perform a task as instructions are simple. | <b>Total size of program is small</b> as few instructions are required to perform a task as instructions are complex & more powerful. |
| 7  | Instructions use a <b>fixed number of operands</b> .                                                                  | Instructions have <b>variable number of operands</b> .                                                                                |
| 8  | Ideal for processors performing a <b>dedicated operation</b> .                                                        | Ideal for processors performing a <b>verity of operations</b> .                                                                       |
| 9  | Since instructions are simple, they can be decoded by a <b>hardwired control unit</b> .                               | Since instructions are complex, they require a <b>Micro-programmed Control Unit</b> .                                                 |
| 10 | Execution speed is <b>faster</b> as most operations are register based.                                               | Execution speed is <b>slower</b> as most operations are memory based.                                                                 |
| 11 | As No. of cycles per instruction is fixed, it gives a <b>better degree of pipelining</b>                              | Since number of cycles per instruction varies, <b>pipelining has more bubbles</b> or stalls.                                          |
| 12 | E.g.: <b>ARM7, PIC 18</b> Microcontrollers.                                                                           | E.g.: Intel <b>8085, 8086</b> Microprocessors.                                                                                        |