

## ISA

| Instruction           | ALU Opcode    | Type | Operation                                                                        |
|-----------------------|---------------|------|----------------------------------------------------------------------------------|
| add \$rd, \$rs, \$rt  | 00000 (00000) | R    | \$rd = \$rs + \$rt<br>\$rstatus = 1 if overflow                                  |
| addi \$rd, \$rs, N    | 00101         | I    | \$rd = \$rs + N<br>\$rstatus = 2 if overflow                                     |
| sub \$rd, \$rs, \$rt  | 00000 (00001) | R    | \$rd = \$rs - \$rt<br>\$rstatus = 3 if overflow                                  |
| and \$rd, \$rs, \$rt  | 00000 (00010) | R    | \$rd = \$rs & \$rt                                                               |
| or \$rd, \$rs, \$rt   | 00000 (00011) | R    | \$rd = \$rs   \$rt                                                               |
| sll \$rd, \$rs, shamt | 00000 (00100) | R    | \$rd = \$rs << shamt                                                             |
| sra \$rd, \$rs, shamt | 00000 (00101) | R    | \$rd = \$rs >>> shamt                                                            |
| sw \$rd, N(\$rs)      | 00111         | I    | MEM[\$rs + N] = \$rd                                                             |
| lw \$rd, N(\$rs)      | 01000         | I    | \$rd = MEM[\$rs + N]                                                             |
| j T                   | 00001         | JI   | PC = T ( <b>not required for this checkpoint</b> )                               |
| bne \$rd, \$rs, N     | 00010         | I    | if (\$rd != \$rs) PC = PC + 1 + N<br>( <b>not required for this checkpoint</b> ) |
| jal T                 | 00011         | JI   | \$r31 = PC + 1, PC = T ( <b>not required for this checkpoint</b> )               |
| jr \$rd               | 00100         | JII  | PC = \$rd ( <b>not required for this checkpoint</b> )                            |
| blt \$rd, \$rs, N     | 00110         | I    | if (\$rd < \$rs) PC = PC + 1 + N ( <b>not required for this checkpoint</b> )     |
| bex T                 | 10110         | JI   | if (\$rstatus != 0) PC = T ( <b>not required for this checkpoint</b> )           |
| setx T                | 10101         | JI   | \$rstatus = T ( <b>not required for this checkpoint</b> )                        |

|                           |                          |   |                                                                                                        |
|---------------------------|--------------------------|---|--------------------------------------------------------------------------------------------------------|
| custom_r \$rd, \$rs, \$rt | 00000<br>(01000 - 11111) | R | \$rd = custom_r(\$rs, \$rt) (For use on Final Project - <b>not required for this checkpoint</b> )      |
| custom ...                | xxxxx+                   | X | Whatever custom instructions you need for your Final Project - <b>not required for this checkpoint</b> |

## Instruction Machine Code Format

| Instruction Format |                                                                                                                                                                                                    |                |                      |               |                      |              |              |              |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------|---------------|----------------------|--------------|--------------|--------------|
| Type               |                                                                                                                                                                                                    |                |                      |               |                      |              |              |              |
| R                  | <table border="1"> <tr> <td>Opcode [31:27]</td> <td>\$rd [26:22]</td> <td>\$rs [21:17]</td> <td>\$rt [16:12]</td> <td>shamt [11:7]</td> <td>ALU op [6:2]</td> <td>Zeroes [1:0]</td> </tr> </table> | Opcode [31:27] | \$rd [26:22]         | \$rs [21:17]  | \$rt [16:12]         | shamt [11:7] | ALU op [6:2] | Zeroes [1:0] |
| Opcode [31:27]     | \$rd [26:22]                                                                                                                                                                                       | \$rs [21:17]   | \$rt [16:12]         | shamt [11:7]  | ALU op [6:2]         | Zeroes [1:0] |              |              |
| I                  | <table border="1"> <tr> <td>Opcode [31:27]</td> <td>\$rd [26:22]</td> <td>\$rs [21:17]</td> <td>Immediate (N) [16:0]</td> </tr> </table>                                                           | Opcode [31:27] | \$rd [26:22]         | \$rs [21:17]  | Immediate (N) [16:0] |              |              |              |
| Opcode [31:27]     | \$rd [26:22]                                                                                                                                                                                       | \$rs [21:17]   | Immediate (N) [16:0] |               |                      |              |              |              |
| JI                 | <table border="1"> <tr> <td>Opcode [31:27]</td> <td>Target (T) [26:0]</td> </tr> </table>                                                                                                          | Opcode [31:27] | Target (T) [26:0]    |               |                      |              |              |              |
| Opcode [31:27]     | Target (T) [26:0]                                                                                                                                                                                  |                |                      |               |                      |              |              |              |
| JII                | <table border="1"> <tr> <td>Opcode [31:27]</td> <td>\$rd [26:22]</td> <td>Zeroes [21:0]</td> </tr> </table>                                                                                        | Opcode [31:27] | \$rd [26:22]         | Zeroes [21:0] |                      |              |              |              |
| Opcode [31:27]     | \$rd [26:22]                                                                                                                                                                                       | Zeroes [21:0]  |                      |               |                      |              |              |              |

1. I-type immediate field [16:0] (N) is signed and is sign-extended to a signed 32-bit integer
2. JI-type target field [26:0] (T) is **unsigned**. PC and STATUS registers' upper bits [31:27] are guaranteed to never be used