## Instruction Types: RISUBJ

@R - (Register Type) -> Arithmetic / Logical operations on two registers. (0110011) (0x3)

OI (Improediate) -> One operand is a registers and another is an immediate (a constant) embedded in the instruction.

All arithmetic operations can be done with one register and one immediate operand.

Other than that, IW - load ward from memory Jalor - Jump and Jink oregister

© S (stone) → Taking a value from register and storing it at a memory address sh -> stone half ward (16 bit) (0100011) (0x 001 sw -> stone word (32 bit) 010

> ns1 > base address 252 -> holds value to be stared. for of babba tarteo from

fund 3-> store type (sb, sh, sw). opcod - identify as stare instruction.

imm | ns2 | ns1 | funct3 | imm | opende | 7 5 5 3 5 7

A-type farmat | funct 7 | rs2 | rs1 | funct 3 | rd | opcode |

fund 7 add June 3 0000000 000 } Sub 0100000 SIL 0 000006 001 402 0 10 SIta

011 KOR

100 SRL

0000000 101 SRA 010,0000

1001 ] OR 110 AND

11 1

Add 12 trailing zeroes. Fill the destination register with immediate. 2) aujec (0010111) Adds upper immediate to current program counter. per immediate to current project (get PC relative address for Jumps) @B-Type (Branch) (1100011) + Format |im[12] |imm[10:5] rs2 | rs1 | fanct3 | imm [4:1] | imm(i) | opcode | 7 imm → 13 bit signed offset, tell × 2, tells how far to Jump. bear 000 bne 001 1= 614 100 4 bge 101 >= bIta ( (u) 110 bgen 111 >= (u) O J- type- (1101111) (Jump) imon[20] | imon [10:1] | imon [19:12] | ord | opcode nt=p Jal > rd = PC+4//saves the next instruction. PC=pc+offret//Jamps

imm ord opcode.

O U type (upper)

i) lai (onom)

offset=[imm (]

```
Immediate codes
  1) For ALU: same funct 3 and funct 7, Just the opcode is 00 100 11 (0x 63)
  2) For Load types, opcode is 0000011 (0x03)
      (Similar to store types).
            16 000
             In 001
                  010
                   100
  3) For Jump (Jalon) opcode 1100111
                                      Junet 3 000.
  4) Envisionment calls. opcode (1110011)
[000...000] ecall 000 > They differ by immediate field.
```

Overall Same format | imm[11:0] | ns1 | funct3 | nd | apcode |

12 5 3 5 7

Control Unit (Main)

|            | Co rostor orul (Main) |                  |                      |
|------------|-----------------------|------------------|----------------------|
| (Edwa)     | opcode                | control signal - | temple and           |
| R-type     | 0110011 (33)          | 10000010         | ALUSTC.              |
| I(ALU)     | 0010011 (13)          | 11000011         | MemRead              |
| I (LOAD)   | 0000011 (03)          |                  | Mem Write            |
| I (TALR)   | 1100111 (67)          | 11101000         | Mem to Reg<br>Branch |
| I (System) | 1110011 (73)          | 11001000         | ALVOPZ               |
| S-type     | 0100011 (22)          | 6000 x000        | elet wh              |
| U (lai)    | 0100011 (23)          | 0101X000         | sgo (relat)          |
|            | 0110111 (37)          | La semb          | ogo sellos to        |
| U (auipc)  | 0010111 (27)          | 11000000         |                      |
| B-type     | 1100011 (63)          | 0000X101         |                      |
| J (JAL)    | 1101111 (6F)          |                  |                      |
|            | (01)                  | 18001000         |                      |

## Immediate Granevator

Ivs we use a 8+1 man. & 7+3 Rom I=000 5=001 B=010 U=011

ALU Control

Control Bits AWOP funct 3 funct 7

10 -> Naronal operations.

OR (001) XOR (0100) SLL (0101) SRL (0110)

ADD (0000)

SUB (000 1) AND (0010)

J=100

SRA(0111) SLT (1000)

SLTU(1001)