

# CS & IT ENGINEERING

COMPUTER ORGANIZATION  
AND ARCHITECTURE



Instruction & Addressing  
Modes

Lecture No.- 01

By- Vishvadeep Gothi sir



# Recap of Previous Lecture



Topic

Micro operations

# Topics to be Covered



| Topic | Instructions     | $x * 2$                   |
|-------|------------------|---------------------------|
| Topic | Opcode           | one time left shift       |
|       | $(11)_2 = 3$     |                           |
|       | $(110)_2 = 6$    | $* 8$                     |
|       | $(1100)_2 = 12$  | <i>3 times left shift</i> |
|       | $(11000)_2 = 24$ |                           |

#Q. Consider the given C-code and its corresponding assembly code, with a few operands U1-U4 being unknown. Some useful information as well as the semantics of each unique assembly instruction is annotated as inline comments in the code. The memory is byte-addressable.  $r_1 = \phi_1$

//C-code

```
int a[10], b[10], i;
// int is 32-bit → uβ
for (i=0; i<10; i++)
    a[i] = b[i] * 8;
```

$$a[0] = b[0] * 8$$

$$a[1] = b[1] * 8$$

$$\vdots$$

;assembly-code (; indicates comments)

;r1-r5 are 32-bit integer registers

;initialize r1=0, r2=10

;initialize r3, r4 with base address of a, b

L01: jeq r1, r2, end ;if(r1==r2) goto end

L02: lw r5, 0(r4) ;r5 <- Memory[r4+0]

L03: shl r5, r5, U1 ;r5 <- r5 << U1<sup>3</sup>

L04: sw r5, 0(r3) ;Memory[r3+0] <- r5

L05: add r3, r3, U2 ;r3 <- r3+U2<sup>4</sup>

L06: add r4, r4, U3<sup>4</sup>

L07: add r1, r1, 1

L08: jmp U4 ;goto U4

L09: end

$$r_3 = a + 4$$

$$r_4 = b + 4$$

$$r_5 = b[0] * 8$$



Which of the following options is a correct replacement for operands in the position (U1, U2, U3, U4) in the above assembly code?

- A (8, 4, 1, L02)
- B (3, 4, 4, L01)
- C (8, 1, 1, L02)
- D (3, 1, 1, L01)





## Topic : Digital Computer





## Topic : Instruction



```
#include<stdio.h>

void main()
{
    int a, b, c;
    printf("Enter 2 values: ");
    scanf("%d %d", &a, &b);
    c = a + b;
    printf("Sum = %d", c);
}
```



## Topic : Instruction

High level lang.

```
#include<stdio.h>
```

```
void main()
{
    int a, b, c;
```

```
    printf("Enter 2 values: ");
    scanf("%d %d", &a, &b);
    c = a + b;
    printf("Sum = %d", c);
}
```

Programming  
stmt's

(Compiler)

Language Translation

Instructions

Low level lang. lang.  
(machine code or  
binary code  
or  
byte code  
or  
object code)

|          |
|----------|
| 10111000 |
| 10000001 |
| 11110010 |
| 01010101 |
| 11110110 |
| 01010101 |
| 10001111 |
| 10100011 |
| 00111101 |



## Topic : Instruction



A group of bits which instructs computer to perform some operation

|                                    |                 |
|------------------------------------|-----------------|
| operation<br>code<br>or<br>op code | operands info^n |
|------------------------------------|-----------------|

000  $\Rightarrow$  ADD

001  $\Rightarrow$  SUB

010  $\Rightarrow$  complement

.

111  $\Rightarrow$  \_\_\_\_\_

{ no. of distinct operations CPU can  
perform = 8

instn opcode = 3 bits

no. of distinct instns supported by  
CPU.



## Topic : Instruction

no. of <sup>distinct</sup> inst<sup>n</sup>s supported by CPU = n

$$\text{opcode} = \lceil \log_2 n \rceil \text{ bits}$$



Topic : ISA → inst<sup>n</sup> set architecture

→ Collection of all inst<sup>n</sup>s supported by a CPU.

size of ISA  
or  
size of inst<sup>n</sup> set } ⇒ no. of distinct inst<sup>n</sup>s supported by a CPU.

#Q.

Q.28

Which of the following is/are part of an Instruction Set Architecture of a processor?

- (A)  The size of the cache memory
- (B)  The clock frequency of the processor
- (C)  The number of cache memory levels
- (D)  The total number of registers



## Topic : Types of Instruction

- 3-Address Instruction:
- 2-Address Instruction:
- 1-Address Instruction:
- 0-Address Instruction:





## Topic : 3-Address Instruction

Max 3 addresses can be specified within an instruction for operands

| Opcode | Add 1 | Add 2 | Add 3 |
|--------|-------|-------|-------|
|--------|-------|-------|-------|

ex:-      10101    11    10    01  
          ↓    ↓    ↓    ↓  
ADD      R3, R2, R1

$$\underline{R3 \leftarrow R2 + R1} \text{ or } R3 + R2 \rightarrow R1$$



## Topic : 2-Address Instruction



Max 2 addresses can be specified within an instruction

| opcode | add. <sub>1</sub> | add. <sub>2</sub> |
|--------|-------------------|-------------------|
|--------|-------------------|-------------------|

10101    11    10  
↓            ↓            ↓  
ADD    R3, R2

$$R3 \leftarrow \underline{R3 + R2} \quad \text{or} \quad R3 + R2 \rightarrow R2$$

default



## Topic : 1-Address Instruction

Max 1 address can be specified within an instruction



10101      11  
↓            ↓  
ADD      R3  
↓

AC-based  
arch.

$AC \leftarrow AC + R3$





## Topic : 0-Address Instruction



No any address can be specified within an instruction

opcode

#Q. Consider a digital computer which supports only 2-address instructions each with 14-bits. If address length is 5-bits then maximum and minimum how many instructions the system can support?

2-add. Instns



$$\begin{aligned} &= 14 - (5 + 5) \\ &= 4 \text{ bits} \end{aligned}$$

max no. of instns supported =  $2^4 = 16$

min = 1

#Q. Consider a digital computer which supports only 3-address instructions each with 32-bits. If address length is 8-bits then maximum and minimum how many instructions the system can support?

3-add. instrs



#Q. Consider a digital computer which supports 64 2-address instructions. If address length is 9-bits then the length of the instruction is 24 bits?

$$\text{no. of instns supported} = 64 \Rightarrow \text{opcode} = 6 \text{ bits}$$

2-add. instns



#Q. Consider a digital computer which supports 64 2-address instructions. If address length is 9-bits then the length of the instruction is 24 bits?

In above question: Each instruction must be stored in memory in a byte-aligned fashion. If a program has 200 instructions, then amount of memory required to store the program text is \_\_\_\_ bytes?



#Q. Consider a digital computer which supports 32 2-address instructions. Consider the address length is 8-bits. Each instruction must be stored in memory in a byte-aligned fashion. If a program has 300 instructions, then amount of memory required to store the program text is 900 bytes?

21 bit but for storing instruction it will require 3 byte as new instruction can't be started from previous byte it requires new one.



opcode = 6 bits

Reg. number = 4 bits  
4 bit for nomenclature

- #Q. A processor has 50 distinct instructions and 16 general purpose registers. Each instruction in system has one opcode field, 2 register operand field and a 10 bits memory address field. The length of the instruction is 24 bits?



#Q. A processor has 20 distinct instructions and 32 general purpose registers. A 24 bits instruction word has an opcode, two register operands and an immediate operand. The number of bits available for the immediate operand field is 9?



#Q. A processor has 20 distinct instructions and 32 general purpose registers. A 24-bit instruction word has an opcode, two register operands and an immediate operand. The number of bits available for the immediate operand field is 9?

In above question: Assume that immediate operand field is an unsigned number, What is its maximum and minimum value possible?

$$\Rightarrow \max = 2^9 - 1 = 511$$

$$\min = 0$$

|           | min          | max               |
|-----------|--------------|-------------------|
| Unsigned  | 0            | $(2^n - 1)$       |
| sign mag. | $-(2^{n-1})$ | $+(2^{n-1} - 1)$  |
| 1's Comp  | $-2^{n-1}$   | $+ (2^{n-1} - 1)$ |
| 2's Comp. |              |                   |

byte addressable

#Q. Consider a system which supports only 3 address instructions only, and supports 256B memory. If the instruction size is 40-bits then maximum & minimum number of instruction supported by the system are?



16 bits

$$\max = 2^{16}$$

$$\min = 1$$

$$\text{no. of cells} = \frac{256 \text{ B}}{1 \text{ B}} = 256 = 2^8$$

add. = 8 bits

**True/False** $R1 \leftarrow R2 + M[2000]$  $R3 \leftarrow R4 + R5$ 

addition  $\Rightarrow$  Same opcode

Above two instructions treated as same type when counted into **Instruction set** architecture? *True*

opcode defines inst'n

**True/False**

False

32-bit architecture CPU has 1 word instruction, it means instruction size = 5B?

$$\downarrow \\ 32 \text{ bits} = 4B$$

**True/False**

False

X-bit architecture computer means the address bus width is x-bits?

*n° relation*



## 2 mins Summary



Topic

Instructions

Topic

Opcode



# Happy Learning

## THANK - YOU