# Computer Organization and Architecture Laboratory Assignment - 7

**Problem 2 - Control Unit and Data Path Specifications** 

**Group 47** 

**Anit Mangal (21CS10005)** 

**Omair Alam (21CS10047)** 

# **INSTRUCTIONS**

#### R TYPE

| OPCODE | rs     | rt     | rd     | Don't care | function |
|--------|--------|--------|--------|------------|----------|
| 4 bits | 5 bits | 5 bits | 5 bits | 8 bits     | 5 bits   |

| instruction | opcode | function |
|-------------|--------|----------|
| ADD         | 0000   | 00000    |
| SUB         | 0000   | 00001    |
| AND         | 0000   | 00010    |
| OR          | 0000   | 00011    |
| XOR         | 0000   | 00100    |
| NOT         | 0000   | 00101    |
| SLA         | 0000   | 00110    |
| SRA         | 0000   | 00111    |
| SRL         | 0000   | 01000    |
| MOVE        | 1101   | xxxxxx   |
| PUSH        | 1001   | xxxxxx   |
| POP         | 1010   | xxxxxx   |

#### <u>I TYPE - ALU</u>

| opcode | rs     | immediate | func   |
|--------|--------|-----------|--------|
| 4 bits | 5 bits | 18 bits   | 5 bits |

| instruction | opcode | function |
|-------------|--------|----------|
| ADDI        | 0000   | 01001    |
| SUBI        | 0000   | 01010    |
| ANDI        | 0000   | 01011    |
| ORI         | 0000   | 01100    |
| XORI        | 0000   | 01101    |
| NOTI        | 0000   | 01110    |
| SLAI        | 0000   | 01111    |
| SRAI        | 0000   | 10000    |
| SRLI        | 0000   | 10001    |

#### <u>I TYPE – 18</u>

| opcode | rs     | immediate | rd     |
|--------|--------|-----------|--------|
| 4 bits | 5 bits | 18 bits   | 5 bits |

| instruction | opcode | function |
|-------------|--------|----------|
| BMI         | 0110   | xxxxx    |
| BPL         | 0111   | xxxxx    |
| BZ          | 1000   | xxxxx    |
| LD          | 0001   | xxxxx    |
| ST          | 0010   | xxxxx    |
| LDSP        | 0011   | xxxxx    |
| STSP        | 0100   | xxxxx    |

#### <u>J TYPE</u>

| opcode | immediate |
|--------|-----------|
| 4 bits | 28 bits   |

| instruction | opcode | function |
|-------------|--------|----------|
| BR          | 101    | xxxxx    |
| CALL        | 1011   | xxxxx    |

#### NO-FIELD TYPE

| opcode | Don't care |
|--------|------------|
| 4 bits | 28 bits    |

| instruction | opcode | function |
|-------------|--------|----------|
| RET         | 1100   | xxxxx    |
| HALT        | 1110   | xxxxx    |
| NOP         | 1111   | xxxxx    |



#### **DATA DESIGN**



# **CONTROLS**

| S  |      |        |       |     |      |       |      |       |        |        | Reg | Reg  |     |       |       |     |      |      |       |      |
|----|------|--------|-------|-----|------|-------|------|-------|--------|--------|-----|------|-----|-------|-------|-----|------|------|-------|------|
| N  | орсо | functi | ACTIO | PC  |      | Instr | Read | Read2 | WriteR | Writel | Rea | Writ | lmm | ALUin | ALUO  | BrO | Data | Mem  | Mem   | HALT |
| 0  | de   | on     | N     | Sel | PCin | Read  | 1Sel | Sel   | egSel  | nfoSel | d   | е    | Sel | 2     | р     | р   | Sel  | Read | Write | Ctrl |
| 1  | 0000 | 00000  | ADD   | 0   | 1    | 1     | 0    | 1     | 2      | 0      | 1   | 1    | х   | 0     | 00000 | 0   | Х    | х    | х     | х    |
| 2  | 0000 | 00001  | SUB   | 0   | 1    | 1     | 0    | 1     | 2      | 0      | 1   | 1    | х   | 0     | 00001 | 0   | х    | х    | х     | х    |
| 3  | 0000 | 00010  | AND   | 0   | 1    | 1     | 0    | 1     | 2      | 0      | 1   | 1    | х   | 0     | 00010 | 0   | Х    | х    | х     | х    |
| 4  | 0000 | 00011  | OR    | 0   | 1    | 1     | 0    | 1     | 2      | 0      | 1   | 1    | х   | 0     | 00011 | 0   | x    | х    | х     | х    |
| 5  | 0000 | 00100  | XOR   | 0   | 1    | 1     | 0    | 1     | 2      | 0      | 1   | 1    | х   | 0     | 00100 | 0   | x    | х    | х     | х    |
| 6  | 0000 | 00101  | NOT   | 0   | 1    | 1     | 0    | 1     | 2      | 0      | 1   | 1    | х   | 0     | 00101 | 0   | х    | х    | х     | х    |
| 7  | 0000 | 00110  | SLA   | 0   | 1    | 1     | 0    | 1     | 2      | 0      | 1   | 1    | х   | 0     | 00110 | 0   | х    | х    | х     | х    |
| 8  | 0000 | 00111  | SRA   | 0   | 1    | 1     | 0    | 1     | 2      | 0      | 1   | 1    | х   | 0     | 00111 | 0   | х    | х    | х     | х    |
| 9  | 0000 | 01000  | SRL   | 0   | 1    | 1     | 0    | 1     | 2      | 0      | 1   | 1    | х   | 0     | 01000 | 0   | х    | х    | х     | х    |
| 10 | 0000 | 01001  | ADDI  | 0   | 1    | 1     | 0    | х     | 1      | 0      | 1   | 1    | 1   | 1     | 00000 | 0   | х    | х    | х     | х    |
| 11 | 0000 | 01010  | SUBI  | 0   | 1    | 1     | 0    | х     | 1      | 0      | 1   | 1    | 1   | 1     | 00001 | 0   | х    | х    | х     | х    |
| 12 | 0000 | 01011  | ANDI  | 0   | 1    | 1     | 0    | х     | 1      | 0      | 1   | 1    | 1   | 1     | 00010 | 0   | х    | х    | х     | х    |
| 13 | 0000 | 01100  | O RI  | 0   | 1    | 1     | 0    | х     | 1      | 0      | 1   | 1    | 1   | 1     | 00011 | 0   | х    | х    | х     | х    |
| 14 | 0000 | 01101  | XORI  | 0   | 1    | 1     | 0    | х     | 1      | 0      | 1   | 1    | 1   | 1     | 00100 | 0   | х    | х    | х     | х    |
| 15 | 0000 | 01110  | NOTI  | 0   | 1    | 1     | 0    | х     | 1      | 0      | 1   | 1    | 1   | 1     | 00101 | 0   | х    | х    | х     | х    |
| 16 | 0000 | 01111  | SLAI  | 0   | 1    | 1     | 0    | х     | 1      | 0      | 1   | 1    | 1   | 1     | 00110 | 0   | х    | х    | х     | х    |
| 17 | 0000 | 10000  | SRAI  | 0   | 1    | 1     | 0    | х     | 1      | 0      | 1   | 1    | 1   | 1     | 00111 | 0   | х    | х    | х     | х    |
| 18 | 0000 | 10001  | SRLI  | 0   | 1    | 1     | 0    | Х     | 1      | 0      | 1   | 1    | 1   | 1     | 01000 | 0   | x    | х    | х     | х    |
| 19 | 0001 | XXXXX  | LD    | 0   | 1    | 1     | 0    | Х     | 1      | 1      | 1   | 1    | 1   | 1     | 00000 | 0   | х    | 1    | 0     | х    |
| 20 | 0010 | XXXXX  | ST    | 0   | 1    | 1     | 0    | 2     | Х      | Х      | 1   | 0    | 1   | 1     | 00000 | 0   | 0    | 0    | 1     | х    |
| 21 | 0011 | XXXXX  | LDSP  | 0   | 1    | 1     | 0    | Х     | 1      | 1      | 1   | 1    | 1   | 1     | 00000 | 0   | х    | 1    | 0     | х    |
| 22 | 0100 | XXXXX  | STSP  | 0   | 1    | 1     | 1    | 2     | х      | Х      | 1   | 0    | 1   | 1     | 00000 | 0   | 0    | 0    | 1     | х    |
| 23 | 0101 | XXXXX  | BR    | 0   | 1    | 1     | Х    | Х     | х      | Х      | 0   | 0    | 0   | х     | 11111 | 1   | х    | 0    | 0     | х    |
| 24 | 0110 | XXXXX  | BMI   | 0   | 1    | 1     | 0    | 0     | х      | Х      | 1   | 0    | 1   | 0     | 00001 | 1   | Х    | 0    | 0     | Х    |
| 25 | 0111 | XXXXX  | BPL   | 0   | 1    | 1     | 0    | 0     | Х      | х      | 1   | 0    | 1   | 0     | 00000 | 1   | Х    | 0    | 0     | х    |
| 26 | 1000 | XXXXX  | BZ    | 0   | 1    | 1     | 0    | 0     | Х      | х      | 1   | 0    | 1   | 0     | 00100 | 1   | Х    | 0    | 0     | х    |
| 27 | 1001 | XXXXX  | PUSH  | 0   | 1    | 1     | 1    | 1     | Х      | х      | 1   | 0    | х   | 2     | 00001 | 0   | 0    | 0    | 1     | х    |
| 28 | 1010 | XXXXX  | POP   | 0   | 1    | 1     | 1    | 0     | 2      | 1      | 1   | 1    | х   | 0/2   | 00000 | 0   | Х    | 1    | 0     | х    |
| 29 | 1011 | XXXXX  | CALL  | 0   | 0/1  | 1     | 1    | х     | 0      | 0      | 1   | 2    | 0   | 2     | 00000 | 0/1 | 1    | 0    | 1     | х    |
| 30 | 1100 | XXXXX  | RET   | 1/0 | 1    | 1     | 1    | 0     | 0      | 0      | 1   | 1    | Х   | 0/2   | 00000 | Х   | Х    | 1    | 0     | х    |

| 31 | 1101 | XXXXX | MOVE | 0 | 1 | 1 | 0 | 0 | 2 | 0 | 1 | 1 | х | 0 | 00000 | 0 | Х | х | х | х |
|----|------|-------|------|---|---|---|---|---|---|---|---|---|---|---|-------|---|---|---|---|---|
| 32 | 1110 | XXXXX | HALT | Х | 0 | 1 | х | х | х | х | 0 | 0 | х | х | xxxxx | Х | x | 0 | 0 | 1 |
| 33 | 1111 | XXXXX | NOP  | 0 | 1 | 1 | Х | Х | Х | Х | 0 | 0 | Х | Х | xxxxx | 0 | Х | 0 | 0 | х |

PCSel - Controls whether value to be passed as PC is taken from {0} incrementing/decrementing current PC value or {1} a value from memory

PCin- Controls whether adjusted PC value is {1} passed to PC register or {0} not (disabled during steps in CALL)

InstrRead - Controls whether {1} pointed instruction is read or {0} not

Read 1 Sel - Controls Read Register 1, can either be {0}0-15 from first register operand, or {1}16 (for SP)

Read2Sel - Controls Read Register 2, can either be {0} constant 0, or 0-15 from second register operand {1} in bits [22:18] or {2} in bits [4:0]

WriteRegSel - Controls Write Register, can either be {0}a copy of Read Register 1, {1}1-15 from second register operand, or {2}1-15 from third register operand

WriteInfoSel - Controls Write Register's value, chooses between {0}ALU operation result or {1}data read from memory

RegRead - Controls whether to {1}allow Reading of Registers or {0}not

RegWrite - Controls whether to {1}allow Writing of Registers or {0}not

ImmSel - Controls which immediate value is selected ({0}28-bit or {1}18-bit)

ALUin2 - Controls whether ALU Operand 2 is {1}Read Register 2's value, {1}immediate value, or {2}constant 4

ALUOp - Chooses among different ALU operations ({0000}Addition, {00001}Subtraction, {00010}AND, {00011}OR, {00100}XOR, {00101}NOT, {00110}Left Arithmetic Shift, {00111}Right Arithmetic Shift, {01000}Right Logical Shift or {11111}Nothing in order)

BrOp - Chooses between reading flags to {1}set PC Adder Operand 2 as a controlled value, or to {0}set PC Adder Operand 2 as a constant 4

DataSel - Chooses between {0}Read Register 2's value, or {1}adjusted PC value

MemRead - Controls whether to {1}allow Reading of Data Memory or {0}not

MemWrite - Controls whether to {1}allow Writing to Data Memory or {0}not

HALTCtrl - Controls whether to {1}halt execution or {0}let it resume

#### **ASSUMPTION**

| Instruction 1 | Memory i | is defined | l as separate | from | Data | Memory |
|---------------|----------|------------|---------------|------|------|--------|
|               |          |            |               |      |      |        |

Instruction Memory module output is a register which can pass sliced outputs to different modules and the control unit

SP is included in the register bank as register number 16 (b10000)

Jump Control acts as a separate control unit for PC increment/decrement to choose whether to increment PC normally or to increment/decrement on the basis of an instruction

ALU output is a register within the ALU toplevel

ALUop = b11111 signifies no ALU operation

SLOW-CLOCK MODULE generates slowclock from system clock

HALT results in slowclock getting paused, slowclock can be resumed with INTERRUPT

# **EXECUTION ORDER OF MICROINSTRUCTIONS**

#### <u>ADD</u>

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | е       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 01       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 0000 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 10         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

#### **SUB**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | e       | ImmSel | ALUin2 | р    | BrOp | I      | d      | e       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 01       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 0001 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 10         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

## <u>AND</u>

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | e       | ImmSel | ALUin2 | р    | BrOp |        | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 01       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 0010 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 10         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

# <u>OR</u>

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | е       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 01       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 0011 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 10         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

## **XOR**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | l          | WriteInfoSel | d      | e       | ImmSel | ALUin2 | р    | BrOp |        | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 01       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 0100 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 10         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

# **NOT**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | е       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 01       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 0101 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 10         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

## **SLA**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | e       | ImmSel | ALUin2 | p    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 01       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 0110 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 10         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

# **SRA**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | е       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 01       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 0111 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 10         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

## <u>SRL</u>

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | e       | ImmSel | ALUin2 | p    | BrOp | l      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 01       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1000 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 10         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

# **ADDI**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | е       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 1      | 01     | 0000 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

## **SUBI**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | e       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 1      | 01     | 0001 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

# <u>ANDI</u>

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | е       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 1      | 01     | 0010 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

# <u>ORI</u>

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | e       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 1      | 01     | 0011 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

# **XORI**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | е       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 1      | 01     | 0100 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

# **NOTI**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | l          | WriteInfoSel | d      | e       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 1      | 01     | 0101 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

# SLAI

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | e       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 1      | 01     | 0110 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

## **SRAI**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | e       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 1      | 01     | 0111 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

# <u>SRLI</u>

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | е       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 1      | 01     | 1000 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

## <u>LD</u>

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | e       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 1      | 01     | 0000 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 1      | 0       |
| t4       | 0     | 0    | 0         | 0        | 00       | 01         | 1            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t5       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

# <u>ST</u>

| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | WriteRegSe<br>I | WriteInfoSel | RegRea<br>d | RegWrit<br>e | ImmSel | ALUin2 | ALUO<br>p | BrOp |   | MemRea<br>d | MemWrit<br>e |
|----------|-------|------|-----------|----------|----------|-----------------|--------------|-------------|--------------|--------|--------|-----------|------|---|-------------|--------------|
| t0       | 0     | 0    | 1         | 0        | 00       | 00              | 0            | 0           | 0            | 0      | 00     | 1111      | 000  | 0 | 0           | 0            |
| t1       | 0     | 0    | 0         | 0        | 00       | 00              | 0            | 1           | 0            | 0      | 00     | 1111      | 000  | 0 | 0           | 0            |
| t2       | 0     | 0    | 0         | 0        | 00       | 00              | 0            | 0           | 0            | 1      | 01     | 0000      | 000  | 0 | 0           | 0            |
| t3       | 0     | 0    | 0         | 0        | 10       | 00              | 0            | 1           | 0            | 0      | 00     | 1111      | 000  | 0 | 0           | 0            |
| t4       | 0     | 0    | 0         | 0        | 00       | 00              | 0            | 0           | 0            | 0      | 00     | 1111      | 000  | 0 | 0           | 1            |
| t5       | 0     | 1    | 0         | 0        | 00       | 00              | 0            | 0           | 0            | 0      | 00     | 1111      | 000  | 0 | 0           | 0            |
| nextinst |       |      |           |          |          |                 |              |             |              |        |        |           |      |   |             | 1            |

# **LDSP**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | е       | ImmSel | ALUin2 | р    | BrOp | I      | d      | e       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 1      | 01     | 0000 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 1      | 0       |
| t4       | 0     | 0    | 0         | 0        | 00       | 01         | 1            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t5       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

## **STSP**

| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | WriteRegSe<br>I | WriteInfoSel | RegRea<br>d | RegWrit<br>e | ImmSel | ALUin2 | ALUO<br>p | BrOp |   | MemRea<br>d | MemWrit<br>e |
|----------|-------|------|-----------|----------|----------|-----------------|--------------|-------------|--------------|--------|--------|-----------|------|---|-------------|--------------|
| t0       | 0     | 0    | 1         | 0        | 00       | 00              | 0            | 0           | 0            | 0      | 00     | 1111      | 000  | 0 | 0           | 0            |
| t1       | 0     | 0    | 0         | 0        | 00       | 00              | 0            | 1           | 0            | 0      | 00     | 1111      | 000  | 0 | 0           | 0            |
| t2       | 0     | 0    | 0         | 0        | 00       | 00              | 0            | 0           | 0            | 1      | 01     | 0000      | 000  | 0 | 0           | 0            |
| t3       | 0     | 0    | 0         | 0        | 10       | 00              | 0            | 1           | 0            | 0      | 00     | 1111      | 000  | 0 | 0           | 0            |
| t4       | 0     | 0    | 0         | 0        | 00       | 00              | 0            | 0           | 0            | 0      | 00     | 1111      | 000  | 0 | 0           | 1            |
| t5       | 0     | 1    | 0         | 0        | 00       | 00              | 0            | 0           | 0            | 0      | 00     | 1111      | 000  | 0 | 0           | 0            |
| nextinst |       |      |           |          |          |                 |              |             |              |        |        |           |      |   |             |              |

## <u>BR</u>

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | е       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 001  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

#### **BMI**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | е       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 0000 | 000  | 0      | 0      | 0       |
| t3       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 1      | 00     | 1111 | 010  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

# **BPL**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | е       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 0000 | 000  | 0      | 0      | 0       |
| t3       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 1      | 00     | 1111 | 011  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

## <u>BZ</u>

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | e       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 0000 | 000  | 0      | 0      | 0       |
| t3       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 1      | 00     | 1111 | 100  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

# **PUSH**

|          |       |      | <u>-</u> . |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      |   | MemRea | MemWrit |
|----------|-------|------|------------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|---|--------|---------|
| ACTION   | PCSel | PCin | InstrRead  | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | е       | ImmSel | ALUin2 | р    | BrOp | I | d      | е       |
| t0       | 0     | 0    | 1          | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0 | 0      | 0       |
| t1       | 0     | 0    | 0          | 1        | 01       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0 | 0      | 0       |
| t2       | 0     | 0    | 0          | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 10     | 0001 | 000  | 0 | 0      | 0       |
| t3       | 0     | 0    | 0          | 1        | 00       | 00         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0 | 0      | 1       |
| t4       | 0     | 1    | 0          | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0 | 0      | 0       |
| nextinst |       |      |            |          |          |            |              |        |         |        |        |      |      |   |        |         |

# **POP**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | e       | ImmSel | ALUin2 | р    | BrOp | I      | d      | e       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 1        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 0000 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 1      | 0       |
| t4       | 0     | 0    | 0         | 0        | 00       | 10         | 1            | 0      | 1       | 0      | 10     | 0000 | 000  | 0      | 0      | 0       |
| t5       | 0     | 1    | 0         | 1        | 00       | 00         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

## **CALL**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | e       | ImmSel | ALUin2 | р    | BrOp | I      | d      | e       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 1        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 10     | 0001 | 000  | 0      | 0      | 0       |
| t3       | 0     | 0    | 0         | 1        | 00       | 00         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 1      | 0      | 1       |
| t4       | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 001  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

## **RET**

| ACTION   | DCS al | DCin  | InstrRead   | Pond1Sol | Pond2Sol | WriteRegSe | WriteInfoSel  | RegRea | RegWrit<br>e | ImmSel    | Alllin2 | ALUO | BrOp |     | MemRea | MemWrit |
|----------|--------|-------|-------------|----------|----------|------------|---------------|--------|--------------|-----------|---------|------|------|-----|--------|---------|
| ACTION   | PCSEI  | PCIII | IIIsti neau | reautsei | Reauzsei | ·          | wiiteiiiiosei | u      | e            | IIIIIISei | ALUITZ  | þ    | ыор  | ļ · | а      | е       |
| t0       | 0      | 0     | 1           | 0        | 00       | 00         | 0             | 0      | 0            | 0         | 00      | 1111 | 000  | 0   | 0      | 0       |
| t1       | 0      | 0     | 0           | 1        | 00       | 00         | 0             | 1      | 0            | 0         | 00      | 1111 | 000  | 0   | 0      | 0       |
| t2       | 0      | 0     | 0           | 0        | 00       | 00         | 0             | 0      | 0            | 0         | 00      | 0000 | 000  | 0   | 0      | 0       |
| t3       | 0      | 0     | 0           | 0        | 00       | 00         | 0             | 0      | 0            | 0         | 00      | 1111 | 000  | 0   | 1      | 0       |
| t4       | 1      | 1     | 0           | 0        | 00       | 00         | 0             | 0      | 0            | 0         | 10      | 0000 | 000  | 0   | 0      | 0       |
| t5       | 0      | 0     | 0           | 1        | 00       | 00         | 0             | 0      | 1            | 0         | 00      | 1111 | 000  | 0   | 0      | 0       |
| nextinst |        |       |             |          |          |            |               |        |              |           |         |      |      |     |        |         |

#### **MOVE**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | е       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t1       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 1      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| t2       | 0     | 0    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 0000 | 000  | 0      | 0      | 0       |
| t3       | 0     | 1    | 0         | 0        | 00       | 01         | 0            | 0      | 1       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

# **HALT**

|          |       |      |           |          |          | WriteRegSe |              | RegRea | RegWrit |        |        | ALUO |      | DataSe | MemRea | MemWrit |
|----------|-------|------|-----------|----------|----------|------------|--------------|--------|---------|--------|--------|------|------|--------|--------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | I          | WriteInfoSel | d      | е       | ImmSel | ALUin2 | р    | BrOp | I      | d      | е       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| INT      | 0     | 1    | 0         | 0        | 00       | 00         | 0            | 0      | 0       | 0      | 00     | 1111 | 000  | 0      | 0      | 0       |
| nextinst |       |      |           |          |          |            |              |        |         |        |        |      |      |        |        |         |

# **NOP**

|          |       |      |           |          |          |             | WriteInfoSe | RegRea | RegWrit |        |        | ALUO |      |         |         | MemWrit |
|----------|-------|------|-----------|----------|----------|-------------|-------------|--------|---------|--------|--------|------|------|---------|---------|---------|
| ACTION   | PCSel | PCin | InstrRead | Read1Sel | Read2Sel | WriteRegSel | I           | d      | е       | ImmSel | ALUin2 | р    | BrOp | DataSel | MemRead | e       |
| t0       | 0     | 0    | 1         | 0        | 00       | 00          | 0           | 0      | 0       | 0      | 00     | 1111 | 000  | 0       | 0       | 0       |
| t1       | 0     | 1    | 0         | 0        | 00       | 00          | 0           | 0      | 0       | 0      | 00     | 1111 | 000  | 0       | 0       | 0       |
| nextinst |       |      |           |          |          |             |             |        |         |        |        |      |      |         |         |         |

#### **MODULE OVERVIEW**

#### TOP - (top.v)

Top-level module of CPU, contains Control Unit, Data path module, and Branch Control. Takes clock and INTERRUPT as input

#### Control Unit - (control unit.v)

Control unit of CPU. Contains states for different executions and corresponding control signal values. Takes opcode, function, and INTERRUPT as input, along with clock. Output is various control signals

#### Data Path - (data path.v)

Data path module responsible for processing and connecting of varying values from the different modules. Contains MUX modules, PC, PCadder, Branch signal controller, instruction memory, data memory, sign extender modules, and register bank. Input is various control signals while output is ALU zero, sign, and carry lines, opcodes, function codes, and value to output

#### MUX READ1SEL - (mux 5b 2 to 1.v)

Register bank feeding module, selects instruction segment or constant value 0 to pass as first register to read, controlled by Read1Sel

#### MUX\_READ2SEL - (mux\_5b\_3\_to\_1.v)

Register bank feeding module, selects which of the instruction segments or constant value 0 to pass as second register to read, controlled by Read2Sel

#### MUX WRITEREGSEL - (mux 5b 3 to 1.v)

Register bank feeding module, selects which of the instruction segments to pass as register to write to, controlled by WriteRegSel

#### MUX WRITEINFOSEL - (mux 32b 2 to 1.v)

Register bank feeding volume, chooses which data (ALU result or memory-read value) to pass to bank as data to write to chosen register. Controlled by WriteInfoSel

#### MUX IMMSEL – (mux 32b 2 to 1.v)

MUX module which selects whether to pass sign extended 18 bit value or 28 bit value for further operations, uses ImmSel as control signal

#### MUX ALUIN2 – (mux 32b 3 to 1.v)

ALU feeding MUX module, selects whether to pass constant value 4, immediate value, or register-read value as an ALU operand. Controlled by ALUin2

#### MUX\_DATASEL - (mux\_32b\_2\_to\_1.v)

Data memory feeding MUX, selects whether to pass register read value or PC value as data to write to memory. Controlled by PCSel

#### MUX PCSel - (mux32b 2 to 1.v)

2to1 MUX module that selects whether PC should get PC+4 value or returned value, controlled by PCSel

#### MUX\_BRSIGNAL - (mux32b\_2\_to\_1)

PCAdder feeding module, takes in constant value of 4 and sign extended immediate value, based on control signal brsignal, decides whether PC should be incremented normally or with returned value by outputting value to PCadder

#### <u>Branch Contol – (branch\_control.v)</u>

Branch Control module, accepts ALU flags and BrOp control signal as input, and gives a control signal BrSignal as output which is passed to MUX BRSIGNAL

#### PCADDER – (pc\_adder.v)

PC adder module, outputs sum of two values given as input

#### PC - (pc.v)

PC module, stores Instruction address in output register. Regsiter is updated with input value when control signal PCin is enabled

#### <u>INSTRMEM – (instr\_mem.v)</u>

Instruction memory module stores instructions as 32bit entries. Accepts instruction address as input along with control signal InstrRead, and outputs various segments of the instruction that is being pointed to.

#### <u>SIGNEX2832 – (signex\_28\_to\_32.v)</u>

Sign extender module extends 28 bit input to 32 bit value as output

#### SIGNEX1832 – (signex 18 to 32.v)

Sign extender module extends 18 bit input to 32 bit output

#### REGBANK – (regbank.v)

Register Bank module, contains sixteen 32bit registers, takes input as address of registers to read and write to, along with data to write, and control signals RegRead and RegWrite. Passes values read from registers as output

#### $\underline{alu - (ALU.v)}$

Arithmetic module. Takes operands as input, along with function to perform. Result is passed to output register, along with zero, sign, and carry flags

#### DATAMEM - (data\_mem.v)

Data memory module. Accepts memory address and 32 bit data as input, along with control signals MemRead and MemWrite. Passes data read from memory location as output

# **FINITE STATES OF CONTROL UNIT**

| opcod<br>e | functio<br>n |     | ACTIO<br>N   | PCSe<br>I | PCin |   | Read1S<br>el | Read2S<br>el | WriteRegS<br>el | WriteInfo<br>Sel | RegRe<br>ad | RegWri<br>te | ImmS<br>el | ALUin<br>2 | ALUO<br>p | BrO<br>p | DataS<br>el |   | MemWri<br>te | STAT<br>E |
|------------|--------------|-----|--------------|-----------|------|---|--------------|--------------|-----------------|------------------|-------------|--------------|------------|------------|-----------|----------|-------------|---|--------------|-----------|
| 0000       | 00000        | ADD | t0           | 0         | 0    | 1 | 0            | 00           | 00              | 0                | 0           | 0            | 0          | 00         | 1111      | 000      | 0           | 0 | 0            | 0         |
|            |              |     | t1           | 0         | 0    | 0 | 0            | 01           | 00              | 0                | 1           | 0            | 0          | 00         | 1111      | 000      | 0           | 0 | 0            | 2         |
|            |              |     | t2           | 0         | 0    | 0 | 0            | 00           | 00              | 0                | 0           | 0            | 0          | 00         | 0000      | 000      | 0           | 0 | 0            | 3         |
|            |              |     | t3           | 0         | 0    | 0 | 0            | 00           | 10              | 0                | 0           | 1            | 0          | 00         | 1111      | 000      | 0           | 0 | 0            | 4         |
|            |              |     | t4           | 0         | 1    | 0 | 0            | 00           | 00              | 0                | 0           | 0            | 0          | 00         | 1111      | 000      | 0           | 0 | 0            | 5         |
|            |              |     | nextin<br>st |           |      |   |              |              |                 |                  |             |              |            |            |           |          |             |   |              |           |
| 0000       | 00001        | SUB | t0           | 0         | 0    | 1 | 0            | 00           | 00              | 0                | 0           | 0            | 0          | 00         | 1111      | 000      | 0           | 0 | 0            | 0         |
|            |              |     | t1           | 0         | 0    | 0 | 0            | 01           | 00              | 0                | 1           | 0            | 0          | 00         | 1111      | 000      | 0           | 0 | 0            | 2         |
|            |              |     | t2           | 0         | 0    | 0 | 0            | 00           | 00              | 0                | 0           | 0            | 0          | 00         | 0001      | 000      | 0           | 0 | 0            | 6         |
|            |              |     | t3           | 0         | 0    | 0 | 0            | 00           | 10              | 0                | 0           | 1            | 0          | 00         | 1111      | 000      | 0           | 0 | 0            | 4         |
|            |              |     | t4           | 0         | 1    | 0 | 0            | 00           | 00              | 0                | 0           | 0            | 0          | 00         | 1111      | 000      | 0           | 0 | 0            | 5         |
|            |              |     | nextin<br>st |           |      |   |              |              |                 |                  |             |              |            |            |           |          |             |   |              |           |
| 0000       | 00010        | AND | t0           | 0         | 0    | 1 | 0            | 00           | 00              | 0                | 0           | 0            | 0          | 00         | 1111      | 000      | 0           | 0 | 0            | 0         |
|            |              |     | t1           | 0         | 0    | 0 | 0            | 01           | 00              | 0                | 1           | 0            | 0          | 00         | 1111      | 000      | 0           | 0 | 0            | 2         |
|            |              |     | t2           | 0         | 0    | 0 | 0            | 00           | 00              | 0                | 0           | 0            | 0          | 00         | 0010      | 000      | 0           | 0 | 0            | 7         |

|      |       |     | t3           | 0 | 0 | 0 | 0 | 00 | 10 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 4 |
|------|-------|-----|--------------|---|---|---|---|----|----|---|---|---|---|----|------|-----|---|---|---|---|
|      |       |     | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5 |
|      |       |     | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |   |
| 0000 | 00011 | OR  | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0 |
|      |       |     | t1           | 0 | 0 | 0 | 0 | 01 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 2 |
|      |       |     | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 0011 | 000 | 0 | 0 | 0 | 8 |
|      |       |     | t3           | 0 | 0 | 0 | 0 | 00 | 10 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 4 |
|      |       |     | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5 |
|      |       |     | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |   |
| 0000 | 00100 | XOR | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0 |
|      |       |     | t1           | 0 | 0 | 0 | 0 | 01 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 2 |
|      |       |     | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 0100 | 000 | 0 | 0 | 0 | 9 |
|      |       |     | t3           | 0 | 0 | 0 | 0 | 00 | 10 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 4 |
|      |       |     | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5 |
|      |       |     | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |   |
| 0000 | 00101 | NOT | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0 |
|      |       |     | t1           | 0 | 0 | 0 | 0 | 01 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 2 |

|      |       |     | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 0101 | 000 | 0 | 0 | 0 | 10 |
|------|-------|-----|--------------|---|---|---|---|----|----|---|---|---|---|----|------|-----|---|---|---|----|
|      |       |     | t3           | 0 | 0 | 0 | 0 | 00 | 10 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 4  |
|      |       |     |              |   |   |   |   | 00 | 10 | 0 | 0 |   | 0 | 00 | 1111 | 000 | 0 |   | 0 | 4  |
|      |       |     | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|      |       |     | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0000 | 00110 | SLA | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |       |     | t1           | 0 | 0 | 0 | 0 | 01 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 2  |
|      |       |     | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 0110 | 000 | 0 | 0 | 0 | 11 |
|      |       |     | t3           | 0 | 0 | 0 | 0 | 00 | 10 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 4  |
|      |       |     | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|      |       |     | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0000 | 00111 | SRA | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |       |     | t1           | 0 | 0 | 0 | 0 | 01 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 2  |
|      |       |     | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 0111 | 000 | 0 | 0 | 0 | 12 |
|      |       |     | t3           | 0 | 0 | 0 | 0 | 00 | 10 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 4  |
|      |       |     | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|      |       |     | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0000 | 01000 | SRL | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |

|      |       |      | t1           | 0 | 0 | 0 | 0 | 01 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 2  |
|------|-------|------|--------------|---|---|---|---|----|----|---|---|---|---|----|------|-----|---|---|---|----|
|      |       |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1000 | 000 | 0 | 0 | 0 | 13 |
|      |       |      | t3           | 0 | 0 | 0 | 0 | 00 | 10 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 4  |
|      |       |      | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|      |       |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0000 | 01001 | ADDI | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |       |      | t1           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |
|      |       |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 1 | 01 | 0000 | 000 | 0 | 0 | 0 | 15 |
|      |       |      | t3           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 16 |
|      |       |      | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|      |       |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0000 | 01010 | SUBI | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |       |      | t1           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |
|      |       |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 1 | 01 | 0001 | 000 | 0 | 0 | 0 | 17 |
|      |       |      | t3           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 16 |
|      |       |      | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|      |       |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |

| 0000 | 01011 | ANDI | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|------|-------|------|--------------|---|---|---|---|----|----|---|---|---|---|----|------|-----|---|---|---|----|
|      |       |      | t1           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |
|      |       |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 1 | 01 | 0010 | 000 | 0 | 0 | 0 | 18 |
|      |       |      | t3           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 16 |
|      |       |      | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|      |       |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0000 | 01100 | ORI  | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |       |      | t1           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |
|      |       |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 1 | 01 | 0011 | 000 | 0 | 0 | 0 | 19 |
|      |       |      | t3           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 16 |
|      |       |      | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|      |       |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0000 | 01101 | XORI | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |       |      | t1           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |
|      |       |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 1 | 01 | 0100 | 000 | 0 | 0 | 0 | 20 |
|      |       |      | t3           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 16 |
|      |       |      | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |

|      |       |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
|------|-------|------|--------------|---|---|---|---|----|----|---|---|---|---|----|------|-----|---|---|---|----|
| 0000 | 01110 | NOTI | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |       |      | t1           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |
|      |       |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 1 | 01 | 0101 | 000 | 0 | 0 | 0 | 21 |
|      |       |      | t3           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 16 |
|      |       |      | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|      |       |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0000 | 01111 | SLAI | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |       |      | t1           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |
|      |       |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 1 | 01 | 0110 | 000 | 0 | 0 | 0 | 22 |
|      |       |      | t3           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 16 |
|      |       |      | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|      |       |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0000 | 10000 | SRAI | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |       |      | t1           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |
|      |       |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 1 | 01 | 0111 | 000 | 0 | 0 | 0 | 23 |
|      |       |      | t3           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 16 |

|      |       |      | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|------|-------|------|--------------|---|---|---|---|----|----|---|---|---|---|----|------|-----|---|---|---|----|
|      |       |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0000 | 10001 | SRLI | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |       |      | t1           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |
|      |       |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 1 | 01 | 1000 | 000 | 0 | 0 | 0 | 24 |
|      |       |      | t3           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 16 |
|      |       |      | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|      |       |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0001 |       | LD   | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |       |      | t1           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |
|      |       |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 1 | 01 | 0000 | 000 | 0 | 0 | 0 | 15 |
|      |       |      | t3           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 1 | 0 | 25 |
|      |       |      | t4           | 0 | 0 | 0 | 0 | 00 | 01 | 1 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 26 |
|      |       |      | t5           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|      |       |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0010 |       | ST   | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |       |      | t1           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |

|      |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 1 | 01 | 0000 | 000 | 0 | 0 | 0 | 15 |
|------|------|--------------|---|---|---|---|----|----|---|---|---|---|----|------|-----|---|---|---|----|
|      |      | t3           | 0 | 0 | 0 | 0 | 10 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 41 |
|      |      | t4           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 1 | 27 |
|      |      | t5           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|      |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0011 | LDSP | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |      | t1           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |
|      |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 1 | 01 | 0000 | 000 | 0 | 0 | 0 | 15 |
|      |      | t3           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 1 | 0 | 25 |
|      |      | t4           | 0 | 0 | 0 | 0 | 00 | 01 | 1 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 26 |
|      |      | t5           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|      |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0100 | STSP | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |      | t1           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |
|      |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 1 | 01 | 0000 | 000 | 0 | 0 | 0 | 15 |
|      |      | t3           | 0 | 0 | 0 | 0 | 10 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 41 |
|      |      | t4           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 1 | 27 |

|      |     | t5           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|------|-----|--------------|---|---|---|---|----|----|---|---|---|---|----|------|-----|---|---|---|----|
|      |     | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0101 | BR  | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |     | t1           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 001 | 0 | 0 | 0 | 38 |
|      |     | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0110 | ВМІ | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |     | t1           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |
|      |     | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 0000 | 000 | 0 | 0 | 0 | 3  |
|      |     | t3           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 1 | 00 | 1111 | 010 | 0 | 0 | 0 | 28 |
|      |     | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 0111 | BPL | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |     | t1           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |
|      |     | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 0000 | 000 | 0 | 0 | 0 | 3  |
|      |     | t3           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 1 | 00 | 1111 | 011 | 0 | 0 | 0 | 29 |
|      |     | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 1000 | BZ  | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |

|      |      | t1           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |
|------|------|--------------|---|---|---|---|----|----|---|---|---|---|----|------|-----|---|---|---|----|
|      |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 0000 | 000 | 0 | 0 | 0 | 3  |
|      |      | t3           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 1 | 00 | 1111 | 100 | 0 | 0 | 0 | 30 |
|      |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 1001 | PUSH | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |      | t1           | 0 | 0 | 0 | 1 | 01 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 31 |
|      |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 10 | 0001 | 000 | 0 | 0 | 0 | 32 |
|      |      | t3           | 0 | 0 | 0 | 1 | 00 | 00 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 1 | 33 |
|      |      | t4           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5  |
|      |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 1010 | POP  | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |      | t1           | 0 | 0 | 0 | 1 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 34 |
|      |      | t2           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 0000 | 000 | 0 | 0 | 0 | 3  |
|      |      | t3           | 0 | 0 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 1 | 0 | 25 |
|      |      | t4           | 0 | 0 | 0 | 0 | 00 | 10 | 1 | 0 | 1 | 0 | 10 | 0000 | 000 | 0 | 0 | 0 | 35 |
|      |      | t5           | 0 | 1 | 0 | 1 | 00 | 00 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 36 |
|      |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |

| 1011 | CA              | LL t0        | ( | 0   | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|------|-----------------|--------------|---|-----|---|---|----|----|---|---|---|---|----|------|-----|---|---|---|----|
|      |                 | t1           | ( | 0   | 0 | 1 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 34 |
|      |                 | t2           | ( | 0   | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 10 | 0001 | 000 | 0 | 0 | 0 | 32 |
|      |                 | t3           |   | 0   | 0 | 1 | 00 | 00 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 1 | 0 | 1 | 37 |
|      |                 | t4           |   | 1   | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 001 | 0 | 0 | 0 | 38 |
|      |                 | nextir<br>st |   |     |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 1100 | RE <sup>-</sup> | Γ t0         | ( | 0   | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0  |
|      |                 | t1           | ( | 0   | 0 | 1 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 34 |
|      |                 | t2           | ( | 0   | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 0000 | 000 | 0 | 0 | 0 | 3  |
|      |                 | t3           | ( | 0   | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 1 | 0 | 25 |
|      |                 | t4           | 1 | . 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 10 | 0000 | 000 | 0 | 0 | 0 | 39 |
|      |                 | t5           | ( | 0   | 0 | 1 | 00 | 00 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 42 |
|      |                 | nextir<br>st |   |     |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
|      | М               |              |   |     |   |   |    |    |   |   |   |   |    |      |     |   |   |   |    |
| 1101 | E               | t0           | ( |     |   |   | 00 | 00 | 0 | 0 |   |   | 00 | 1111 |     | 0 |   | 0 |    |
|      |                 | t1           | ( | 0   | 0 | 0 | 00 | 00 | 0 | 1 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 14 |
|      |                 | t2           | ( | 0   | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 0000 | 000 | 0 | 0 | 0 | 3  |
|      |                 | t3           | ( | 1   | 0 | 0 | 00 | 01 | 0 | 0 | 1 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 40 |

|      |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |   |
|------|------|--------------|---|---|---|---|----|----|---|---|---|---|----|------|-----|---|---|---|---|
| 1110 | HALT | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0 |
|      |      | INT          | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5 |
|      |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |   |
| 1111 | NOP  | t0           | 0 | 0 | 1 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 0 |
|      |      | t1           | 0 | 1 | 0 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | 00 | 1111 | 000 | 0 | 0 | 0 | 5 |
|      |      | nextin<br>st |   |   |   |   |    |    |   |   |   |   |    |      |     |   |   |   |   |