## **Definitions**

| RS = Register[IR[25-21]] |
|--------------------------|
| RT = Register[IR[20-16]] |
| RD = Register[IR[15-11]] |

$$JT = IR[25-0]]$$
  $OP = IR[5-0]]$   $IMM = IR[15-0]$   $FUNC = IR[31-26]$ 

## **Common RTL**

| Cycle | Label   | RTL                          | Control                                                                                          |
|-------|---------|------------------------------|--------------------------------------------------------------------------------------------------|
| 0     | Fetch:  |                              | ALUSelA <= 0 ALUSelB <= 001 MemRead_L <= 0 IorD <= 0 IRWrite_H <= 1 PCWrite_H <= 1 PCSource <= 0 |
| 1     | Decode: | Target <= PC + SEx(Imm << 2) | ALUSelA <= 0<br>ALUSelB <= 011<br>TargetWrite_H <= 1                                             |
| Last  | Done:   | goto Fetch                   |                                                                                                  |

## **Memory Read**

| Cycle | Label    | RTL                                             | Control  |
|-------|----------|-------------------------------------------------|----------|
| ?     | MR:      | if MMRESP_H then goto MR_Done                   | MMREAD_L |
| ?     |          | if MMRESP_H then goto MR_Done else goto MR_Loop |          |
| ?     | MR_DONE: |                                                 |          |

## **Memory Write**

| Cycle                               | Label    | RTL                                             | Control |
|-------------------------------------|----------|-------------------------------------------------|---------|
| ? MW: if MMRESP_H then goto MW_Done |          | MMWRITE_L                                       |         |
| ?                                   |          | if MMRESP_H then goto MW_Done else goto MW_Loop |         |
| ?                                   | MW_DONE: |                                                 |         |

| add   | Type R-Type | Op (31:26)<br>000000 | Func (5:0)<br>100000 |                                |
|-------|-------------|----------------------|----------------------|--------------------------------|
| Cycle | Label       | RTL                  |                      | Control                        |
| 2     | ADD:        | ALUOut <= RS         | S + RT               | ALUSelA <= 1<br>ALUSelB <= 000 |

| 3 | RD <= ALUOut | ALUSelA <= 1    |
|---|--------------|-----------------|
|   |              | ALUSelB <= 000  |
| 1 |              | RegDst <= 01    |
| 1 |              | MemToReg <= 00  |
|   |              | RegWrite_H <= 1 |

| addi  | Type Op (31:26)  I-Type 001000 |                         |                                                                                     |
|-------|--------------------------------|-------------------------|-------------------------------------------------------------------------------------|
| Cycle | Label                          | RTL                     | Control                                                                             |
| 2     | ADDI:                          | ALUOut <= RS + SEx(Imm) | ALUSelA <= 1<br>ALUSelB <= 010                                                      |
| 3     |                                | RT <= ALUOut            | ALUSelA <= 1<br>ALUSelB <= 010<br>RegDst <= 01<br>MemToReg <= 00<br>RegWrite_H <= 1 |

| and   | Туре <b>R-Туре</b> | Op (31:26)<br>000000 | Func (5:0)<br>100100 |                                                                                     |   |
|-------|--------------------|----------------------|----------------------|-------------------------------------------------------------------------------------|---|
| Cycle | Label              | RTL                  |                      | Control                                                                             |   |
| 2     | AND:               | ALUOut <= RS A       | AND RT               | ALUSelA <= 1<br>ALUSelB <= 000                                                      |   |
| 3     |                    | RD <= ALUOut         |                      | ALUSeIA <= 1<br>ALUSeIB <= 000<br>RegDst <= 01<br>MemToReg <= 00<br>RegWrite_H <= 1 | ) |

| andi  | ndi Type Op (31:26) I-Type 001100 |                           |                                                                         |
|-------|-----------------------------------|---------------------------|-------------------------------------------------------------------------|
| Cycle | Label                             | RTL                       | Control                                                                 |
| 2     | ANDI:                             | ALUOut <= RS AND ZEx(Imm) | ALUSelA <= 1<br>ALUSelB <= 010                                          |
| 3     |                                   | RT <= ALUOut              | ALUSeIA <= 1 ALUSeIB <= 100 RegDst <= 01 MemToReg <= 00 RegWrite_H <= 1 |

| beq   | Type<br>I-Type | Op (31:26)<br><b>001000</b> |         |
|-------|----------------|-----------------------------|---------|
| Cycle | Label          | RTL                         | Control |

| 2 | BEQ: | ALUSelA <= 1<br>ALUSelB <= 000                                         |
|---|------|------------------------------------------------------------------------|
| 3 |      | ALUSelA <= 1<br>ALUSelB <= 000<br>PCWriteZero_H <= 1<br>PCSource <= 01 |

| bne   | Type Op (31:26) <b>I-Type 001001</b> |                         |                                                                         |
|-------|--------------------------------------|-------------------------|-------------------------------------------------------------------------|
| Cycle | Label                                | RTL                     | Control                                                                 |
| 2     | BNE:                                 | ALUOut <= RS - RT       | ALUSelA <= 1<br>ALUSelB <= 000                                          |
| 3     |                                      | if (!Zero) PC <= Target | ALUSelA <= 1<br>ALUSelB <= 000<br>PCWriteNZero_H <= 1<br>PCSource <= 01 |

| j     | Туре <b>J-Туре</b> | Op (31:26)<br><b>000010</b>  |                                  |
|-------|--------------------|------------------------------|----------------------------------|
| Cycle | Label              | RTL                          | Control                          |
| 2     | J:                 | PC <= PC[31-28]    (JT << 2) | PCWrite_H <= 1<br>PCSource <= 10 |

| jal   | Type Op (31:26) <b>J-Type 000011</b> |                                           |                                                                         |
|-------|--------------------------------------|-------------------------------------------|-------------------------------------------------------------------------|
| Cycle | Label                                | RTL                                       | Control                                                                 |
| 2     | JAL:                                 | R31 <= PC<br>PC <= PC[31-28]    (JT << 2) | RegDst <= 10 MemToReg <= 10 RegWrite_H <= 1 PCWrite <= 1 PCSource <= 10 |

| jr    | Туре <b>R-Туре</b> | Op (31:26)<br><b>000000</b> | Func (5:0)<br><b>001000</b> |                                |
|-------|--------------------|-----------------------------|-----------------------------|--------------------------------|
| Cycle | Label              | RTL                         |                             | Control                        |
| 2     | JR:                | PC <= RS                    |                             | PCWrite <= 1<br>PCSource <= 11 |

| Type Op (31:26) I-Type 001111 |  |
|-------------------------------|--|
|-------------------------------|--|

| Cycle | Label | RTL                           | Control         |
|-------|-------|-------------------------------|-----------------|
| 2     | LUI:  | $RT \le IMM \parallel 0^{16}$ | RegDst <= 00    |
|       |       | 22.22.2    0                  | MemToReg <= 11  |
|       |       |                               | RegWrite_H <= 1 |

| lw    | Type<br>I-Type | Op (31:26)<br>100011 |                                                                                                 |
|-------|----------------|----------------------|-------------------------------------------------------------------------------------------------|
| Cycle | Label          | RTL                  | Control                                                                                         |
| 2     | LW:            | ALUOut <= RS + IMM   | ALUSelA <= 1<br>ALUSelB <= 010                                                                  |
| 3     |                | RT <= Mem[ALUOut]    | MemRead_L <= 0 IorD = 1 ALUSelA <= 1 ALUSelB <= 010 RegDst <= 00 MemToReg <= 01 RegWrite_H <= 1 |

| or    | Type R-Type | Op (31:26)<br>000000 | Func (5:0)<br>100101 |                                                                                     |
|-------|-------------|----------------------|----------------------|-------------------------------------------------------------------------------------|
| Cycle | Label       | RTL                  |                      | Control                                                                             |
| 2     | OR:         | ALUOut <= RT         | OR RS                | ALUSelA <= 1<br>ALUSelB <= 000                                                      |
| 3     |             | RD <= ALUOu          | t                    | ALUSelA <= 1<br>ALUSelB <= 000<br>RegDst <= 01<br>MemToReg <= 00<br>RegWrite_H <= 1 |

| ori   | Type I-Type | Op (31:26)<br><b>001101</b> |                                                                         |
|-------|-------------|-----------------------------|-------------------------------------------------------------------------|
| Cycle | Label       | RTL                         | Control                                                                 |
| 2     | ORI:        | ALUOut <= RT OR ZEx(IMM)    | ALUSelA <= 1<br>ALUSelB <= 010                                          |
| 3     |             | RD <= ALUOut                | ALUSelA <= 1 ALUSelB <= 100 RegDst <= 01 MemToReg <= 00 RegWrite_H <= 1 |

| sll | Туре<br><b>R-Туре</b> | Op (31:26)<br>000000 | Func (5:0)<br>000000 |  |
|-----|-----------------------|----------------------|----------------------|--|
|     |                       |                      |                      |  |

| Cycle | Label | RTL                      | Control                                                                             |
|-------|-------|--------------------------|-------------------------------------------------------------------------------------|
| 2     | SLL:  | ALUOut <= RT << IR[10-6] | ALUSelA <= 1<br>ALUSelB <= 100                                                      |
| 3     |       | RD <= ALUOut             | ALUSeIA <= 1<br>ALUSeIB <= 100<br>RegDst <= 01<br>MemToReg <= 00<br>RegWrite_H <= 1 |

| slt   | Type R-Type | Op (31:26)<br><b>000000</b> | Func (5:0) 101010             |                                                                         |
|-------|-------------|-----------------------------|-------------------------------|-------------------------------------------------------------------------|
| Cycle | Label       | RTL                         |                               | Control                                                                 |
| 2     | SLT:        | if (RS < RT) the            | en ALUOut = 1 else ALUOut = 0 | ALUSelA <= 1<br>ALUSelB <= 000                                          |
| 3     |             | RD <= ALUOu                 | t                             | ALUSelA <= 1 ALUSelB <= 000 RegDst <= 01 MemToReg <= 00 RegWrite_H <= 1 |

| slti  | Type<br>I-Type | Op (31:26)<br>101010                                 |                                                                                     |
|-------|----------------|------------------------------------------------------|-------------------------------------------------------------------------------------|
| Cycle | Label          | RTL                                                  | Control                                                                             |
| 2     | SLTI:          | if $(RS < SEx(IMM))$ then ALUOut = 1 else ALUOut = 0 | ALUSelA <= 1<br>ALUSelB <= 010                                                      |
| 3     |                |                                                      | ALUSelA <= 1<br>ALUSelB <= 010<br>RegDst <= 01<br>MemToReg <= 00<br>RegWrite_H <= 1 |

| srl   | Type R-Type | Op (31:26)<br><b>000000</b> | Func (5:0)<br>000010 |                                                                         |
|-------|-------------|-----------------------------|----------------------|-------------------------------------------------------------------------|
| Cycle | Label       | RTL                         |                      | Control                                                                 |
| 2     | SRL:        | ALUOut <= RT                | >> IR[10-6]          | ALUSelA <= 1<br>ALUSelB <= 100                                          |
| 3     |             | RD <= ALUOu                 | t                    | ALUSelA <= 1 ALUSelB <= 100 RegDst <= 01 MemToReg <= 00 RegWrite_H <= 1 |

| sub   | Type R-Type | Op (31:26) Func (5:0) <b>100010</b> |                                                                                     |
|-------|-------------|-------------------------------------|-------------------------------------------------------------------------------------|
| Cycle | Label       | RTL                                 | Control                                                                             |
| 2     | SUB:        | ALUOut <= RS - RT                   | ALUSelA <= 1<br>ALUSelB <= 000                                                      |
| 3     |             | RD <= ALUOut                        | ALUSelA <= 1<br>ALUSelB <= 000<br>RegDst <= 01<br>MemToReg <= 00<br>RegWrite_H <= 1 |

| SW    | Type Op (31:26) <b>I-Type</b> 100011 |                    |                                                                           |  |
|-------|--------------------------------------|--------------------|---------------------------------------------------------------------------|--|
| Cycle | Label                                | RTL                | Control                                                                   |  |
| 2     | SW:                                  | ALUOut <= RS + IMM | ALUSelA <= 1<br>ALUSelB <= 010                                            |  |
| 3     |                                      | Mem[ALUOut] <= RT  | MemWrite IorD = 1 ALUSelA <= 1 ALUSelB <= 010 RegDst <= 00 MemToReg <= 01 |  |