

Ques 4 — gate - 2016

Consider a processor with 64 registers and an instruction set of size 12. Each instruction has five distinct fields, namely, Opcode, two source register identifiers, one destination register <sup>^</sup> must be stored in memory in a byte aligned fashion. If a program has 100 instruction, the amount of memory in (bytes) consumed by the program text is?

and a twelve bit immediate value each instruction

Sol: No of register = 64  $\rightarrow \log_2 64 = 6$ -bit (size)  
 Set of instruction size  $\rightarrow 12 \rightarrow \log_2 12 = 4$  bit  
 means number of instruction supported by the architecture  
 hence Opcode Size = 4bit

- Each instruction has five distinct field

| Opcode | Reg1 | Reg2 | Reg3 | immediate<br>instruction |
|--------|------|------|------|--------------------------|
| 4bit   | 6bit | 6bit | 6bit | 12bit                    |

- Instruction length = 34bit

- Each instruction must be stored in memory in a "byte" aligned fashion

$$1 \text{ byte} = 8 \text{ bit}$$

If a program has 100 instruction, the amount of memory consumed by program text.



$$\begin{aligned} & 5 \text{ byte for 1 instruction} \\ & 100 \text{ instruction} = 5 \times 100 = 500 \text{ bytes} \end{aligned}$$

Ans



### Multiple type Instruction

### Lecture - 8

- Instruction length



~~bytes~~

Ques: Consider a system which supports 2 add. and 1 add. both. The system has 6-bit instructions and 2 bit add. If there are three 2-add. instruction in the system, then maximum and minimum how many 1-add. instruction the system can support?

Sol: 2dd. instruction



1-add. instruction



- An instruction comes to CPU for ~~instruction~~ execution

011001

as 2dd. instruction

|    |    |    |
|----|----|----|
| 00 | 10 | 01 |
|----|----|----|

  
opcode Add1 Add2.

max opcodes  $\Rightarrow 2^3 = 8$   
(00, 01, 10, 11)

Used opcodes 3

assume: (00, 01, 11)

unused 1 opcode = (11)

min = 1  
Ans

ans 1 add instruction

|      |    |
|------|----|
| 0110 | 01 |
|------|----|

  
opcode add1.

max opcodes =  $2^4 = 16$

{ 1100 }

{ 1101 }

{ 1110 }

{ 1111 }

max = 9 Ans

## \* Method to solve these type of questions

- Make format first
- Start from min bit of opcode

2 dd.



$$\begin{aligned} \text{max opcode} &= 2^3 = 4 \\ \text{used} &= 3 \\ \text{unused} &= 1 \end{aligned}$$

1 add1



divide this Op code into  
2 half, 1st half  
is == bit taken  
by previous instruction

2 add. instn    unused    1 add1 inst  
              opcode

$$2 \cdot \underbrace{\downarrow}_{\text{remaining}} \times \underbrace{2^2}_{2} = 4$$

|   |   |                     |
|---|---|---------------------|
| 4 | 0 | $0 \times 2^2 = 0$  |
| 3 | 1 | $1 \times 2^2 = 4$  |
| 2 | 2 | $2 \times 2^2 = 8$  |
| 1 | 3 | $3 \times 2^2 = 12$ |
| 0 | 4 | $4 \times 2^2 = 16$ |

- only 2 dd.  
instruction  
Supported  
Combinations of  
opcode we can  
make

, only 1 add. instruction  
supported

Ques 3.2 Consider a system with 24 bit instruction and 9 bit addresses if there are 60, 2 address instruction, then maximum how many instructions can be found formulated in the system

Sol

2 add.



1 add.



max opcodes

$$2^6 = 64$$

$$\text{Used opcodes} = 60$$

$$\text{Unused} = 4$$

$$74 * 2^9 = 2048 \text{ Avg}$$

Ques 3

Consider a system with 32-bit instruction and 12-bit addresses. If ~~254~~ there are 254, 2 address instruction and 8000, 1 address instruction then minimum how many 0 address instruction can be formulated?

Sol

2 add.



1 add.



O - add.

$\leftarrow 32 \rightarrow$

[opcode]

4

4

4

2 dd.

add.

$$\text{max opcode} = 2^8 = 256$$

$$\text{used} = 254$$

$$\text{un used} = 2$$

$\longleftrightarrow$   
 $8 \dots 12$   
 $\downarrow$

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

O add. 32

[opcode]

$\leftarrow 20 \rightarrow 12$

$$192 * 2^{12} =$$

maximum 1 add. instruction = 8192

Used instruction = 8000  
unused = 192

maximum O add. instruction = 786,432

PW 4 gate 2020

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 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?

Page No. \_\_\_\_\_

64 register  $\rightarrow \log_2 64 \rightarrow 6$  bit size  
for reg  
16 bit instruction

I type instruction



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

$$(16 - n) * 4 = 8$$

$$16 - n = \frac{8}{4} 2$$

$$\underline{14 = n} \quad \underline{\cancel{n}}$$

R-type instruction



max opcodes  $= 2^4 = 16$   
 used "  $\geq n$   
 unused "  $\geq 16 - n$

\* How instructions are generated and executed? Lecture 9

- Compiler generates instructions based on CPU.

→ means only those type of instructions it will generate, what are supported by CPU.