

# MIPS Reference Data

(1)

| CORE INSTRUCTION SET        |       | OPCODE / FUNCT | FOR-NAME, MNEMONIC                                   | MAT   | OPERATION (in Verilog) |
|-----------------------------|-------|----------------|------------------------------------------------------|-------|------------------------|
| Add                         | add   | R              | R[rd] = R[rs] + R[rt]                                | (1)   | 0 / 20 <sub>hex</sub>  |
| Add Immediate               | addi  | I              | R[rt] = R[rs] + SignExtImm                           | (1,2) | 8 <sub>hex</sub>       |
| Add Imm. Unsigned           | addiu | I              | R[rt] = R[rs] + SignExtImm                           | (2)   | 9 <sub>hex</sub>       |
| Add Unsigned                | addu  | R              | R[rd] = R[rs] + R[rt]                                |       | 0 / 21 <sub>hex</sub>  |
| And                         | and   | R              | R[rd] = R[rs] & R[rt]                                |       | 0 / 24 <sub>hex</sub>  |
| And Immediate               | andi  | I              | R[rt] = R[rs] & ZeroExtImm                           | (3)   | c <sub>hex</sub>       |
| Branch On Equal             | beq   | I              | if(R[rs]==R[rt]) PC=PC+4+BranchAddr                  | (4)   | 4 <sub>hex</sub>       |
| Branch On Not Equal         | bne   | I              | if(R[rs]!=R[rt]) PC=PC+4+BranchAddr                  | (4)   | 5 <sub>hex</sub>       |
| Jump                        | j     | J              | PC=JumpAddr                                          | (5)   | 2 <sub>hex</sub>       |
| Jump And Link               | jal   | J              | R[31]=PC+8;PC=JumpAddr                               | (5)   | 3 <sub>hex</sub>       |
| Jump Register               | jr    | R              | PC=R[rs]                                             |       | 0 / 08 <sub>hex</sub>  |
| Load Byte Unsigned          | lbu   | I              | R[rt]={24'b0,M[R[rs]]+SignExtImm}(7:0)               | (2)   | 24 <sub>hex</sub>      |
| Load Halfword Unsigned      | lhu   | I              | R[rt]={16'b0,M[R[rs]]+SignExtImm}(15:0)              | (2)   | 25 <sub>hex</sub>      |
| Load Linked                 | ll    | I              | R[rt]=M[R[rs]]+SignExtImm                            | (2,7) | 30 <sub>hex</sub>      |
| Load Upper Imm.             | lui   | I              | R[rt]={imm, 16'b0}                                   |       | f <sub>hex</sub>       |
| Load Word                   | lw    | I              | R[rt]=M[R[rs]]+SignExtImm                            | (2)   | 23 <sub>hex</sub>      |
| Nor                         | nor   | R              | R[rd] = ~ (R[rs]   R[rt])                            |       | 0 / 27 <sub>hex</sub>  |
| Or                          | or    | R              | R[rd] = R[rs]   R[rt]                                |       | 0 / 25 <sub>hex</sub>  |
| Or Immediate                | ori   | I              | R[rt] = R[rs]   ZeroExtImm                           | (3)   | d <sub>hex</sub>       |
| Set Less Than               | slt   | R              | R[rd]=(R[rs] < R[rt]) ? 1 : 0                        |       | 0 / 2a <sub>hex</sub>  |
| Set Less Than Imm.          | slti  | I              | R[rt]=(R[rs] < SignExtImm) ? 1 : 0                   | (2)   | a <sub>hex</sub>       |
| Set Less Than Imm. Unsigned | sltiu | I              | R[rt]=(R[rs] < SignExtImm) ? 1 : 0                   | (2,6) | b <sub>hex</sub>       |
| Set Less Than Unsigned      | sltu  | R              | R[rd]=(R[rs] < R[rt]) ? 1 : 0                        | (6)   | 0 / 2b <sub>hex</sub>  |
| Shift Left Logical          | sll   | R              | R[rd]=R[rt]<>shamt                                   |       | 0 / 00 <sub>hex</sub>  |
| Shift Right Logical         | srl   | R              | R[rd]=R[rt]>>shamt                                   |       | 0 / 02 <sub>hex</sub>  |
| Store Byte                  | sb    | I              | M[R[rs]]+SignExtImm](7:0)=R[rt](7:0)                 | (2)   | 28 <sub>hex</sub>      |
| Store Conditional           | sc    | I              | M[R[rs]]+SignExtImm] = R[rt]; R[rt]=(atomic) ? 1 : 0 | (2,7) | 38 <sub>hex</sub>      |
| Store Halfword              | sh    | I              | M[R[rs]]+SignExtImm](15:0)=R[rt](15:0)               | (2)   | 29 <sub>hex</sub>      |
| Store Word                  | sw    | I              | M[R[rs]]+SignExtImm] = R[rt]                         | (2)   | 2b <sub>hex</sub>      |
| Subtract                    | sub   | R              | R[rd] = R[rs] - R[rt]                                | (1)   | 0 / 22 <sub>hex</sub>  |
| Subtract Unsigned           | subu  | R              | R[rd] = R[rs] - R[rt]                                |       | 0 / 23 <sub>hex</sub>  |

- (1) May cause overflow exception
- (2) SignExtImm = { 16'imm[15], immediate }
- (3) ZeroExtImm = { 16'1b'0 }, immediate
- (4) BranchAddr = { 14'imm[15], immediate, 2'b0 }
- (5) JumpAddr = { PC+4[31:28], address, 2'b0 }
- (6) Operands considered unsigned numbers (vs. 2's comp.)
- (7) Atomic test&set pair; R[rt] = 1 if pair atomic, 0 if not atomic

## BASIC INSTRUCTION FORMATS

|   |          |       |       |         |       |           |
|---|----------|-------|-------|---------|-------|-----------|
| R | opcode   | rs    | rt    | rd      | shamt | funct     |
|   | 31 26 25 | 21 20 | 16 15 | 11 10   | 6 5   | 0         |
| I | opcode   | rs    | rt    |         |       | immediate |
|   | 31 26 25 | 21 20 | 16 15 |         |       | 0         |
| J | opcode   |       |       | address |       |           |
|   | 31 26 25 |       |       |         |       | 0         |

Copyright 2009 by Elsevier, Inc., All rights reserved. From Patterson and Hennessy, Computer Organization and Design, 4th ed.

## ARITHMETIC CORE INSTRUCTION SET

(2) OPCODE / FMT / FT / FUNCT / FUNCT (Hex)

| NAME, MNEMONIC     | MAT    | OPERATION                                                      | (Hex)                                |                |
|--------------------|--------|----------------------------------------------------------------|--------------------------------------|----------------|
| Branch On FP True  | bc1t   | FI if(FPcond)PC=PC+4+BranchAddr                                | (4)                                  |                |
| Branch On FP False | bc1f   | FI if(!FPcond)PC=PC+4+BranchAddr                               | (4)                                  |                |
| Divide             | div    | R Lo=R[rs]/R[rt]; Hi=R[rs]%R[rt]                               | 0/-/-/1a                             |                |
| Divide Unsigned    | divu   | R Lo=R[rs]/R[rt]; Hi=R[rs]%R[rt]                               | (6) 0/-/-/1b                         |                |
| FP Add Single      | add.s  | FR F[fd]=F[fs]+F[ft]                                           | 11/10/-/0                            |                |
| FP Add             | add.d  | FR {F[fd],F[fd+1]} = {F[fs],F[fs+1]} + {F[ft],F[ft+1]}         | 11/11/-/0                            |                |
| Double             | c.x.s* | FR FPcond = (F[fs] op F[ft]) ? 1 : 0                           | 11/10/-/y                            |                |
| FP Compare Single  | c.x.d* | FR FPcond = ({F[fs],F[fs+1]} op {F[ft],F[ft+1]}) ? 1 : 0       | 11/11/-/y                            |                |
| Double             | *      | (x is eq, lt, or le) (op is ==, <, or <=) (y is 32, 3c, or 3e) |                                      |                |
| FP Divide Single   | div.s  | FR F[fd] = F[fs] / F[ft]                                       | 11/10/-/3                            |                |
| FP Divide          |        | {F[fd],F[fd+1]} = {F[fs],F[fs+1]} / {F[ft],F[ft+1]}            | 11/11/-/3                            |                |
| Double             | div.d  | FR F[fd] = F[fs] - F[ft]                                       | 11/10/-/1                            |                |
| FP Multiply Single | mul.s  | FR F[fd] = F[fs] * F[ft]                                       | 11/10/-/2                            |                |
| FP Multiply        | mul.d  | FR {F[fd],F[fd+1]} = {F[fs],F[fs+1]} * {F[ft],F[ft+1]}         | 11/11/-/2                            |                |
| Double             |        | F[fd]=F[fs] - F[ft]                                            | 11/11/-/1                            |                |
| FP Subtract Single | sub.s  | FR F[fd]=F[fs] - F[ft]                                         | 11/10/-/1                            |                |
| FP Subtract        | sub.d  | FR {F[fd],F[fd+1]} = {F[fs],F[fs+1]} - {F[ft],F[ft+1]}         | 11/11/-/1                            |                |
| Double             |        | Load FP Single                                                 | lwc1 I F[rt]=M[R[rs]]+SignExtImm     | (2) 31/-/-/-   |
|                    |        | Load FP                                                        | ldc1 I F[rt]=M[R[rs]]+SignExtImm;    | (2) 35/-/-/-   |
|                    |        | Double                                                         | ldc1 I F[rt+1]=M[R[rs]]+SignExtImm+4 |                |
|                    |        | Move From Hi                                                   | mfhi R R[rd]=Hi                      | 0 /--/-/10     |
|                    |        | Move From Lo                                                   | mflo R R[rd]=Lo                      | 0 /--/-/12     |
|                    |        | Move From Control                                              | mfc0 R R[rd]=CR[rs]                  | 10/0/-/0       |
|                    |        | Multiply                                                       | mult R {Hi,Lo} = R[rs] * R[rt]       | 0 /--/-/18     |
|                    |        | Multiply Unsigned                                              | multu R {Hi,Lo} = R[rs] * R[rt]      | (6) 0 /--/-/19 |
|                    |        | Shift Right Arith.                                             | sra R R[rd]=R[rt]>>shamt             | 0 /--/-/3      |
|                    |        | Store FP Single                                                | swc1 I M[R[rs]]+SignExtImm] = F[rt]  | (2) 39/-/-/-   |
|                    |        | Store FP                                                       | sdc1 I M[R[rs]]+SignExtImm] = F[rt]; | (2) 3d/-/-/-   |
|                    |        | Double                                                         | M[R[rs]]+SignExtImm+4] = F[rt+1]     |                |

## FLOATING-POINT INSTRUCTION FORMATS

| FR | opcode   | fmt   | ft    | fs        | fd  | funct |
|----|----------|-------|-------|-----------|-----|-------|
|    | 31 26 25 | 21 20 | 16 15 | 11 10     | 6 5 | 0     |
| FI | opcode   | fmt   | ft    | immediate |     |       |
|    | 31 26 25 | 21 20 | 16 15 |           |     | 0     |

## PSEUDOINSTRUCTION SET

| NAME                         | MNEMONIC | OPERATION                   |
|------------------------------|----------|-----------------------------|
| Branch Less Than             | blt      | if(R[rs]<R[rt]) PC = Label  |
| Branch Greater Than          | bgt      | if(R[rs]>R[rt]) PC = Label  |
| Branch Less Than or Equal    | ble      | if(R[rs]<=R[rt]) PC = Label |
| Branch Greater Than or Equal | bge      | if(R[rs]>=R[rt]) PC = Label |
| Load Immediate               | li       | R[rd] = immediate           |
| Move                         | move     | R[rd] = R[rs]               |

## REGISTER NAME, NUMBER, USE, CALL CONVENTION

| NAME      | NUMBER | USE                                                   | PRESERVED ACROSS A CALL? |
|-----------|--------|-------------------------------------------------------|--------------------------|
| \$zero    | 0      | The Constant Value 0                                  | N.A.                     |
| \$at      | 1      | Assembler Temporary                                   | No                       |
| \$v0-\$v1 | 2-3    | Values for Function Results and Expression Evaluation | No                       |
| \$a0-\$a3 | 4-7    | Arguments                                             | No                       |
| \$t0-\$t7 | 8-15   | Temporaries                                           | No                       |
| \$s0-\$s7 | 16-23  | Saved Temporaries                                     | Yes                      |
| \$t8-\$t9 | 24-25  | Temporaries                                           | No                       |
| \$k0-\$k1 | 26-27  | Reserved for OS Kernel                                | No                       |
| \$gp      | 28     | Global Pointer                                        | Yes                      |
| \$sp      | 29     | Stack Pointer                                         | Yes                      |
| \$fp      | 30     | Frame Pointer                                         | Yes                      |
| \$ra      | 31     | Return Address                                        | No                       |

### OPCODES, BASE CONVERSION, ASCII SYMBOLS

| MIPS (1) | MIPS (2) | MIPS (31:26) | MIPS (5:0) | Binary | Deci-mal | Hexa-deci-mal | ASCII Char-acter | Deci-mal | Hexa-deci-mal | ASCII Char-acter |
|----------|----------|--------------|------------|--------|----------|---------------|------------------|----------|---------------|------------------|
| (1)      | sll      | add.f        | 00 0000    | 0      | 0        | NUL           | 64               | 40       | @             |                  |
|          |          | sub.f        | 00 0001    | 1      | 1        | SOH           | 65               | 41       | A             |                  |
| j        | srl      | mul.f        | 00 0010    | 2      | 2        | STX           | 66               | 42       | B             |                  |
| jal      | sra      | div.f        | 00 0011    | 3      | 3        | ETX           | 67               | 43       | C             |                  |
| beq      | slrv     | sqrt.f       | 00 0100    | 4      | 4        | EOT           | 68               | 44       | D             |                  |
| bne      |          | abs.f        | 00 0101    | 5      | 5        | ENQ           | 69               | 45       | E             |                  |
| blez     | sriv     | mov.f        | 00 0110    | 6      | 6        | ACK           | 70               | 46       | F             |                  |
| bgtz     | srav     | neg.f        | 00 0111    | 7      | 7        | BEL           | 71               | 47       | G             |                  |
| addi     | jr       |              | 00 1000    | 8      | 8        | BS            | 72               | 48       | H             |                  |
| addiu    | jalr     |              | 00 1001    | 9      | 9        | HT            | 73               | 49       | I             |                  |
| slti     | movz     |              | 00 1010    | 10     | a        | LF            | 74               | 4a       | J             |                  |
| sltiu    | movn     |              | 00 1011    | 11     | b        | VT            | 75               | 4b       | K             |                  |
| andi     | syscall  | round.wf     | 00 1100    | 12     | c        | FF            | 76               | 4c       | L             |                  |
| ori      | break    | trunc.wf     | 00 1101    | 13     | d        | CR            | 77               | 4d       | M             |                  |
| xori     |          | ceil.wf      | 00 1110    | 14     | e        | SO            | 78               | 4e       | N             |                  |
| lui      | sync     | floor.wf     | 00 1111    | 15     | f        | SI            | 79               | 4f       | O             |                  |
| (2)      | mfhi     |              | 01 0000    | 16     | 10       | DLE           | 80               | 50       | P             |                  |
| mthi     |          |              | 01 0001    | 17     | 11       | DC1           | 81               | 51       | Q             |                  |
| mflo     | movzf    |              | 01 0010    | 18     | 12       | DC2           | 82               | 52       | R             |                  |
| mtlo     | movnf    |              | 01 0011    | 19     | 13       | DC3           | 83               | 53       | S             |                  |
|          |          |              | 01 0100    | 20     | 14       | DC4           | 84               | 54       | T             |                  |
|          |          |              | 01 0101    | 21     | 15       | NAK           | 85               | 55       | U             |                  |
|          |          |              | 01 0110    | 22     | 16       | SYN           | 86               | 56       | V             |                  |
|          |          |              | 01 0111    | 23     | 17       | ETB           | 87               | 57       | W             |                  |
| mult     |          |              | 01 1000    | 24     | 18       | CAN           | 88               | 58       | X             |                  |
| multu    |          |              | 01 1001    | 25     | 19       | EM            | 89               | 59       | Y             |                  |
| div      |          |              | 01 1010    | 26     | 1a       | SUB           | 90               | 5a       | Z             |                  |
| divu     |          |              | 01 1011    | 27     | 1b       | ESC           | 91               | 5b       | [             |                  |
|          |          |              | 01 1100    | 28     | 1c       | FS            | 92               | 5c       | \             |                  |
|          |          |              | 01 1101    | 29     | 1d       | GS            | 93               | 5d       | ]             |                  |
|          |          |              | 01 1110    | 30     | 1e       | RS            | 94               | 5e       | ^             |                  |
|          |          |              | 01 1111    | 31     | 1f       | US            | 95               | 5f       | -             |                  |
| lb       | add      | cvt.s.f      | 10 0000    | 32     | 20       | Space         | 96               | 60       | -             |                  |
| lh       | addu     | cvt.d.f      | 10 0001    | 33     | 21       | !             | 97               | 61       | a             |                  |
| lw       | sub      |              | 10 0010    | 34     | 22       | "             | 98               | 62       | b             |                  |
| lw       | subu     |              | 10 0011    | 35     | 23       | #             | 99               | 63       | c             |                  |
| lbu      | and      | cvt.w.f      | 10 0100    | 36     | 24       | \$            | 100              | 64       | d             |                  |
| lhu      | or       |              | 10 0101    | 37     | 25       | %             | 101              | 65       | e             |                  |
| lwr      | xor      |              | 10 0110    | 38     | 26       | &             | 102              | 66       | f             |                  |
|          | nor      |              | 10 0111    | 39     | 27       | ,             | 103              | 67       | g             |                  |
| sb       |          |              | 10 1000    | 40     | 28       | (             | 104              | 68       | h             |                  |
| sh       |          |              | 10 1001    | 41     | 29       | )             | 105              | 69       | i             |                  |
| swl      | slt      |              | 10 1010    | 42     | 2a       | *             | 106              | 6a       | j             |                  |
| sw       | sltu     |              | 10 1011    | 43     | 2b       | +             | 107              | 6b       | k             |                  |
|          |          |              | 10 1100    | 44     | 2c       | ,             | 108              | 6c       | l             |                  |
|          |          |              | 10 1101    | 45     | 2d       | -             | 109              | 6d       | m             |                  |
|          |          |              | 10 1110    | 46     | 2e       | .             | 110              | 6e       | n             |                  |
|          |          |              | 10 1111    | 47     | 2f       | /             | 111              | 6f       | o             |                  |
| ll       | tge      | c.f.f        | 11 0000    | 48     | 30       | 0             | 112              | 70       | p             |                  |
| lwc1     | tgeu     | c.unf        | 11 0001    | 49     | 31       | 1             | 113              | 71       | q             |                  |
| lwc2     | tlc      | c.eqf        | 11 0010    | 50     | 32       | 2             | 114              | 72       | r             |                  |
| pref     | tltu     | c.ueqf       | 11 0011    | 51     | 33       | 3             | 115              | 73       | s             |                  |
|          | teq      | c.coltf      | 11 0100    | 52     | 34       | 4             | 116              | 74       | t             |                  |
| ldc1     |          | c.ultf       | 11 0101    | 53     | 35       | 5             | 117              | 75       | u             |                  |
| ldc2     | tne      | c.olef       | 11 0110    | 54     | 36       | 6             | 118              | 76       | v             |                  |
|          |          | c.ulef       | 11 0111    | 55     | 37       | 7             | 119              | 77       | w             |                  |
| sc       |          | c.ssf        | 11 1000    | 56     | 38       | 8             | 120              | 78       | x             |                  |
| swc1     |          | c.nglef      | 11 1001    | 57     | 39       | 9             | 121              | 79       | y             |                  |
| swc2     |          | c.seqf       | 11 1010    | 58     | 3a       | :             | 122              | 7a       | z             |                  |
|          |          | c.nglf       | 11 1011    | 59     | 3b       | ;             | 123              | 7b       | {             |                  |
| sdc1     |          | c.lt.f       | 11 1100    | 60     | 3c       | <             | 124              | 7c       | -             |                  |
| sdc2     |          | c.ng.e       | 11 1101    | 61     | 3d       | =             | 125              | 7d       | }             |                  |
|          |          | c.le.f       | 11 1110    | 62     | 3e       | >             | 126              | 7e       | ~             |                  |
|          |          | c.ngt.f      | 11 1111    | 63     | 3f       | ?             | 127              | 7f       | DEL           |                  |

(1) opcode(31:26) == 0  
 (2) opcode(31:26) == 17<sub>10</sub> (11<sub>hex</sub>); if fmt(25:21) == 16<sub>10</sub> (10<sub>hex</sub>) f = s (single);  
 if fmt(25:21) == 17<sub>10</sub> (11<sub>hex</sub>) f = d (double)

(3)

### IEEE 754 FLOATING-POINT STANDARD

$$(-1)^S \times (1 + \text{Fraction}) \times 2^{(\text{Exponent} - \text{Bias})}$$

where Single Precision Bias = 127,  
 Double Precision Bias = 1023.

### IEEE Single Precision and Double Precision Formats:

### IEEE 754 Symbols

| Exponent     | Fraction | Object             |
|--------------|----------|--------------------|
| 0            | 0        | $\pm 0$            |
| 0            | $\neq 0$ | $\pm$ Denorm       |
| 1 to MAX - 1 | anything | $\pm$ Fl. Pt. Num. |
| MAX          | 0        | $\pm\infty$        |
| MAX          | $\neq 0$ | NaN                |

S.P. MAX = 255, D.P. MAX = 2047

### MEMORY ALLOCATION



### STACK FRAME



### DATA ALIGNMENT

| Double Word                                                        |      |          |      |          |      |          |      |
|--------------------------------------------------------------------|------|----------|------|----------|------|----------|------|
| Word                                                               |      |          |      | Word     |      |          |      |
| Halfword                                                           |      | Halfword |      | Halfword |      | Halfword |      |
| Byte                                                               | Byte | Byte     | Byte | Byte     | Byte | Byte     | Byte |
| 0                                                                  | 1    | 2        | 3    | 4        | 5    | 6        | 7    |
| Value of three least significant bits of byte address (Big Endian) |      |          |      |          |      |          |      |

### EXCEPTION CONTROL REGISTERS: CAUSE AND STATUS



BD = Branch Delay, UM = User Mode, EL = Exception Level, IE = Interrupt Enable

### EXCEPTION CODES

| Number | Name | Cause of Exception                                  | Number | Name | Cause of Exception             |
|--------|------|-----------------------------------------------------|--------|------|--------------------------------|
| 0      | Int  | Interrupt (hardware)                                | 9      | Bp   | Breakpoint Exception           |
| 4      | AdEL | Address Error Exception (load or instruction fetch) | 10     | RI   | Reserved Instruction Exception |
| 5      | AdES | Address Error Exception (store)                     | 11     | CpU  | Coprocessor Unimplemented      |
| 6      | IBE  | Bus Error on Instruction Fetch                      | 12     | Ov   | Arithmetic Overflow Exception  |
| 7      | DBE  | Bus Error on Load or Store                          | 13     | Tr   | Trap                           |
| 8      | Sys  | Syscall Exception                                   | 15     | FPE  | Floating Point Exception       |

### SIZE PREFIXES (10<sup>x</sup> for Disk, Communication; 2<sup>x</sup> for Memory)

| SI Size          | Prefix | Symbol | IEC Size        | Prefix | Symbol |
|------------------|--------|--------|-----------------|--------|--------|
| 10 <sup>3</sup>  | Kilo-  | K      | 2 <sup>10</sup> | Kibi-  | Ki     |
| 10 <sup>6</sup>  | Mega-  | M      | 2 <sup>20</sup> | Mebi-  | Mi     |
| 10 <sup>9</sup>  | Giga-  | G      | 2 <sup>30</sup> | Gibi-  | Gi     |
| 10 <sup>12</sup> | Tera-  | T      | 2 <sup>40</sup> | Tebi-  | Ti     |
| 10 <sup>15</sup> | Peta-  | P      | 2 <sup>50</sup> | Pebi-  | Pi     |
| 10 <sup>18</sup> | Exa-   | E      | 2 <sup>60</sup> | Exbi-  | Ei     |
| 10 <sup>21</sup> | Zetta- | Z      | 2 <sup>70</sup> | Zebi-  | Zi     |
| 10 <sup>24</sup> | Yotta- | Y      | 2 <sup>80</sup> | Yobi-  | Yi     |

| R-type instructions                                                                                                                                                                                                    | I-type instructions                                                                                                                                                                                                                                                                    | J-type instructions                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|
| <b>add \$rd, \$rs, \$rt</b><br><b>sub \$rd, \$rs, \$rt</b><br><b>or \$rd, \$rs, \$rt</b><br><b>and \$rd, \$rs, \$rt</b><br><b>sll \$rd, \$rt, shamt</b><br><b>srl \$rd, \$rt, shamt</b><br><b>slt \$rd, \$rs, \$rt</b> | <b>addi \$rt, \$rs, immediate</b><br><b>ori \$rt, \$rs, immediate</b><br><b>andi \$rt, \$rs, immediate</b><br><b>lw \$rt, immediate(\$rs)</b><br><b>sw \$rt, immediate(\$rs)</b><br><b>lui \$rt, immediate</b><br><b>beq \$rt, \$rs, immediate</b><br><b>bne \$rt, \$rs, immediate</b> | <b>jal address</b><br><b>jr address</b><br><b>j address</b> |