| Name   | Format                  | Functionality                                                                                                                                                             | Specialized  |  |  |  |  |
|--------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--|--|--|--|
|        |                         |                                                                                                                                                                           | signal       |  |  |  |  |
| R-type |                         |                                                                                                                                                                           |              |  |  |  |  |
| add    | add \$r1,<br>\$r2, \$r3 | add two register<br>numbers (\$r2 and \$r3)<br>and store the result in<br>one register (\$r1)                                                                             | Write memory |  |  |  |  |
| and    | and \$r1,<br>\$r2, \$r3 | bit-wise logical AND of<br>two register numbers<br>(\$r2 and \$r3), and store<br>the result in a register<br>(\$r1)                                                       | Write memory |  |  |  |  |
| or     | or \$r1,<br>\$r2, \$r3  | bit-wise logical OR of<br>two register numbers<br>(\$r2 and \$r3), and store<br>the result in a register<br>(\$r1)                                                        | Write memory |  |  |  |  |
| slt    | slt \$r1,<br>\$r2, \$r3 | if the register number (\$r2) is less than the register number (\$r3), then \$r1=1; or \$r1=0.                                                                            | Less than    |  |  |  |  |
| Isl    | Isl \$r1,<br>\$r2, \$r3 | logical-shift a register<br>number (\$r2) to left for<br>several digits<br>(\$r3), and store the<br>result in a register (\$r1)                                           |              |  |  |  |  |
| Isr    | Isr \$r1,<br>\$r2, \$r3 | logical-shift a register<br>number (\$r2) to right<br>for several digits<br>(\$r3), and store the<br>result in a register (\$r1).<br>The shift-in high<br>bits are all 0. |              |  |  |  |  |
| neg    | neg \$r1,<br>\$r2       | negate a register number (\$r2) and store the result in the register (\$r1)                                                                                               |              |  |  |  |  |
|        |                         | I-type                                                                                                                                                                    |              |  |  |  |  |
| addi   | addi \$r1,<br>\$r2, x   | add a register number (\$r2) and an immediate number (x), and store the result in one register (\$r1)                                                                     | immediate    |  |  |  |  |

| rtn    | rtn    | Jump to address stored   |  |
|--------|--------|--------------------------|--|
|        |        | in \$ra.                 |  |
| reboot | reboot | Directly jump to         |  |
|        |        | address 0                |  |
| halt   | halt   | all registers (including |  |
|        |        | PC, the 8 general        |  |
|        |        | purpose registers and    |  |
|        |        | all other registers) in  |  |
|        |        | the processor are        |  |
|        |        | disabled (so the         |  |
|        |        | processor halts).        |  |