# Computer Organisation and Architecture Laboratory

# Specifications of Datapath and Control Unit

Group 51

Gayahtri Anant (22CS30026)

Vaasu Singla (22CS10078)

# Instructions

# R-type Instructions

| Opcode | rs     | rt     | rd     | don't care | funct  |
|--------|--------|--------|--------|------------|--------|
| 6 bits | 5 bits | 5 bits | 5 bits | 5 bits     | 6 bits |

| Instruction | Opcode | funct  | Instruction_no |
|-------------|--------|--------|----------------|
| ADD         | 000000 | 000000 | 0              |
| SUB         | 000000 | 000001 | 1              |
| AND         | 000000 | 000010 | 2              |
| OR          | 000000 | 000011 | 3              |
| XOR         | 000000 | 000100 | 4              |
| NOR         | 000000 | 000101 | 5              |
| NOT         | 000000 | 000110 | 6              |
| SL          | 000000 | 000111 | 7              |
| SRL         | 000000 | 001000 | 8              |
| SRA         | 000000 | 001001 | 9              |
| INC         | 000000 | 001010 | 10             |
| DEC         | 000000 | 001011 | 11             |
| SLT         | 000000 | 001100 | 12             |
| SGT         | 000000 | 001101 | 13             |
| HAM         | 000000 | 001111 | 15             |
| MOVE        | 000000 | 010000 | 16             |
| CMOVE       | 000000 | 010001 | 17             |

Note: rt = 0 for MOVE instruction

#### I-type instructions

| Opcode | rs     | rt     | imm1    |
|--------|--------|--------|---------|
| 6 bits | 5 bits | 5 bits | 16 bits |

| Instructions | Opcode | Instruction_no |
|--------------|--------|----------------|
| ADDI         | 110000 | 18             |
| SUBI         | 110001 | 19             |
| ANDI         | 110010 | 20             |
| ORI          | 110011 | 21             |
| XORI         | 110100 | 22             |
| NORI         | 110101 | 23             |
| NOTI         | 110110 | 24             |
| SLI          | 110111 | 25             |
| SRLI         | 111000 | 26             |
| SRAI         | 111001 | 27             |
| SLTI         | 111100 | 28             |
| SGTI         | 111101 | 29             |
| LUI          | 111110 | 30             |
| HAMI         | 111111 | 31             |
| LD           | 100000 | 32             |
| ST           | 100001 | 33             |
| ВМІ          | 100010 | 34             |
| BPL          | 100011 | 35             |
| BZ           | 100100 | 36             |

# J-type instructions

| Opcode | lmm2    |
|--------|---------|
| 6 bits | 26 bits |

| Instructions | Opcode | Instruction no |
|--------------|--------|----------------|
|--------------|--------|----------------|

| BR | 100101 | 37 |
|----|--------|----|
|    |        |    |

#### **No-Field instructions**

| Opcode | Unused  |
|--------|---------|
| 6 bits | 26 bits |

| Instructions | Opcode | Instruction no |
|--------------|--------|----------------|
| NOP          | 100110 | 38             |
| HALT         | 100111 | 39             |

# Datapath



# Controls

# R-type Instructions

| Instruction | T1                            | T2                                          | Т3                                                       | T4                   | T5                                   |
|-------------|-------------------------------|---------------------------------------------|----------------------------------------------------------|----------------------|--------------------------------------|
| ADD         | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>ReadReg2,<br>Load A, Load<br>B | ALUFunc =<br>ADD, MUX1 =<br>1, MUX2 = 1,<br>LoadALUOut   | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 0,<br>WriteReg |
| SUB         | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>ReadReg2,<br>Load A, Load<br>B | ALUFunc =<br>SUB, MUX1 =<br>1, MUX2 = 1,<br>LoadALUOut   | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 0,<br>WriteReg |
| AND         | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>ReadReg2,<br>Load A, Load<br>B | ALUFunc =<br>AND, MUX1 =<br>1, MUX2 = 1,<br>LoadALUOut   | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 0,<br>WriteReg |
| OR          | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>ReadReg2,<br>Load A, Load<br>B | ALUFunc =<br>OR, MUX1 =<br>1, MUX2 = 1,<br>LoadALUOut    | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 0,<br>WriteReg |
| XOR         | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>ReadReg2,<br>Load A, Load<br>B | ALUFunc =<br>XOR, MUX1 =<br>1, MUX2 = 1,<br>LoadALUOut   | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 0,<br>WriteReg |
| NOR         | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>ReadReg2,<br>Load A, Load<br>B | ALUFunc<br>=NOR, MUX1<br>= 1, MUX2 =<br>1,LoadALUOu<br>t | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 0,<br>WriteReg |
| NOT         | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>Load A                         | ALUFunc =<br>NOT, MUX1 =<br>1,<br>LoadALUOut             | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 0,<br>WriteReg |
| SL          | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>ReadReg2,<br>Load A, Load      | ALUFunc =<br>SL, MUX1 =<br>1, MUX2 = 1,                  | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 0,<br>WriteReg |

|     |                               | В                                           | LoadALUOut                                             |                      |                                      |
|-----|-------------------------------|---------------------------------------------|--------------------------------------------------------|----------------------|--------------------------------------|
| SRL | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>ReadReg2,<br>Load A, Load<br>B | ALUFunc =<br>SRL, MUX1 =<br>1, MUX2 = 1,<br>LoadALUOut | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 0,<br>WriteReg |
| SRA | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>ReadReg2,<br>Load A, Load<br>B | ALUFunc =<br>SRA, MUX1 =<br>1, MUX2 = 1,<br>LoadALUOut | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 0,<br>WriteReg |
| INC | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>Load A                         | ALUFunc =<br>INC, MUX1 =<br>1,<br>LoadALUOut           | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 2,<br>WriteReg |
| DEC | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>Load A, Load<br>B              | ALUFunc =<br>ADD, MUX1 =<br>1, MUX2 = 1,<br>LoadALUOut | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 2,<br>WriteReg |
| SLT | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>ReadReg2,<br>Load A, Load<br>B | ALUFunc =<br>ADD, MUX1 =<br>1, MUX2 = 1,<br>LoadALUOut | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 0,<br>WriteReg |
| SGT | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>ReadReg2,<br>Load A, Load<br>B | ALUFunc =<br>ADD, MUX1 =<br>1, MUX2 = 1,<br>LoadALUOut | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 0,<br>WriteReg |
| НАМ | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>ReadReg2,<br>Load A, Load<br>B | ALUFunc =<br>ADD, MUX1 =<br>1, MUX2 = 1,<br>LoadALUOut | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 0,<br>WriteReg |

| Instruction | T1      | T2           | Т3           | T4        | T5          |
|-------------|---------|--------------|--------------|-----------|-------------|
| MOVE        |         |              | ALUFunc =    |           |             |
|             | ReadIM, | ReadReg1,Lo  | ADD, MUX1 =  |           | MUXW = 1,   |
|             | LoadIR, | adlmm1, Load | 1, MUX2 = 0, | LoadPC,   | MUXDst = 0, |
|             | LoadNPC | A, MUXI=0    | LoadALUOut   | MUXPC = 0 | WriteReg    |

|      |         | ReadReg1, | ALUFunc =    |           |             |
|------|---------|-----------|--------------|-----------|-------------|
|      | ReadIM, | ReadReg2, | SLT, MUX1 =  |           | MUXW = 2,   |
|      | LoadIR, | Load A,   | 0, MUX2 = 0, | LoadPC,   | MUXDst = 0, |
| CMOV | LoadNPC | LoadB     | LoadALUOut   | MUXPC = 0 | WriteReg    |

# I-type Instructions

| Instruction | T1                            | T2                                         | Т3                                                        | T4                   | T5                                   |
|-------------|-------------------------------|--------------------------------------------|-----------------------------------------------------------|----------------------|--------------------------------------|
| ADDI        | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,Lo<br>adImm1, Load<br>A, MUXI = 0 | ALUFunc =<br>ADD, MUX1 =<br>1, MUX2 = 0,<br>LoadALUOut    | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 1,<br>WriteReg |
| SUBI        | ReadIM,<br>LoadIR,<br>LoadNPC | _                                          | ALUFunc =<br>SUB, MUX1 =<br>1, MUX2 = 0,<br>LoadALUOut    | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 1,<br>WriteReg |
| ANDI        | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,Lo<br>adImm1, Load<br>A, MUXI = 0 | ALUFunc =<br>AND, MUX1 =<br>1, MUX2 = 0,<br>LoadALUOut    | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 1,<br>WriteReg |
| ORI         | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,Lo<br>adImm1, Load<br>A, MUXI = 0 | ALUFunc =<br>OR, MUX1 =<br>1, MUX2 = 0,<br>LoadALUOut     | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 1,<br>WriteReg |
| XORI        | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,Lo<br>adImm1, Load<br>A, MUXI = 0 | ALUFunc =<br>XOR, MUX1 =<br>1, MUX2 = 0,<br>LoadALUOut    | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 1,<br>WriteReg |
| NORI        | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,Lo<br>adImm1, Load<br>A, MUXI = 0 | ALUFunc =<br>NOR, MUX1<br>= 1, MUX2 =<br>0,<br>LoadALUOut | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 1,<br>WriteReg |
| NOTI        | ReadIM,<br>LoadIR,<br>LoadNPC | LoadImm1,<br>MUXI = 0                      | ALUFunc =<br>NOT, MUX1 =<br>1, MUX2 = 0,<br>LoadALUOut    | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 1,<br>WriteReg |

| SLI  | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,Lo<br>adImm1, Load<br>A, MUXI = 0 | ALUFunc =<br>SL, MUX1 =<br>1, MUX2 = 0,<br>LoadALUOut     | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 1,<br>WriteReg |
|------|-------------------------------|--------------------------------------------|-----------------------------------------------------------|----------------------|--------------------------------------|
| SRLI | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,Lo<br>adImm1, Load<br>A, MUXI = 0 | ALUFunc =<br>SRL, MUX1 =<br>1, MUX2 = 0,<br>LoadALUOut    | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 1,<br>WriteReg |
| SRAI | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,Lo<br>adImm1, Load<br>A, MUXI = 0 | ALUFunc =<br>SRA, MUX1 =<br>1, MUX2 = 0,<br>LoadALUOut    | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 1,<br>WriteReg |
| SLTI | ReadIM,<br>LoadIR,<br>LoadNPC |                                            | ALUFunc =<br>SLT, MUX1 =<br>1, MUX2 = 0,<br>LoadALUOut    | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 1,<br>WriteReg |
| SGTI | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,Lo<br>adImm1, Load<br>A, MUXI = 0 | ALUFunc =<br>SGT, MUX1 =<br>1, MUX2 = 0,<br>LoadALUOut    | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 1,<br>WriteReg |
| НАМІ | ReadIM,<br>LoadIR,<br>LoadNPC | LoadImm1,<br>MUXI = 0                      | ALUFunc =<br>HAM, MUX1<br>= 1, MUX2 =<br>0,<br>LoadALUOut | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 1,<br>WriteReg |
| LUI  | ReadIM,<br>LoadIR,<br>LoadNPC | LoadImm1,<br>MUXI = 0                      | ALUFunc =<br>LUI, MUX1 =<br>1, MUX2 = 0,<br>LoadALUOut    | LoadPC,<br>MUXPC = 0 | MUXW = 1,<br>MUXDst = 1,<br>WriteReg |

| Instruction | T1      | T2        | Т3           | T4        | T5        |
|-------------|---------|-----------|--------------|-----------|-----------|
|             |         |           |              | LoadPC,   |           |
|             |         | ReadReg1, | ALUFunc =    | ReadDM,   |           |
|             | ReadIM, | LoadA,    | ADD, MUX1 =  | LoadLMD,  |           |
|             | LoadIR, | Loadlmm1, | 1, MUX2 = 0, | MUXD = 0, | MUXW = 0, |
| LD          | LoadNPC | MUXI = 0  | LoadALUOut   | MUXPC = 0 | WriteReg  |

| ST  | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>ReadReg2,<br>LoadA,<br>LoadB,<br>LoadImm1,<br>MUXI = 0 | ADD, MUX1 = 1, MUX2 = 0,                               | -                    |  |
|-----|-------------------------------|---------------------------------------------------------------------|--------------------------------------------------------|----------------------|--|
| ВМІ | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>LoadA,<br>LoadImm1,<br>MUXI = 0                        | ALUFunc =<br>ADD, MUX1 =<br>0, MUX2 = 0,<br>LoadALUOut | LoadPC,<br>MUXPC = 2 |  |
| BPL | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>LoadA,<br>LoadImm1,<br>MUXI = 0                        | ALUFunc =<br>ADD, MUX1 =<br>0, MUX2 = 0,<br>LoadALUOut | LoadPC,<br>MUXPC = 4 |  |
| BZ  | ReadIM,<br>LoadIR,<br>LoadNPC | ReadReg1,<br>LoadA,<br>LoadImm1,<br>MUXI = 0                        | ALUFunc =<br>ADD, MUX1 =<br>0, MUX2 = 0,<br>LoadALUOut | LoadPC,<br>MUXPC = 3 |  |

# J-type Instructions

| Instruction | T1      | T2        | Т3           | T4        | T5 |
|-------------|---------|-----------|--------------|-----------|----|
|             |         |           | ALUFunc =    |           |    |
|             | ReadIM, |           | ADD, MUX1 =  |           |    |
|             | LoadIR, | LoadImm2, | 0, MUX2 = 0, | LoadPC,   |    |
| BR          | LoadNPC | MUXI = 1  | LoadALUOut   | MUXPC = 1 |    |

# No Field type Instructions

| Instruction | T1                            | T2 | T3 | T4 | T5 |
|-------------|-------------------------------|----|----|----|----|
|             | ReadIM,<br>LoadIR,<br>LoadNPC |    |    |    |    |
|             | ReadIM,<br>LoadIR,<br>LoadNPC |    |    |    |    |

#### **Notes on Control Signals**

**MUXI:** 0 - lmm1

1 - Imm2

MUXDst: 0 - dst = rd

1 - dst = rt

2 - dst = rs

**MUX1:** 0 - NPC

1 - A

**MUX2:** 0 - Imm

1 - B

MUXD: 0 - ALUOut

1 - B

MUXW: 0 - LMD

1 - ALUOut

2 - Output of MUXMOVE

**MUXPC:** 0 - 0

1 - 1

2 - A < 0

3 - A = 0

4 - A > 0