

# CS & IT ENGINEERING

COMPUTER ORGANIZATION  
AND ARCHITECTURE



Instruction & Addressing  
Modes

Lecture No.- 02

By- Vishvadeep Gothi sir



# Recap of Previous Lecture



Topic

Instructions

Topic

Opcode

# Topics to be Covered



Topic

Multiple Instructions Support

Topic

Variable Length Instructions

Ans = 4

#Q. Consider a computer which supports only 2-address and 1-address instructions. Each instruction is of 6-bits and each address is of 2-bits. If there are 3 2-address instructions supported by the system then maximum number of 1-address instructions supported by system is?

2-add.

6-bits

| opcode | a.1 | a.2 |
|--------|-----|-----|
| 2      | 2   | 2   |

1-add.

6-bits

| opcode | a.1 |
|--------|-----|
| 4      | 2   |

$$\text{max opcodes} = 2^2 = 4 \quad (00, 01, 10, 11)$$

$$\frac{\text{used } 11}{\text{unused}} = 3 \quad (\text{assume: } 00, 01, 10)$$

2      2

1100  
1101  
1110  
1111

$$\text{max 1-add. instns} = 4$$

If any inst<sup>n</sup>s comes to CPU for execution



- should not be used as 2-add. inst<sup>n</sup>s

↓  
then only treated as 1-add. inst<sup>n</sup>

#Q. Consider a computer which supports only 2-address and 1-address instructions. Each instruction is of 6-bits and each address is of 2-bits. If there are 3 2-address instructions supported by the system then maximum number of 1-address instructions supported by system is?

In above instruction what is the range of number of 1-address instructions supported?

1 to 4

2-add.

| opcode | q.1/q.2 |   |
|--------|---------|---|
| 2      | 2       | 2 |

$$\text{max} = 2^2 = 4$$

$$\text{used} = 3$$

$$\text{unused} = 1$$

$$1 * 2^2 = 4$$

Ans.

1-add.

| opcode | q.1 |   |
|--------|-----|---|
| 4      | 2   | 2 |



2-add. instrns

unused  
opcodes

max 1-add.  
instrns

|   |   |
|---|---|
| 4 | 0 |
| 3 | 1 |
| 2 | 2 |
| 1 | 3 |
| 0 | 4 |

$$0 * 2^2 = 0$$

$$1 * 2^2 = 4$$

$$2 * 2^2 = 8$$

$$3 * 2^2 = 12$$

$$4 * 2^2 = 16$$

only 2-add.  
type instrn  
supported

only 1-add. type  
instrn supported

Ans = 2560

- #Q. Consider a system with 24-bit instructions and 9-bit addresses. If there are 59 2-address instructions then maximum how many 1-address instructions can be formulated in the system?



$$\text{max} = 2^6 = 64$$

$$\frac{\text{used}}{\text{unused}} = \frac{59}{5}$$



$$5 * 2^9 = 2560$$

$$\text{Ans} = \underline{\underline{8192}}$$

#Q. Consider a system with 32-bit instructions and 12-bit addresses. If there are 254 2-address instructions then maximum how many 1-address instructions can be formulated in the system?

2-add.

| 32     |     |     |
|--------|-----|-----|
| opcode | q.1 | q.2 |
| 8      | 12  | 12  |

1-add.

| 32      |     |
|---------|-----|
| 6Opcode | q.1 |
| 8       | 12  |

$$\max = 2^8 = 256$$

$$\frac{\max}{\text{used}} = \frac{256}{254}$$

$$\frac{\text{unused}}{\text{unused}} = \frac{2}{2}$$

$$2 * 2^{12} = 2^{13} = 8192$$

#Q. Consider a system with 32-bit instructions and 12-bit addresses. If there are 254 2-address instructions and 8150 1-address instructions then maximum how many 0-address instructions can be formulated?

$$\begin{array}{r} \text{max 1 add. instns} = 8192 \\ \text{used} = 8150 \\ \hline \text{unused} = 42 \end{array}$$



$$m = (64 - x) * 2^8$$

#Q. Consider a system which supports 3-address and 2-address instructions both. It has 30-bit instructions with 8-bit addresses. If there are 'x' 3-address instructions then maximum how many 2-address instructions can be formulated?



Ques) In prev. quest<sup>n</sup> if max 2-add inst<sup>n</sup>s are 2048,  
then  $x = \underline{56}$  ?.

Sol<sup>n</sup>

$$(64-x) 2^8 = 2048$$

$$64-x = 8$$

$$\boxed{x = 56}$$

Ans = 12

- #Q. Consider a system which supports 2-address and 1-address instructions both. It has 24-bit instructions with 10-bit addresses. If there are 4096 1-address instructions then maximum how many 2-address instructions can be formulated?



$$\max = 2^4 = 16$$

$$\frac{\text{used}}{\text{unused}} = \frac{x}{16-x}$$

$$(16-x) * 2^{10} = 4096$$

$$16-x = 4$$

$x = 12$

#Q. Consider a system with 16-bits instructions and 64 CPU registers. The System supported 2 types of instructions: Type-A and Type-B.

Type-A instructions have an opcode, one register operand and one immediate operand of 3-bits

Type-B instructions have an opcode, and 2 register operands.

If there are 10 Type-B instructions supported by the system then maximum how many Type-A Instructions supported by the system?

Ans = 48

Type - A



Type - B



Ans = 14

Reg = 6 bits

- #Q. A processor has 64 registers and uses 16-bit instruction format. It has two types of instructions: I-type and R-type. Each I-type instruction contains an opcode, a register name, and a 4-bit immediate value. Each R-type instruction contains an opcode and two register names. If there are 8 distinct I-type opcodes, then the maximum number of distinct R-type opcodes is \_\_\_\_?

I-type  $\xrightarrow{16}$ 

|        |      |      |
|--------|------|------|
| opcode | Reg. | I.v. |
|--------|------|------|

 $\xleftarrow{4} | \xleftarrow{1} | \xrightarrow{2}$ 

$$(16-x) * 2^2 = 8$$

$$\begin{array}{|l|} \hline 16 - x = 2 \\ \hline x = 14 \end{array}$$

R-type  $\xrightarrow{16}$ 

|        |       |       |
|--------|-------|-------|
| opcode | Reg.1 | Reg.2 |
|--------|-------|-------|

4 6 6

$$\frac{\text{max} = 2^4 = 16}{\text{used} = x}$$

$$\frac{\text{unused} = 16 - x}{}$$

#Q. A processor has 16 integer registers ( $R_0, R_1, \dots, R_{15}$ ) and 64 floating point registers ( $F_0, F_1, \dots, F_{63}$ ). It uses a 2-byte instruction format. There are four categories of instructions: Type-1, Type-2, Type-3, and Type 4. Type-1 category consists of four instructions, each with 3 integer register operands (3Rs). Type-2 category consists of eight instructions, each with 2 floating point register operands (2Fs). Type-3 category consists of fourteen instructions, each with one integer register operand and one floating point register operand (1R+1F). Type-4 category consists of N instructions, each with a floating-point register operand (1F).

The maximum value of N is \_\_\_\_ ?



#Q. Consider there are 3 types of instructions in system:

1. Register Operand instructions: One opcode and 2 registers
2. Memory Operand instructions: One opcode, 1 register and 1 memory address
3. Immediate Operand Instructions: One opcode, 1 register and 1 immediate operand

Number of registers = 64  $\rightarrow$  Reg. Number = 6 bits

Number of bits in immediate operand = 10-bits

Memory size = 512Mbytes (byte addressable)  $\Rightarrow$  mem. add. = 29 bits

Total Instructions:

1. Reg Operand type: 10  $\rightarrow$  Total = 26  $\Rightarrow$  opcode = 5 bits
2. Memory Operand type : 12
3. immediate Operand type : 4

Maximum and Minimum instruction length are? 40 , 17 bits Ans.

Reg. operand

| opcode |   | Reg.1 | Reg.2 |
|--------|---|-------|-------|
| 5      | 6 | 6     |       |

17 bits

Imm. operand

| opcode |   | Reg. | Imm. Operand |
|--------|---|------|--------------|
| 5      | 6 | 10   |              |

21 bits

mem. operand

| Opcode |   | Reg.1 | mem. add. |
|--------|---|-------|-----------|
| 5      | 6 | 29    |           |

40 bits

#Q. In a simplified computer the instructions are:

|                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |               |                                                                 |             |                                                                                                                                   |              |                                                              |              |                                                              |
|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-----------------------------------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|--------------|--------------------------------------------------------------|--------------|--------------------------------------------------------------|
| <i>Reg-mem<br/>based<br/>arch.</i> | <table border="1"> <tr> <td>OP <math>R_i, R_j</math></td><td>- Performs <math>R_i \text{ Op } R_j</math> and stores the result in <math>R_j</math></td></tr> <tr> <td>OP <math>m, R_i</math></td><td>- Performs <math>\text{val} \text{ Op } R_i</math> and stores the result in <math>R_i</math><br/><math>\text{val}</math> denotes the content of memory location <math>m</math></td></tr> <tr> <td>MOV <math>m, R_i</math></td><td>- Moves the content of memory location <math>m</math> to register <math>R_i</math></td></tr> <tr> <td>MOV <math>R_i, m</math></td><td>- Moves the content of register <math>R_i</math> to memory location <math>m</math></td></tr> </table> | OP $R_i, R_j$ | - Performs $R_i \text{ Op } R_j$ and stores the result in $R_j$ | OP $m, R_i$ | - Performs $\text{val} \text{ Op } R_i$ and stores the result in $R_i$<br>$\text{val}$ denotes the content of memory location $m$ | MOV $m, R_i$ | - Moves the content of memory location $m$ to register $R_i$ | MOV $R_i, m$ | - Moves the content of register $R_i$ to memory location $m$ |
| OP $R_i, R_j$                      | - Performs $R_i \text{ Op } R_j$ and stores the result in $R_j$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |               |                                                                 |             |                                                                                                                                   |              |                                                              |              |                                                              |
| OP $m, R_i$                        | - Performs $\text{val} \text{ Op } R_i$ and stores the result in $R_i$<br>$\text{val}$ denotes the content of memory location $m$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |               |                                                                 |             |                                                                                                                                   |              |                                                              |              |                                                              |
| MOV $m, R_i$                       | - Moves the content of memory location $m$ to register $R_i$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |               |                                                                 |             |                                                                                                                                   |              |                                                              |              |                                                              |
| MOV $R_i, m$                       | - Moves the content of register $R_i$ to memory location $m$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |               |                                                                 |             |                                                                                                                                   |              |                                                              |              |                                                              |
| <i>Reg. or mem. Reg.</i>           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |               |                                                                 |             |                                                                                                                                   |              |                                                              |              |                                                              |
| <i>ALU</i>                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |               |                                                                 |             |                                                                                                                                   |              |                                                              |              |                                                              |

The computer has only two registers and OP is either ADD or SUB. Consider the following basic block:

$$R1 \quad t1 = a + b$$

$$t2 = c + d$$

$$t3 = e - t2$$

$$R2 \quad t4 = t1 - t3$$

#Q. Assume that all operands are initially in memory. The final value of the computation should be in memory. What is the minimum number of MOV instructions in the code generated for this basic block?

|            |                         |
|------------|-------------------------|
| ✓MOV b, R1 | $R1 \leftarrow b$       |
| ADD a, R1  | $R1 \leftarrow a + R1$  |
| ✓MOV d, R2 | $R2 \leftarrow d$       |
| ADD C, R2  | $R2 \leftarrow C + R2$  |
| SUB e, R2  | $R2 \leftarrow e - R2$  |
| SUB R1, R2 | $R2 \leftarrow R1 - R2$ |
| ✓MOV R2, X | $X \leftarrow R2$       |

Ans = 3

Ans = 5

#Q. In a simplified computer the instructions are:

|                |                                                                                                                     |
|----------------|---------------------------------------------------------------------------------------------------------------------|
| $OP\ R_i, R_j$ | - Performs $R_i \text{ Op } R_j$ and stores the result in $R_i$                                                     |
| $OP\ R_i, m$   | - Performs $R_i \text{ Op } val$ and stores the result in $R_i$<br>$val$ denotes the content of memory location $m$ |
| $MOV\ m, R_i$  | - Moves the content of memory location $m$ to register $R_i$                                                        |
| $MOV\ R_i, m$  | - Moves the content of register $R_i$ to memory location $m$                                                        |

The computer has only two registers and OP is either ADD or SUB. Consider the following basic block:

$$R1\ t1 = a + b$$

$$t2 = c + d$$

$$R2\ t3 = e - t2$$

$$t4 = t1 - t3$$

#Q. Assume that all operands are initially in memory. The final value of the computation should be in memory. What is the minimum number of MOV instructions in the code generated for this basic block?

$$\checkmark R1 \leftarrow a$$

$t \Rightarrow \text{mem. location}$

$$R1 \leftarrow R1 + b$$

$$\checkmark R2 \leftarrow c$$

$$R2 \leftarrow R2 + d$$

$$\checkmark t \leftarrow R2$$

$$\checkmark R2 \leftarrow e$$

$$R2 \leftarrow R2 - t$$

$$R1 \leftarrow R1 - R2$$

$$\checkmark x \leftarrow R1$$



## Topic : Register Spill

If sufficient no. of registers are not available in CPU, and for a program an intermediate operand is moved out of register to memory for temporary basis.

[NAT]

Ans = 2



#Q. Consider a register-memory architecture system (2-address instructions). For this system the following intermediate code is going to be converted in machine code. Minimum how many registers are required in system so that the code can run without register spill?

Consider first operand is always the register operand and it's the destination for operation too.

$$\begin{aligned} t1 &= X + Y \\ R1 & \quad t2 = t1 - Z \\ R2 & \quad t3 = t1 + t2 \\ t4 &= M + t3 \end{aligned}$$

$$\begin{aligned} R1 &\leftarrow X \\ R1 &\leftarrow R1 + Y \\ R2 &\leftarrow R1 \\ R1 &\leftarrow R1 - Z \\ R2 &\leftarrow R2 + R1 \end{aligned}$$

Assume X, Y, Z and M are memory operands

$$\begin{aligned} R1 &\leftarrow M \\ R1 &\leftarrow R1 + R2 \end{aligned}$$

Ans = 3

#Q. Consider a register-based architecture system (2-address instructions). For this system the following intermediate code is going to be converted in machine code. Minimum how many registers are required in system so that the code can run without register spill?

Consider first operand is always the register operand and it's the destination for operation too.

$$t_1 = X + Y$$

$$R_1 \leftarrow t_2 = t_1 - Z$$

$$R_2 \leftarrow t_3 = t_1 + t_2$$

$$t_4 = M + t_3$$

Assume X, Y, Z and M are memory operands

$$\begin{aligned} R_1 &\leftarrow X \\ R_2 &\leftarrow Y \\ R_1 &\leftarrow R_1 + R_2 \\ R_2 &\leftarrow R_1 \\ R_3 &\leftarrow Z \end{aligned}$$

$$R_1 \leftarrow R_1 + R_2$$

$$\begin{aligned} R_1 &\leftarrow R_1 - R_3 \\ R_2 &\leftarrow R_2 + R_1 \\ R_1 &\leftarrow M \end{aligned}$$



## 2 mins Summary



**Topic**

**Multiple Instructions Support**

**Topic**

**Variable Length Instructions**

Sat - 3 ⇒ 11 am - 1 PM



# Happy Learning

## THANK - YOU