### Team members:

- Mohammad Hosseini (4003613021) محمد حسيني
- Arshia Shafiei (4003623019) ارشیا شفیعی
- Behnood Oboodiyat (4003623027) بهنود عبودیت

### Instruction format(16-bit):

### R-type:

| Opcode(4-bit) | Rs(4-bit) | Rt(4-bit) Rd(4-bit) |                                |
|---------------|-----------|---------------------|--------------------------------|
| I-type:       |           |                     |                                |
| Opcode(4-bit) | Rs(4-bit) | Rt(4-bit)           | Imm/Address/Off<br>set (4-bit) |

# Instructions and Opcodes:

| Instruction | Op Code | format |
|-------------|---------|--------|
| add         | 0000    | R      |
| sub         | 0001    | R      |
| mul         | 0010    | R      |
| div         | 0011    | R      |
| ori         | 0100    | Ι      |
| nor         | 0101    | R      |
| nand        | 0110    | R      |
| sw          | 0111    | Ι      |
| lw          | 1000    | Ι      |
| blt         | 1001    | Ι      |

## Control Unit Truth Table:

|          | R-format | ori     | SW  | lw      | blt     |
|----------|----------|---------|-----|---------|---------|
| RegDst   | 1        | 0       | X   | 0       | X       |
| Alusrc   | 0        | 1       | 1   | 1       | 0       |
| MemToReg | 0        | 0       | X   | 1       | X       |
| RegWrite | 1        | 1       | 0   | 1       | 0       |
| MemWrite | 0        | 0       | 1   | 0       | 0       |
| Branch   | 0        | 0       | 0   | 0       | 1       |
| ExtOp    | X        | 0       | 1   | 1       | 0       |
| Aluctr   | Op[2:0]  | Op[2:0] | 000 | Op[2:0] | Op[2:0] |

add, sub, mul, div, nor and nand are the same but with different Opcodes.

### **Control Unit test results:**

| ist - Defa |    | /Controllinit th/Oncode /Controllinit th/Mambleite |
|------------|----|----------------------------------------------------|
| ps-y       |    | /ControlUnit_tb/Opcode/ControlUnit_tb/MemWrite     |
| delta⊸     |    |                                                    |
|            |    | /ControlUnit_tb/ALUsrc /ControlUnit_tb/Ext0p       |
|            |    | /ControlUnit_tb/MemtoReg_ /ControlUnit_tb/ALUctr_  |
|            |    | /ControlUnit_tb/RegWrite⊸                          |
| 0          | +0 | 0000 StX StX StX StX StX StX StX StX xxx           |
| 0          | +2 | 0000 St1 St0 St0 St1 St0 St0 St0 000               |
| 100        | +0 | 0001 St1 St0 St0 St1 St0 St0 St0 000               |
| 100        | +2 | 0001 St1 St0 St0 St1 St0 St0 St0 001               |
| 200        | +0 | 0010 St1 St0 St0 St1 St0 St0 St0 001               |
| 200        | +2 | 0010 St1 St0 St0 St1 St0 St0 St0 010               |
| 300        | +0 | 0011 St1 St0 St0 St1 St0 St0 St0 010               |
| 300        | +2 | 0011 St1 St0 St0 St1 St0 St0 St0 011               |
| 400        | +0 | 0101 St1 St0 St0 St1 St0 St0 St0 011               |
| 400        | +2 | 0101 St1 St0 St0 St1 St0 St0 St0 101               |
| 500        | +0 | 0110 St1 St0 St0 St1 St0 St0 St0 101               |
| 500        | +2 | 0110 St1 St0 St0 St1                               |
| 600        | +0 | 0100 St1 St0 St0 St1                               |
| 600        | +2 | 0100 St0 St1 St0 St1 St0 St0 St0 100               |
| 700        | +0 | 0111 St0 St1 St0 St1 St0 St0 St0 100               |
| 700        | +2 | 0111 St0 St1 St0 St0 St1 St0 St1 000               |
| 800        | +0 | 1000 St0 St1 St0 St0 St1 St0 St1 000               |
| 800        | +2 | 1000 St0 St1 St1 St1 St0 St0 St1 000               |
| 900        | +0 | 1001 St0 St1 St1 St1 St0 St0 St1 000               |
| 900        | +2 | 1001 St0 St0 St0 St0 St0 St1 St0 001               |
|            |    |                                                    |
|            |    |                                                    |

### **ALU** test results:

Adder and subtractor tests:



### Multiplier and Subtractor tests:



#### OR, NOR and NAND tests:

