#### Instruction set architecture

- •All instructions are 30-bit wide (but padded with 2 trailing zeroes)
- •Three instruction formats: R-type, I-type, and J-type
- •There are 32 general purpose registers that are 32-bit wide

#### **Instruction formats:**

### R-type Instructions:

| Opcode | Rs     | Rt     | Rd     | Reserved |
|--------|--------|--------|--------|----------|
| 4 bits | 5 bits | 5 bits | 5 bits | 11 bits  |

### **I-type Instructions:**

| Opcode | Rs     | Rt     | Immediate |
|--------|--------|--------|-----------|
| 4 bits | 5 bits | 5 bits | 16 bits   |

## **J-type Instructions:**

| Opcode | Address |
|--------|---------|
| 4 bits | 26 bits |

- •Op<sup>4</sup>: 4-bit opcode of the instruction
- •Rs<sup>5</sup>, Rt<sup>5</sup>, Rd<sup>5</sup>: 5-bit source and destination register numbers
- •Immediate<sup>16</sup>: 16-bit immediate constant or PC-relative offset
- •Address<sup>26</sup>: 26-bit target address of the jump instruction

•R-type instructions have a 11-bit reserved field that can be used for additional functionality.

## **Instruction Subset:**

| Instruction Meaning |                                     | Format           |      |                       |                 |                      |                        |
|---------------------|-------------------------------------|------------------|------|-----------------------|-----------------|----------------------|------------------------|
| add                 | <u>rd, rs, rt</u>                   | addition         | 0x00 | rs <sup>5</sup>       | rt <sup>5</sup> | rd <sup>5</sup>      | reserved <sup>11</sup> |
| sub                 | rd, rs, rt                          | subtraction      | 0x01 | rs <sup>5</sup>       | rt <sup>5</sup> | rd <sup>5</sup>      | reserved <sup>11</sup> |
| and                 | rd, rs, rt                          | bitwise and      | 0x02 | rs <sup>5</sup>       | rt⁵             | rd <sup>5</sup>      | reserved <sup>11</sup> |
| or                  | rd, rs, rt                          | bitwise or       | 0x03 | rs <sup>5</sup>       | rt <sup>5</sup> | rd <sup>5</sup>      | reserved <sup>11</sup> |
| xor                 | rd, rs, rt                          | exclusive or     | 0x04 | rs <sup>5</sup>       | rt <sup>5</sup> | rd <sup>5</sup>      | reserved <sup>11</sup> |
| slt                 | rd, rs, rt                          | set on less than | 0x05 | rs <sup>5</sup>       | rt <sup>5</sup> | rd <sup>5</sup>      | reserved <sup>11</sup> |
| addi                | rt, <u>rs</u> , imm <sup>16</sup>   | add immediate    | 0x06 | rs <sup>5</sup>       | rt <sup>5</sup> | Imm <sup>16</sup>    |                        |
| 6slti               | rt, <u>rs</u> , imm <sup>16</sup>   | slt immediate    | 0x07 | rs <sup>5</sup>       | rt <sup>5</sup> | Imm <sup>16</sup>    |                        |
| andi                | rt, <u>rs</u> , imm <sup>16</sup>   | and immediate    | 0x08 | rs <sup>5</sup>       | rt <sup>5</sup> | Imm <sup>16</sup>    |                        |
| ori                 | rt, <u>rs</u> , imm <sup>16</sup>   | or immediate     | 0x09 | rs <sup>5</sup>       | rt <sup>5</sup> | lmm <sup>16</sup>    |                        |
| xori                | rt, imm <sup>16</sup>               | xor immediate    | 0x0a | rs <sup>5</sup>       | rt <sup>5</sup> | lmm <sup>16</sup>    |                        |
| lw                  | rt, imm <sup>16</sup> ( <u>rs</u> ) | load word        | 0x0b | rs <sup>5</sup>       | rt <sup>5</sup> | lmm <sup>16</sup>    |                        |
| SW                  | rt, imm <sup>16</sup> ( <u>rs</u> ) | store word       | 0x0c | rs <sup>5</sup>       | rt <sup>5</sup> | lmm <sup>16</sup>    |                        |
| beq                 | rs, rt, offset16                    | branch if equal  | 0x0d | rs <sup>5</sup>       | rt <sup>5</sup> | offset <sup>16</sup> |                        |
| bne                 | rs, rt, offset16                    | branch not equal | 0x0e | rs <sup>5</sup>       | rt <sup>5</sup> | offset <sup>16</sup> |                        |
| j                   | address <sup>26</sup>               | jump             | 0x0f | Address <sup>26</sup> |                 |                      |                        |

## **Addressing Modes:**



## **Block Diagram:**



# Pipelining:

The pipeline consists of 5 stages: Instruction fetch, Instruction decode, execution, memory, write back.