# MIPS I

The first version of the MIPS architecture was designed by MIPS Computer Systems for its R2000microprocessor, the first MIPS implementation. Both MIPS and the R2000 were introduced together in 1985. When MIPS II was introduced, MIPS was renamed MIPS I to distinguish it from the new version. [3]:32

MIPS is a <u>load/store</u> architecture (also known as a *register-register architecture*); except for the load/store instructions used to access memory, all instructions operate on the registers.

# **Registers**

MIPS I has thirty-two 32-bit general-purpose registers (GPR). Register \$0 is hardwired to zero and writes to it are discarded. Register \$31 is the link register. For integer multiplication and division instructions, which run asynchronously from other instructions, a pair of 32-bit registers, *HI* and *LO*, are provided. There is a small set of instructions for copying data between the general-purpose registers and the HI/LO registers.

The program counter has 32 bits. The two low-order bits always contain zero since MIPS I instructions are 32 bits long and are aligned to their natural word boundaries.

#### Instruction formats

Instructions are divided into three types: R, I and J. Every instruction starts with a 6-bit opcode. In addition to the opcode, R-type instructions specify three registers, a shift amount field, and a function field; I-type instructions specify two registers and a 16-bit immediate value; J-type instructions follow the opcode with a 26-bit jump target. [2]:A-174

The following are the three formats used for the core instruction set:

| Туре | -31-       | format (bits) -0- |        |                |           |  |  |  |  |  |
|------|------------|-------------------|--------|----------------|-----------|--|--|--|--|--|
| R    | opcode (6) | rs (5)            | rt (5) | rd (5)         | funct (6) |  |  |  |  |  |
| ı    | opcode (6) | rs (5)            | rt (5) | immediate (16) |           |  |  |  |  |  |
| J    | opcode (6) | address (26)      |        |                |           |  |  |  |  |  |

### **CPU** instructions

#### Loads and stores

MIPS I has instructions that load and store 8-bit bytes, 16-bit halfwords, and 32-bit words. Only one <u>addressing mode</u> is supported: base + displacement. Since MIPS I is a 32-bit architecture, loading quantities fewer than 32 bits requires the datum to be either signed- or zero-extended to 32 bits. The load instructions suffixed by "unsigned" perform zero extension; otherwise sign extension is performed. Load instructions source the base from the contents of a GPR (rs) and write the result to another GPR (rt). Store instructions source the base from the contents of a GPR (rs) and the store data from another GPR (rt). All load and store instructions compute the memory address by summing the

base with the sign-extended 16-bit immediate. MIPS I requires all memory accesses to be aligned to their natural word boundaries, otherwise an exception is signaled. To support efficient unaligned memory accesses, there are load/store word instructions suffixed by "left" or "right". All load instructions are followed by a <u>load delay slot</u>. The instruction in the load delay slot cannot use the data loaded by the load instruction. The load delay slot can be filled with an instruction that is not dependent on the load; a nop is substituted if such an instruction cannot be found.

| Instruction name       | Mnemonic | Format | Encoding         |    |    |        |  |  |  |
|------------------------|----------|--------|------------------|----|----|--------|--|--|--|
| Load Byte              | LB       | I      | 32 <sub>10</sub> | rs | rt | offset |  |  |  |
| Load Halfword          | LH       | I      | 33 <sub>10</sub> | rs | rt | offset |  |  |  |
| Load Word Left         | LWL      | I      | 34 <sub>10</sub> | rs | rt | offset |  |  |  |
| Load Word              | LW       | I      | 35 <sub>10</sub> | rs | rt | offset |  |  |  |
| Load Byte Unsigned     | LBU      | I      | 36 <sub>10</sub> | rs | rt | offset |  |  |  |
| Load Halfword Unsigned | LHU      | I      | 37 <sub>10</sub> | rs | rt | offset |  |  |  |
| Load Word Right        | LWR      | I      | 38 <sub>10</sub> | rs | rt | offset |  |  |  |
| Store Byte             | SB       | I      | 40 <sub>10</sub> | rs | rt | offset |  |  |  |
| Store Halfword         | SH       | I      | 41 <sub>10</sub> | rs | rt | offset |  |  |  |
| Store Word Left        | SWL      | I      | 42 <sub>10</sub> | rs | rt | offset |  |  |  |
| Store Word             | SW       | I      | 43 <sub>10</sub> | rs | rt | offset |  |  |  |
| Store Word Right       | SWR      | I      | 46 <sub>10</sub> | rs | rt | offset |  |  |  |

### **ALU**

MIPS I has instructions to perform addition and subtraction. These instructions source their operands from two GPRs (rs and rt), and write the result to a third GPR (rd). Alternatively, addition can source one of the operands from a 16-bit immediate (which is sign-extended to 32 bits). The instructions for addition and subtraction have two variants: by default, an exception is signaled if the result overflows; instructions with the "unsigned" suffix do not signal an exception. The overflow check interprets the result as a 32-bit two's complement integer.

MIPS I has instructions to perform <u>bitwise</u> logical AND, OR, XOR, and NOR. These instructions source their operands from two GPRs and write the result to a third GPR. The AND, OR, and XOR instructions can alternatively source one of the operands from a 16-bit immediate (which is zero-extended to 32 bits).

The Set on *relation* instructions write one or zero to the destination register if the specified relation is true or false. These instructions source their operands from two GPRs or one GPR and a 16-bit immediate (which is sign-extended to 32 bits), and write the result to a third GPR. By default, the operands are interpreted as signed integers. The variants of these instructions that are suffixed with "unsigned" interpret the operands as unsigned integers (even those that source an operand from the sign-extended 16-bit immediate).

The Load Immediate Upper instruction copies the 16-bit immediate into the high-order 16 bits of a GPR. It is used in conjunction with the Or Immediate instruction to load a 32-bit immediate into a register.

| Instruction name                       | Mnemonic | Format | Encoding         |                 |     |           |                 |                  |  |
|----------------------------------------|----------|--------|------------------|-----------------|-----|-----------|-----------------|------------------|--|
| Add                                    | ADD      | R      | 0 <sub>10</sub>  | rs              | rt  | rd        | 0 <sub>10</sub> | 32 <sub>10</sub> |  |
| Add Unsigned                           | ADDU     | R      | 0 <sub>10</sub>  | rs              | rt  | rd        | 0 <sub>10</sub> | 33 <sub>10</sub> |  |
| Subtract                               | SUB      | R      | 0 <sub>10</sub>  | rs              | rt  | rd        | 0 <sub>10</sub> | 34 <sub>10</sub> |  |
| Subtract Unsigned                      | SUBU     | R      | 0 <sub>10</sub>  | rs              | rt  | rd        | 0 <sub>10</sub> | 35 <sub>10</sub> |  |
| And                                    | AND      | R      | 0 <sub>10</sub>  | rs              | rt  | rd        | 0 <sub>10</sub> | 36 <sub>10</sub> |  |
| Or                                     | OR       | R      | 0 <sub>10</sub>  | rs              | rt  | rd        | 0 <sub>10</sub> | 37 <sub>10</sub> |  |
| Exclusive Or                           | XOR      | R      | 0 <sub>10</sub>  | rs              | rt  | rd        | 0 <sub>10</sub> | 38 <sub>10</sub> |  |
| Nor                                    | NOR      | R      | 0 <sub>10</sub>  | rs              | rt  | rd        | 0 <sub>10</sub> | 39 <sub>10</sub> |  |
| Set on Less Than                       | SLT      | R      | 0 <sub>10</sub>  | rs              | rt  | rd        | 0 <sub>10</sub> | 42 <sub>10</sub> |  |
| Set on Less Than<br>Unsigned           | SLTU     | R      | 0 <sub>10</sub>  | rs              | rt  | rd        | 0 <sub>10</sub> | 43 <sub>10</sub> |  |
| Add Immediate                          | ADDI     | I      | 8 <sub>10</sub>  | rs              | rd  | immediate |                 |                  |  |
| Add Immediate<br>Unsigned              | ADDIU    | I      | 9 <sub>10</sub>  | \$s             | \$d | immediate |                 |                  |  |
| Set on Less Than<br>Immediate          | SLTI     | I      | 10 <sub>10</sub> | \$s             | \$d |           | immediate       | •                |  |
| Set on Less Than<br>Immediate Unsigned | SLTIU    | I      | 11 <sub>10</sub> | \$s             | \$d | immediate |                 |                  |  |
| And Immediate                          | ANDI     | I      | 12 <sub>10</sub> | \$s             | \$d | immediate |                 |                  |  |
| Or Immediate                           | ORI      | 1      | 13 <sub>10</sub> | \$s             | \$d | immediate |                 |                  |  |
| Exclusive Or Immediate                 | XORI     | I      | 14 <sub>10</sub> | \$s             | \$d | immediate |                 |                  |  |
| Load Upper Immediate                   | LUI      | I      | 15 <sub>10</sub> | 0 <sub>10</sub> | \$d | immediate |                 |                  |  |

### **Shifts**

MIPS I has instructions to perform left and right logical shifts and right arithmetic shifts. The operand is obtained from a GPR (rt), and the result is written to another GPR (rd). The shift distance is obtained from either a GPR (rs) or a 5-bit "shift amount" (the "sa" field).

| Instruction name                | Mnemonic | Format | Encoding        |                 |    |    |                 |                 |  |
|---------------------------------|----------|--------|-----------------|-----------------|----|----|-----------------|-----------------|--|
| Shift Left Logical              | SLL      | R      | 0 <sub>10</sub> | 0 <sub>10</sub> | rt | rd | sa              | 0 <sub>10</sub> |  |
| Shift Right Logical             | SRL      | R      | 0 <sub>10</sub> | 0 <sub>10</sub> | rt | rd | sa              | 2 <sub>10</sub> |  |
| Shift Right Arithmetic          | SRA      | R      | 0 <sub>10</sub> | 0 <sub>10</sub> | rt | rd | sa              | 3 <sub>10</sub> |  |
| Shift Left Logical<br>Variable  | SLLV     | R      | 0 <sub>10</sub> | rs              | rt | rd | 0 <sub>10</sub> | 4 <sub>10</sub> |  |
| Shift Right Logical<br>Variable | SRLV     | R      | 0 <sub>10</sub> | rs              | rt | rd | 0 <sub>10</sub> | 6 <sub>10</sub> |  |
| Shift Right Arithmetic Variable | SRAV     | R      | 0 <sub>10</sub> | rs              | rt | rd | 0 <sub>10</sub> | 7 <sub>10</sub> |  |

#### **Multiplication and division**

MIPS I has instructions for signed and unsigned integer multiplication and division. These instructions source their operands from two GPRs and write their results to a pair of 32-bit registers called HI and LO, since they may execute separately from (and concurrently with) the other CPU instructions. For multiplication, the high- and low-order halves of the 64-bit product is written to HI and LO (respectively). For division, the quotient is written to LO and the remainder to HI. To access the results, a pair of instructions (Move from HI and Move from LO) is provided to copy the contents of HI or LO to a GPR. These instructions are interlocked: reads of HI and LO do not proceed past an unfinished arithmetic instruction that will write to HI and LO. Another pair of instructions (Move to HI or Move to LO) copies the contents of a GPR to HI and LO. These instructions are used to restore HI and LO to their original state after exception handling. Instructions that read HI or LO must be separated by two instructions that do not write to HI or LO.

| Instruction name  | Mnemonic | Format | Encoding        |                 |                 |                 |                 |                  |  |  |
|-------------------|----------|--------|-----------------|-----------------|-----------------|-----------------|-----------------|------------------|--|--|
| Move from HI      | MFHI     | R      | 0 <sub>10</sub> | 0 <sub>10</sub> | 0 <sub>10</sub> | rd              | 0 <sub>10</sub> | 16 <sub>10</sub> |  |  |
| Move to HI        | MTHI     | R      | 0 <sub>10</sub> | rs              | 0 <sub>10</sub> | 0 <sub>10</sub> | 0 <sub>10</sub> | 17 <sub>10</sub> |  |  |
| Move from LO      | MFLO     | R      | 0 <sub>10</sub> | 0 <sub>10</sub> | 0 <sub>10</sub> | rd              | 0 <sub>10</sub> | 18 <sub>10</sub> |  |  |
| Move to LO        | MTLO     | R      | 0 <sub>10</sub> | rs              | 0 <sub>10</sub> | 0 <sub>10</sub> | 0 <sub>10</sub> | 19 <sub>10</sub> |  |  |
| Multiply          | MULT     | R      | 0 <sub>10</sub> | rs              | rt              | 0 <sub>10</sub> | 0 <sub>10</sub> | 24 <sub>10</sub> |  |  |
| Multiply Unsigned | MULTU    | R      | 0 <sub>10</sub> | rs              | rt              | 0 <sub>10</sub> | 0 <sub>10</sub> | 25 <sub>10</sub> |  |  |
| Divide            | DIV      | R      | 0 <sub>10</sub> | rs              | rt              | 0 <sub>10</sub> | 0 <sub>10</sub> | 26 <sub>10</sub> |  |  |
| Divide Unsigned   | DIVU     | R      | 0 <sub>10</sub> | rs              | rt              | 0 <sub>10</sub> | 0 <sub>10</sub> | 27 <sub>10</sub> |  |  |

#### Jump and branch

All MIPS I control flow instructions are followed by a <u>branch delay slot</u>. Unless the branch delay slot is filled by an instruction performing useful work, an nop is substituted. MIPS I branch instructions compare the contents of a GPR (rs) against zero or another GPR (rt) as signed integers and branch if the specified condition is true. Control is transferred to the address computed by shifting the 16-bit offset left by two bits, sign-extending the 18-bit result, and adding the 32-bit sign-extended result to the sum of the program counter (instruction address) and 8<sub>10</sub>. Jumps have two versions: absolute and

register-indirect. Absolute jumps ("Jump" and "Jump and Link") compute the address control is transferred to by shifting the 26-bit instr\_index left by two bits and concatenating the 28-bit result with the four high-order bits of the address of the instruction in the branch delay slot. Register-indirect jumps transfer control to the instruction at the address sourced from a GPR (rs). The address sourced from the GPR must be word-aligned, else an exception is signaled after the instruction in the branch delay slot is executed. Branch and jump instructions that link (except for "Jump and Link Register") save the return address to GPR 31. The "Jump and Link Register" instruction permits the return address to be saved to any writable GPR.

| Instruction name                                       | Mnemonic | Format |                 | Encoding |                 |                                    |                 |                 |  |
|--------------------------------------------------------|----------|--------|-----------------|----------|-----------------|------------------------------------|-----------------|-----------------|--|
| Jump Register                                          | JR       | R      | 0 <sub>10</sub> | rs       | 0 <sub>10</sub> | 0 <sub>10</sub>                    | 0 <sub>10</sub> | 8 <sub>10</sub> |  |
| Jump and Link<br>Register                              | JALR     | R      | 0 <sub>10</sub> | rs       | 0 <sub>10</sub> | rd 0 <sub>10</sub> 9 <sub>10</sub> |                 | 9 <sub>10</sub> |  |
| Branch on Less Than<br>Zero                            | BLTZ     | I      | 1 <sub>10</sub> | rs       | 0 <sub>10</sub> | offset                             |                 |                 |  |
| Branch on Greater<br>Than or Equal to Zero             | BGEZ     | I      | 1 <sub>10</sub> | rs       | 1 <sub>10</sub> | offset                             |                 |                 |  |
| Branch on Less Than<br>Zero and Link                   | BLTZAL   | I      | 1 <sub>10</sub> | rs       | 16              | offset                             |                 |                 |  |
| Branch on Greater<br>Than or Equal to Zero<br>and Link | BGEZAL   | I      | 1 <sub>10</sub> | rs       | 17              | offset                             |                 |                 |  |
| Jump                                                   | J        | J      | 2 <sub>10</sub> |          | instr_index     |                                    |                 |                 |  |
| Jump and Link                                          | JAL      | J      | 3 <sub>10</sub> |          |                 | instr_inde                         | х               |                 |  |
| Branch on Equal                                        | BEQ      | I      | 4 <sub>10</sub> | rs       | rt              |                                    | offset          |                 |  |
| Branch on Not Equal                                    | BNE      | I      | 5 <sub>10</sub> | rs       | rt              | offset                             |                 |                 |  |
| Branch on Less Than or Equal to Zero                   | BLEZ     | I      | 6 <sub>10</sub> | rs       | 0 <sub>10</sub> | offset                             |                 |                 |  |
| Branch on Greater<br>Than Zero                         | BGTZ     | I      | 7 <sub>10</sub> | rs       | 0 <sub>10</sub> | offset                             |                 |                 |  |

### **Exception**

MIPS I has two instructions for software to signal an exception: System Call and Breakpoint. System Call is used by user mode software to make kernel calls; and Breakpoint is used to transfer control to a debugger via the kernel's exception handler. Both instructions have a 20-bit Code field that can contain operating environment-specific information for the exception handler.

| Instruction name | Mnemonic | Format | Encoding        |      |                  |  |  |  |  |
|------------------|----------|--------|-----------------|------|------------------|--|--|--|--|
| System Call      | SYSCALL  | ?      | 0 <sub>10</sub> | Code | 12 <sub>10</sub> |  |  |  |  |
| Breakpoint       | BREAK    | ?      | 0 <sub>10</sub> | Code | 13 <sub>10</sub> |  |  |  |  |