**Table 1. Core Instruction Set** 

| NAME                                     | MNE-  | FOR-<br>MAT | OPERATION                                                   | OPCODE/FUNCT |  |  |
|------------------------------------------|-------|-------------|-------------------------------------------------------------|--------------|--|--|
|                                          | MONIC |             | (in Verilog)                                                | (Hex)        |  |  |
| Add <sup>(1)</sup>                       | add   | R           | R[rd]=R[rs]+R[rt]                                           | 0/20         |  |  |
| Add Unsigned                             | addu  | R           | R[rd]=R[rs]+R[rt]                                           | 0/21         |  |  |
| Subtract <sup>(1)</sup>                  | sub   | R           | R[rd]=R[rs]-R[rt]                                           | 0/22         |  |  |
| And                                      | and   | R           | R[rd]=R[rs]&R[rt]                                           | 0/24         |  |  |
| Or                                       | or    | R           | R[rd]=R[rs] R[rt]                                           | 0/25         |  |  |
| Shift Left Logical                       | sll   | R           | R[rd]=R[rs]< <shamt< td=""><td>0/00</td></shamt<>           | 0/00         |  |  |
| Shift Right Logical                      | srl   | R           | R[rd]=R[rs]>>shamt                                          | 0/02         |  |  |
| Set Less Than                            | slt   | R           | R[rd]=(R[rs] <r[rt])?1:0< td=""><td>0/2a</td></r[rt])?1:0<> | 0/2a         |  |  |
| Add Immediate <sup>(1)(2)</sup>          | addi  | I           | R[rd]=R[rs]+SignExtImm                                      | 8            |  |  |
| Add Immediate<br>Unsigned <sup>(2)</sup> | addiu | I           | R[rd]=R[rs]+SignExtImm                                      | 9            |  |  |
| And Immediate <sup>(3)</sup>             | andi  | I           | R[rd]=R[rs]&ZeroExtImm                                      | С            |  |  |
| Or Immediate <sup>(3)</sup>              | ori   | I           | R[rd]=R[rs] ZeroExtImm                                      | d            |  |  |
| Load Upper<br>Immediate                  | lui   | I           | R[rd]={imm,16'd0}                                           | f            |  |  |
| Load Word <sup>(2)</sup>                 | lw    | I           | R[rt]=M[R[rs]+SignExtImm]                                   | 23           |  |  |
| Store Word <sup>(2)</sup>                | SW    | I           | M[R[rs]+SignExtImm]=R[rt]                                   | 2b           |  |  |
| Branch On Equal <sup>(4)</sup>           | beq   | I           | If(R[rs]==R[rt])PC=PC+4+BranchAddr                          | 4            |  |  |
| Jump <sup>(5)</sup>                      | j     | J           | PC=JumpAddr                                                 | 2            |  |  |

## Note:

- (1) May cause overflow exception
- (2) SignExtImm={16{immediate[15]}, immediate}
- (3) ZeroExtImm={16{1'b0}, immediate}

- (4) BranchAddr={14{imeediate[15]}, immediate, 2'b00}
- (5) JumpAddr = {PC[31:28], address, 2'b00}

| NAME                                           | MNE-<br>MONIC | OPERATION    | BIT FIELD (Hex) |         |         |         |        |
|------------------------------------------------|---------------|--------------|-----------------|---------|---------|---------|--------|
|                                                | Wientie       | (in Verilog) | [31-26]         | [25-21] | [20-16] | [15-11] | [10-0] |
| Move From co-<br>Processor                     | mfc0          | R[rt]=CP[rd] | 10              | 0       | Rt      | Rd      | 0      |
| Move From co-<br>Processor                     | mtc0          | CP[rd]=R[rt] | 10              | 4       | Rt      | Rd      | 0      |
| Return from Interrupt<br>Service Routine (ISR) | eret          | PC=CP[epc]   | 10              | 10      | 0       | 0       | 10     |