# A 7 CPU Instruction Formats

A CPU instruction is a single 32-bit aligned word. The major instruction formats are shown in Figure A-10.

I-Type (Immediate).



J-Type (Jump).



R-Type (Register).



| opcode      | 6-bit primary operation code                                                                                                                                        |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rd          | 5-bit destination register specifier                                                                                                                                |
| rs          | 5-bit source register specifier                                                                                                                                     |
| rt          | 5-bit target (source/destination) register specifier or used to specify functions within the primary opcode value <i>REGIMM</i>                                     |
| immediate   | 16-bit signed immediate used for: logical operands, arithmetic signed operands, load/store address byte offsets, PC-relative branch signed instruction displacement |
| instr_index | 26-bit index shifted left two bits to supply the low-order 28 bits of the jump target address.                                                                      |
| sa          | 5-bit shift amount                                                                                                                                                  |
| function    | 6-bit function field used to specify functions within the primary operation code value <i>SPECIAL</i> .                                                             |

Figure A-10 CPU Instruction Formats

# A 8 CPU Instruction Encoding

This section describes the encoding of user-level, i.e. non-privileged, CPU instructions for the four levels of the MIPS architecture, MIPS I through MIPS IV. Each architecture level includes the instructions in the previous level; MIPS IV includes all instructions in MIPS I, MIPS II, and MIPS III. This section presents eight different views of the instruction encoding.

- Separate encoding tables for each architecture level.
- A MIPS IV encoding table showing the architecture level at which each opcode was originally defined and subsequently modified (if modified).
- Separate encoding tables for each architecture revision showing the changes made during that revision.

#### A 8.1 Instruction Decode

Instruction field names are printed in **bold** in this section.

The primary **opcode** field is decoded first. Most **opcode** values completely specify an instruction that has an immediate value or offset. **Opcode** values that do not specify an instruction specify an instruction class. Instructions within a class are further specified by values in other fields. The **opcode** values *SPECIAL* and *REGIMM* specify instruction classes. The *COP0*, *COP1*, *COP2*, *COP3*, and *COP1X* instruction classes are not CPU instructions; they are discussed in section A 8.3.

#### A 8.1.1 SPECIAL Instruction Class

The **opcode**=*SPECIAL* instruction class encodes 3-register computational instructions, jump register, and some special purpose instructions. The class is further decoded by examining the **format** field. The **format** values fully specify the CPU instructions; the *MOVCI* instruction class is not a CPU instruction class.

#### A 8.1.2 REGIMM Instruction Class

The **opcode**=*REGIMM* instruction class encodes conditional branch and trap immediate instructions. The class is further decode, and the instructions fully specified, by examining the **rt** field.

## A 8.2 Instruction Subsets of MIPS III and MIPS IV Processors.

MIPS III processors, such as the R4000, R4200, R4300, R4400, and R4600, have a processor mode in which only the MIPS II instructions are valid. The MIPS II encoding table describes the MIPS II-only mode except that the Coprocessor 3 instructions (COP3, LWC3, SWC3, LDC3, SDC3) are not available and cause a Reserved Instruction exception.

<sup>†</sup> An exception to this rule is that the reserved, but never implemented, Coprocessor 3 instructions were removed or changed to another use starting in MIPS III.

MIPS IV processors, such as the R8000 and R10000, have processor modes in which only the MIPS II or MIPS III instructions are valid. The MIPS II encoding table describes the MIPS II-only mode except that the Coprocessor 3 instructions (COP3, LWC3, SWC3, LDC3, SDC3) are not available and cause a Reserved Instruction exception. The MIPS III encoding table describes the MIPS III-only mode.

## A 8.3 Non-CPU Instructions in the Tables

The encoding tables show all values for the field they describe and by doing this they include some entries that are not user-level CPU instructions. The primary opcode table includes coprocessor instruction classes (COP0, COP1, COP2, COP3/COP1X) and coprocessor load/store instructions (LWCx, SWCx, LDCx, SDCx for x=1, 2, or 3). The **opcode**=SPECIAL + function=MOVCI instruction class is an FPU instruction.

### A 8.3.1 Coprocessor 0 - COP0

*COP0* encodes privileged instructions for Coprocessor 0, the System Control Coprocessor. The definition of the System Control Coprocessor is processor-specific and further information on these instructions are not included in this document.

## A 8.3.2 Coprocessor 1 - COP1, COP1X, MOVCI, and CP1 load/store.

Coprocessor 1 is the floating-point unit in the MIPS architecture. *COP1*, *COP1X*, and the (**opcode**=*SPECIAL* + **function**=*MOVCI*) instruction classes encode floating-point instructions. LWC1, SWC1, LDC1, and SDC1 are floating-point loads and stores. The FPU instruction encoding is documented in section B.12.

#### A 8.3.3 Coprocessor 2 - COP2 and CP2 load/store.

Coprocessor 2 is optional and implementation-specific. No standard processor from MIPS has implemented coprocessor 2, but MIPS' semiconductor licensees may have implemented it in a product based on one of the standard MIPS processors. At this time the standard processors are: R2000, R3000, R4000, R4200, R4300, R4400, R4600, R6000, R8000, and R10000.

### A 8.3.4 Coprocessor 3 - COP3 and CP3 load/store.

Coprocessor 3 is optional and implementation-specific in the MIPS I and MIPS II architecture levels. It was removed from MIPS III and later architecture levels. Note that in MIPS IV the *COP3* primary opcode was reused for the *COP1X* instruction class. No standard processor from MIPS has implemented coprocessor 2, but MIPS' semiconductor licensees may have implemented it in a product based on one of the standard MIPS processors. At this time the standard processors are: R2000, R3000, R4000, R4200, R4300, R4400, R6000, R6000, R8000, and R10000.

# A 8.4 CPU Instruction Encoding (MIPS I)

Table A-37 CPU Instruction Encoding - MIPS I Architecture



| op   | code | bits 2826 |          | Instructions | encoded by | pcode field. |     |      |      |
|------|------|-----------|----------|--------------|------------|--------------|-----|------|------|
| ŀ    | oits | 0         | 1        | 2            | 3          | 4            | 5   | 6    | 7    |
| 3129 |      | 000       | 001      | 010          | 011        | 100          | 101 | 110  | 111  |
| 0    | 000  | SPECIAL δ | REGIMM δ | J            | JAL        | BEQ          | BNE | BLEZ | BGTZ |
| 1    | 001  | ADDI      | ADDIU    | SLTI         | SLTIU      | ANDI         | ORI | XORI | LUI  |
| 2    | 010  | СОРО б,л  | СОР1 д,я | СОР2 б,я     | СОРЗ д,л,к | *            | *   | *    | *    |
| 3    | 011  | *         | *        | *            | *          | *            | *   | *    | *    |
| 4    | 100  | LB        | LH       | LWL          | LW         | LBU          | LHU | LWR  | *    |
| 5    | 101  | SB        | SH       | SWL          | SW         | *            | *   | SWR  | *    |
| 6    | 110  | *         | LWC1 π   | LWC2 π       | LWC3 π,κ   | *            | *   | *    | *    |
| 7    | 111  | *         | SWC1 π   | SWC2 π       | SWC3 π,κ   | *            | *   | *    | *    |

| 31 26               | 5        | 0 |
|---------------------|----------|---|
| opcode<br>= SPECIAL | function |   |

| fun | ction | bits 20 |       | Instructions encoded by <b>function</b> field when opcode field = SPECIAL. |      |         |       |      |      |  |  |
|-----|-------|---------|-------|----------------------------------------------------------------------------|------|---------|-------|------|------|--|--|
| ŀ   | oits  | 0       | 1     | 2                                                                          | 3    | 4       | 5     | 6    | 7    |  |  |
| 5   | 53    | 000     | 001   | 010                                                                        | 011  | 100     | 101   | 110  | 111  |  |  |
| 0   | 000   | SLL     | *     | SRL                                                                        | SRA  | SLLV    | *     | SRLV | SRAV |  |  |
| 1   | 001   | JR      | JALR  | *                                                                          | *    | SYSCALL | BREAK | *    | *    |  |  |
| 2   | 010   | MFHI    | MTHI  | MFLO                                                                       | MTLO | *       | *     | *    | *    |  |  |
| 3   | 011   | MULT    | MULTU | DIV                                                                        | DIVU | *       | *     | *    | *    |  |  |
| 4   | 100   | ADD     | ADDU  | SUB                                                                        | SUBU | AND     | OR    | XOR  | NOR  |  |  |
| 5   | 101   | *       | *     | SLT                                                                        | SLTU | *       | *     | *    | *    |  |  |
| 6   | 110   | *       | *     | *                                                                          | *    | *       | *     | *    | *    |  |  |
| 7   | 111   | *       | *     | *                                                                          | *    | *       | *     | *    | *    |  |  |

| 31 26                     | <br>20 | 16 | 0 |  |
|---------------------------|--------|----|---|--|
| opcode<br>= <i>REGIMM</i> | rt     |    |   |  |

|      | rt  | bits 1816 | bits 1816 Instructions encoded by the <b>rt</b> field when opcode field = REGIMM. |     |     |     |     |     |     |  |  |  |
|------|-----|-----------|-----------------------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|--|--|--|
| b    | its | 0         | 1                                                                                 | 2   | 3   | 4   | 5   | 6   | 7   |  |  |  |
| 2019 |     | 000       | 001                                                                               | 010 | 011 | 100 | 101 | 110 | 111 |  |  |  |
| 0    | 00  | BLTZ      | BGEZ                                                                              | +   | †   | +   | +   | †   | +   |  |  |  |
| 1    | 01  | +         | +                                                                                 | +   | +   | +   | +   | +   | +   |  |  |  |
| 2    | 10  | BLTZAL    | BGEZAL                                                                            | +   | +   | +   | +   | +   | +   |  |  |  |
| 3    | 11  | †         | †                                                                                 | +   | +   | +   | +   | +   | +   |  |  |  |

# A 8.5 CPU Instruction Encoding (MIPS II)

Table A-38 CPU Instruction Encoding - MIPS II Architecture



| op | bits 2826 Instructions encoded by <b>opcode</b> field. |           |          |          |            |      |        |        |          |  |
|----|--------------------------------------------------------|-----------|----------|----------|------------|------|--------|--------|----------|--|
| b  | oits                                                   | 0         | 1        | 2        | 3          | 4    | 5      | 6      | 7        |  |
| 31 | 29                                                     | 000       | 001      | 010      | 011        | 100  | 101    | 110    | 111      |  |
| 0  | 000                                                    | SPECIAL 8 | REGIMM δ | J        | JAL        | BEQ  | BNE    | BLEZ   | BGTZ     |  |
| 1  | 001                                                    | ADDI      | ADDIU    | SLTI     | SLTIU      | ANDI | ORI    | XORI   | LUI      |  |
| 2  | 010                                                    | СОРО б,я  | СОР1 д,я | СОР2 б,я | СОРЗ б,л,к | BEQL | BNEL   | BLEZL  | BGTZL    |  |
| 3  | 011                                                    | *         | *        | *        | *          | *    | *      | *      | *        |  |
| 4  | 100                                                    | LB        | LH       | LWL      | LW         | LBU  | LHU    | LWR    | *        |  |
| 5  | 101                                                    | SB        | SH       | SWL      | SW         | *    | *      | SWR    | ρ        |  |
| 6  | 110                                                    | LL        | LWC1 π   | LWC2 π   | LWC3 π,κ   | *    | LDC1 π | LDC2 π | LDC3 π,κ |  |
| 7  | 111                                                    | SC        | SWC1 π   | SWC2 π   | SWC3 π,κ   | *    | SDC1 π | SDC2 π | SDC3 π,κ |  |

| 31 26               | 5 | 5       | 0 |
|---------------------|---|---------|---|
| opcode<br>= SPECIAL |   | functio | n |

| fun | ction | bits 20 |       | Instructions | encoded by | <b>function</b> field | l when opcoo | de field = SPE | ECIAL. |
|-----|-------|---------|-------|--------------|------------|-----------------------|--------------|----------------|--------|
| b   | oits  | 0       | 1     | 2            | 3          | 4                     | 5            | 6              | 7      |
| 5   | 53    | 000     | 001   | 010          | 011        | 100                   | 101          | 110            | 111    |
| 0   | 000   | SLL     | *     | SRL          | SRA        | SLLV                  | *            | SRLV           | SRAV   |
| 1   | 001   | JR      | JALR  | *            | *          | SYSCALL               | BREAK        | *              | SYNC   |
| 2   | 010   | MFHI    | MTHI  | MFLO         | MTLO       | *                     | *            | *              | *      |
| 3   | 011   | MULT    | MULTU | DIV          | DIVU       | *                     | *            | *              | *      |
| 4   | 100   | ADD     | ADDU  | SUB          | SUBU       | AND                   | OR           | XOR            | NOR    |
| 5   | 101   | *       | *     | SLT          | SLTU       | *                     | *            | *              | *      |
| 6   | 110   | TGE     | TGEU  | TLT          | TLTU       | TEQ                   | *            | TNE            | *      |
| 7   | 111   | *       | *     | *            | *          | *                     | *            | *              | *      |

| 31 26                     | 20 | 16 | 0 |
|---------------------------|----|----|---|
| opcode<br>= <i>REGIMM</i> | rt |    |   |

| rt bits 1816 Instructions encoded by the rt field when opc |    |        |              |         |         |      | hen opcode fi | ield = REGIN | ſM. |
|------------------------------------------------------------|----|--------|--------------|---------|---------|------|---------------|--------------|-----|
| bits                                                       |    | 0 1    |              | 2       | 3       | 4    | 5             | 6            | 7   |
| 2019                                                       |    | 000    | 001          | 010     | 011     | 100  | 101           | 110          | 111 |
| 0                                                          | 00 | BLTZ   | BGEZ         | BLTZL   | BGEZL   | *    | *             | *            | *   |
| 1                                                          | 01 | TGEI   | I TGEIU TLTI |         | TLTIU   | TEQI | *             | TNEI         | *   |
| 2                                                          | 10 | BLTZAL | BGEZAL       | BLTZALL | BGEZALL | *    | *             | *            | *   |
| 3                                                          | 11 | *      | *            | *       | *       | *    | *             | *            | *   |

# A 8.6 CPU Instruction Encoding (MIPS III)

Table A-39 CPU Instruction Encoding - MIPS III Architecture



| op | code | bits 2826 |          | Instructions | encoded by | opcode field. |        |        |       |
|----|------|-----------|----------|--------------|------------|---------------|--------|--------|-------|
| b  | oits | 0         | 1        | 2            | 3          | 4             | 5      | 6      | 7     |
| 31 | 29   | 000       | 001      | 010          | 011        | 100           | 101    | 110    | 111   |
| 0  | 000  | SPECIAL δ | REGIMM δ | J            | JAL        | BEQ           | BNE    | BLEZ   | BGTZ  |
| 1  | 001  | ADDI      | ADDIU    | SLTI         | SLTIU      | ANDI          | ORI    | XORI   | LUI   |
| 2  | 010  | СОРО б,л  | СОР1 д,я | СОР2 д,я     | *          | BEQL          | BNEL   | BLEZL  | BGTZL |
| 3  | 011  | DADDI     | DADDIU   | LDL          | LDR        | *             | *      | *      | *     |
| 4  | 100  | LB        | LH       | LWL          | LW         | LBU           | LHU    | LWR    | LWU   |
| 5  | 101  | SB        | SH       | SWL          | SW         | SDL           | SDR    | SWR    | ρ     |
| 6  | 110  | LL        | LWC1 π   | LWC2 π       | *          | LLD           | LDC1 π | LDC2 π | LD    |
| 7  | 111  | SC        | SWC1 π   | SWC2 π       | *          | SCD           | SDC1 π | SDC2 π | SD    |

| _ | 31 26               | 5   | 0     |
|---|---------------------|-----|-------|
|   | opcode<br>= SPECIAL | fun | ction |

| fun  | ction | bits 20 Instructions encoded by <b>function</b> field when opcode field = SPECIAL. |       |      |      |         |        |        |        |  |  |  |
|------|-------|------------------------------------------------------------------------------------|-------|------|------|---------|--------|--------|--------|--|--|--|
| bits |       | 0                                                                                  | 1     | 2    | 3    | 4       | 5      | 6      | 7      |  |  |  |
| 53   |       | 000                                                                                | 001   | 010  | 011  | 100     | 101    | 110    | 111    |  |  |  |
| 0    | 000   | SLL                                                                                | *     | SRL  | SRA  | SLLV    | *      | SRLV   | SRAV   |  |  |  |
| 1    | 001   | JR                                                                                 | JALR  | *    | *    | SYSCALL | BREAK  | *      | SYNC   |  |  |  |
| 2    | 010   | MFHI                                                                               | MTHI  | MFLO | MTLO | DSLLV   | *      | DSRLV  | DSRAV  |  |  |  |
| 3    | 011   | MULT                                                                               | MULTU | DIV  | DIVU | DMULT   | DMULTU | DDIV   | DDIVU  |  |  |  |
| 4    | 100   | ADD                                                                                | ADDU  | SUB  | SUBU | AND     | OR     | XOR    | NOR    |  |  |  |
| 5    | 101   | *                                                                                  | *     | SLT  | SLTU | DADD    | DADDU  | DSUB   | DSUBU  |  |  |  |
| 6    | 110   | TGE                                                                                | TGEU  | TLT  | TLTU | TEQ     | *      | TNE    | *      |  |  |  |
| 7    | 111   | DSLL                                                                               | *     | DSRL | DSRA | DSLL32  | *      | DSRL32 | DSRA32 |  |  |  |

| 31 26                     | <br>20 | 16 | 0 |
|---------------------------|--------|----|---|
| opcode<br>= <i>REGIMM</i> | rt     |    |   |

|    | rt  | bits 1816 |        | Instructions | ield = REGIN | ſΜ.  |     |      |     |
|----|-----|-----------|--------|--------------|--------------|------|-----|------|-----|
| b  | its | 0         | 1      | 2            | 3            | 4    | 5   | 6    | 7   |
| 20 | 19  | 000       | 001    | 010          | 011          | 100  | 101 | 110  | 111 |
| 0  | 00  | BLTZ      | BGEZ   | BLTZL        | BGEZL        | *    | *   | *    | *   |
| 1  | 01  | TGEI      | TGEIU  | TLTI         | TLTIU        | TEQI | *   | TNEI | *   |
| 2  | 10  | BLTZAL    | BGEZAL | BLTZALL      | BGEZALL      | *    | *   | *    | *   |
| 3  | 11  | *         | *      | *            | *            | *    | *   | *    | *   |

# A 8.7 CPU Instruction Encoding (MIPS IV)

Table A-40 CPU Instruction Encoding - MIPS IV Architecture



| op | code | bits 2826 | bits 2826 Instructions encoded by <b>opcode</b> field. |          |           |      |        |        |       |  |  |  |  |  |
|----|------|-----------|--------------------------------------------------------|----------|-----------|------|--------|--------|-------|--|--|--|--|--|
| b  | oits | 0         | 1                                                      | 2        | 3         | 4    | 5      | 6      | 7     |  |  |  |  |  |
| 31 | 29   | 000       | 001                                                    | 010      | 011       | 100  | 101    | 110    | 111   |  |  |  |  |  |
| 0  | 000  | SPECIAL δ | REGIMM δ                                               | J        | JAL       | BEQ  | BNE    | BLEZ   | BGTZ  |  |  |  |  |  |
| 1  | 001  | ADDI      | ADDIU                                                  | SLTI     | SLTIU     | ANDI | ORI    | XORI   | LUI   |  |  |  |  |  |
| 2  | 010  | СОРО б,л  | СОР1 д,я                                               | СОР2 б,л | СОР1Х б,л | BEQL | BNEL   | BLEZL  | BGTZL |  |  |  |  |  |
| 3  | 011  | DADDI     | DADDIU                                                 | LDL      | LDR       |      | *      | *      | *     |  |  |  |  |  |
| 4  | 100  | LB        | LH                                                     | LWL      | LW        | LBU  | LHU    | LWR    | LWU   |  |  |  |  |  |
| 5  | 101  | SB        | SH                                                     | SWL      | SW        | SDL  | SDR    | SWR    | ρ     |  |  |  |  |  |
| 6  | 110  | LL        | LWC1 π                                                 | LWC2 π   | PREF      | LLD  | LDC1 π | LDC2 π | LD    |  |  |  |  |  |
| 7  | 111  | SC        | SWC1 π                                                 | SWC2 π   | *         | SCD  | SDC1 π | SDC2 π | SD    |  |  |  |  |  |

| 31 26               | 6 | 5        | 0 |
|---------------------|---|----------|---|
| opcode<br>= SPECIAL |   | function |   |

| function | bits 20 |           | Instructions encoded by <b>function</b> field when opcode field = SPECIAL. |      |         |        |        |        |  |  |
|----------|---------|-----------|----------------------------------------------------------------------------|------|---------|--------|--------|--------|--|--|
| bits     | 0       | 1         | 2                                                                          | 3    | 4       | 5      | 6      | 7      |  |  |
| 53       | 000     | 001       | 010                                                                        | 011  | 100     | 101    | 110    | 111    |  |  |
| 0 000    | SLL     | MOVCI δ,μ | SRL                                                                        | SRA  | SLLV    | *      | SRLV   | SRAV   |  |  |
| 1 001    | JR      | JALR      | MOVZ                                                                       | MOVN | SYSCALL | BREAK  | *      | SYNC   |  |  |
| 2 010    | MFHI    | MTHI      | MFLO                                                                       | MTLO | DSLLV   | *      | DSRLV  | DSRAV  |  |  |
| 3 011    | MULT    | MULTU     | DIV                                                                        | DIVU | DMULT   | DMULTU | DDIV   | DDIVU  |  |  |
| 4 100    | ADD     | ADDU      | SUB                                                                        | SUBU | AND     | OR     | XOR    | NOR    |  |  |
| 5 101    | *       | *         | SLT                                                                        | SLTU | DADD    | DADDU  | DSUB   | DSUBU  |  |  |
| 6 110    | TGE     | TGEU      | TLT                                                                        | TLTU | TEQ     | *      | TNE    | *      |  |  |
| 7 111    | DSLL    | *         | DSRL                                                                       | DSRA | DSLL32  | *      | DSRL32 | DSRA32 |  |  |

| 31 26              | 20 | 16 | 0 |
|--------------------|----|----|---|
| opcode<br>= REGIMM | rt |    |   |

| rt bits 1816 Instructions encoded by the rt field when o |     |        |        |         |         | hen opcode f | ield = REGIN | ſΜ.  |     |
|----------------------------------------------------------|-----|--------|--------|---------|---------|--------------|--------------|------|-----|
| bits                                                     |     | 0      | 1      | 2       | 3       | 4            | 5            | 6    | 7   |
| 20                                                       | )19 | 000    | 001    | 010     | 011     | 100          | 101          | 110  | 111 |
| 0                                                        | 00  | BLTZ   | BGEZ   | BLTZL   | BGEZL   | *            | *            | *    | *   |
| 1                                                        | 01  | TGEI   | TGEIU  | TLTI    | TLTIU   | TEQI         | *            | TNEI | *   |
| 2                                                        | 10  | BLTZAL | BGEZAL | BLTZALL | BGEZALL | *            | *            | *    | *   |
| 3                                                        | 11  | *      | *      | *       | *       | *            | *            | *    | *   |

Table A-41 Architecture Level in Which CPU Instructions are Defined or Extended.

The architecture level in which each MIPS IVencoding was defined is indicated by a subscript 1, 2, 3, or 4 (for architecture level I, II, III, or IV). If an instruction or instruction class was later extended, the extending level is indicated after the defining level.



| <b>opcode</b> bits 2826 Instructions encoded by <b>opcode</b> field. |      |                   |                         |                   |                    |                   |                   |                    |                    |
|----------------------------------------------------------------------|------|-------------------|-------------------------|-------------------|--------------------|-------------------|-------------------|--------------------|--------------------|
| ŀ                                                                    | oits | 0                 | 1                       | 2                 | 3                  | 4                 | 5                 | 6                  | 7                  |
| 31                                                                   | 129  | 000               | 001                     | 010               | 011                | 100               | 101               | 110                | 111                |
| 0                                                                    | 000  | SPECIAL 1-4       | REGIMM                  | J <sub>1</sub>    | JAL <sub>1</sub>   | BEQ <sub>1</sub>  | BNE 1             | BLEZ <sub>1</sub>  | BGTZ <sub>1</sub>  |
|                                                                      |      |                   | 1,2                     |                   |                    |                   |                   |                    |                    |
| 1                                                                    | 001  | ADDI 1            | ADDIU 1                 | SLTI <sub>1</sub> | SLTIU <sub>1</sub> | ANDI 1            | ORI 1             | XORI 1             | LUI 1              |
| 2                                                                    | 010  | COP0 <sub>1</sub> | COP1 <sub>1,2,3,4</sub> | COP2 <sub>1</sub> | COP1X <sub>4</sub> | BEQL <sub>2</sub> | BNEL <sub>2</sub> | BLEZL <sub>2</sub> | BGTZL <sub>2</sub> |
| 3                                                                    | 011  | DADDI 3           | DADDIU <sub>3</sub>     | LDL <sub>3</sub>  | LDR <sub>3</sub>   | * 1               | * 1               | * 1                | * 1                |
| 4                                                                    | 100  | LB <sub>1</sub>   | LH <sub>1</sub>         | LWL <sub>1</sub>  | LW <sub>1</sub>    | LBU 1             | LHU <sub>1</sub>  | LWR <sub>1</sub>   | LWU <sub>3</sub>   |
| 5                                                                    | 101  | SB <sub>1</sub>   | SH <sub>1</sub>         | SWL <sub>1</sub>  | SW <sub>1</sub>    | SDL <sub>3</sub>  | SDR <sub>3</sub>  | SWR <sub>1</sub>   | ρ2                 |
| 6                                                                    | 110  | LL <sub>2</sub>   | LWC1 <sub>1</sub>       | LWC2 <sub>1</sub> | PREF <sub>4</sub>  | LLD <sub>3</sub>  | LDC1 <sub>2</sub> | LDC2 <sub>2</sub>  | LD <sub>3</sub>    |
| 7                                                                    | 111  | SC <sub>2</sub>   | SWC1 <sub>1</sub>       | SWC2 <sub>1</sub> | *3                 | SCD <sub>3</sub>  | SDC1 <sub>2</sub> | SDC2 <sub>2</sub>  | SD <sub>3</sub>    |



| fun  | ction | etion bits 20 Instructions encoded |                    |                   |                   | by <b>function</b> field when opcode field = SPECIAL. |                     |                     |                     |  |  |
|------|-------|------------------------------------|--------------------|-------------------|-------------------|-------------------------------------------------------|---------------------|---------------------|---------------------|--|--|
| bits |       | 0                                  | 1                  | 2                 | 3                 | 4                                                     | 5                   | 6                   | 7                   |  |  |
| 53   |       | 000                                | 001                | 010               | 011               | 100                                                   | 101                 | 110                 | 111                 |  |  |
| 0    | 000   | SLL <sub>1</sub>                   | MOVCI 4            | SRL <sub>1</sub>  | SRA <sub>1</sub>  | SLLV <sub>1</sub>                                     | * 1                 | SRLV <sub>1</sub>   | SRAV <sub>1</sub>   |  |  |
| 1    | 001   | JR <sub>1</sub>                    | JALR <sub>1</sub>  | $MOVZ_4$          | MOVN <sub>4</sub> | SYSCALL <sub>1</sub>                                  | BREAK 1             | * 1                 | SYNC <sub>2</sub>   |  |  |
| 2    | 010   | MFHI <sub>1</sub>                  | MTHI <sub>1</sub>  | MFLO <sub>1</sub> | MTLO <sub>1</sub> | DSLLV <sub>3</sub>                                    | * 1                 | DSRLV <sub>3</sub>  | DSRAV <sub>3</sub>  |  |  |
| 3    | 011   | MULT <sub>1</sub>                  | MULTU <sub>1</sub> | DIV <sub>1</sub>  | DIVU 1            | DMULT <sub>3</sub>                                    | DMULTU <sub>3</sub> | DDIV <sub>3</sub>   | DDIVU <sub>3</sub>  |  |  |
| 4    | 100   | $ADD_1$                            | ADDU 1             | SUB <sub>1</sub>  | SUBU 1            | AND <sub>1</sub>                                      | OR 1                | XOR <sub>1</sub>    | NOR 1               |  |  |
| 5    | 101   | * 1                                | * 1                | SLT <sub>1</sub>  | SLTU <sub>1</sub> | DADD <sub>3</sub>                                     | DADDU <sub>3</sub>  | DSUB <sub>3</sub>   | DSUBU <sub>3</sub>  |  |  |
| 6    | 110   | TGE 2                              | TGEU 2             | TLT <sub>2</sub>  | TLTU <sub>2</sub> | TEQ <sub>2</sub>                                      | * 1                 | TNE 2               | * 1                 |  |  |
| 7    | 111   | DSLL <sub>3</sub>                  | * 1                | DSRL <sub>3</sub> | DSRA <sub>3</sub> | DSLL32 <sub>3</sub>                                   | * 1                 | DSRL32 <sub>3</sub> | DSRA32 <sub>3</sub> |  |  |

| 31 26                     | 20 | 16 | 0 |
|---------------------------|----|----|---|
| opcode<br>= <i>REGIMM</i> | rt |    |   |

|      | rt | bits 1816         |                     | Instructions         | encoded by t         | he <b>rt</b> field w | hen opcode fi | ield = REGIN | ſΜ. |
|------|----|-------------------|---------------------|----------------------|----------------------|----------------------|---------------|--------------|-----|
| bits |    | 0                 | 1                   | 2                    | 3                    | 4                    | 5             | 6            | 7   |
| 2019 |    | 000               | 001                 | 010                  | 011                  | 100                  | 101           | 110          | 111 |
| 0    | 00 | BLTZ <sub>1</sub> | BGEZ <sub>1</sub>   | BLTZL <sub>2</sub>   | BGEZL <sub>2</sub>   | * 1                  | * 1           | * 1          | * 1 |
| 1    | 01 | TGEI 2            | TGEIU 2             | TLTI 2               | TLTIU <sub>2</sub>   | TEQI 2               | * 1           | TNEI 2       | * 1 |
| 2    | 10 | BLTZAL 1          | BGEZAL <sub>1</sub> | BLTZALL <sub>2</sub> | BGEZALL <sub>2</sub> | * 1                  | * 1           | * 1          | * 1 |
| 3    | 11 | * 1               | * 1                 | * 1                  | * 1                  | * 1                  | * 1           | * 1          | * 1 |

| A 8.8 | CPU Instruction Encoding Changes (MIPS II) |
|-------|--------------------------------------------|
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |
|       |                                            |

Table A-42 CPU Instruction Encoding Changes - MIPS II Revision.



An instruction encoding is shown if the instruction is added in this revision.

| <b>opcode</b> bits 2826 Instructions encoded |      |     |     |     |     | opcode field. |        |        |        |
|----------------------------------------------|------|-----|-----|-----|-----|---------------|--------|--------|--------|
| b                                            | oits | 0   | 1   | 2   | 3   | 4             | 5      | 6      | 7      |
| 31                                           | 129  | 000 | 001 | 010 | 011 | 100           | 101    | 110    | 111    |
| 0                                            | 000  |     |     |     |     |               |        |        |        |
| 1                                            | 001  |     |     |     |     |               |        |        |        |
| 2                                            | 010  |     |     |     |     | BEQL          | BNEL   | BLEZL  | BGTZL  |
| 3                                            | 011  |     |     |     |     |               |        |        |        |
| 4                                            | 100  |     |     |     |     |               |        |        |        |
| 5                                            | 101  |     |     |     |     |               |        |        | ρ      |
| 6                                            | 110  | LL  |     |     |     |               | LDC1 π | LDC2 π | LDC3 π |
| 7                                            | 111  | SC  |     |     |     |               | SDC1 π | SDC2 π | SDC3 π |

| 31 26               | 5        | 0 |
|---------------------|----------|---|
| opcode<br>= SPECIAL | function |   |

| fun  | ction | bits 20 |      | Instructions | encoded by f | f <b>unction</b> field | l when opcoo | de field = SPE | ECIAL. |
|------|-------|---------|------|--------------|--------------|------------------------|--------------|----------------|--------|
| bits |       | 0       | 1    | 2            | 3            | 4                      | 5            | 6              | 7      |
| 53   |       | 000     | 001  | 010          | 011          | 100                    | 101          | 110            | 111    |
| 0    | 000   |         |      |              |              |                        |              |                |        |
| 1    | 001   |         |      |              |              |                        |              |                | SYNC   |
| 2    | 010   |         |      |              |              |                        |              |                |        |
| 3    | 011   |         |      |              |              |                        |              |                |        |
| 4    | 100   |         |      |              |              |                        |              |                |        |
| 5    | 101   |         |      |              |              |                        |              |                |        |
| 6    | 110   | TGE     | TGEU | TLT          | TLTU         | TEQ                    |              | TNE            |        |
| 7    | 111   |         |      |              |              |                        |              |                |        |

| 31 26                     | 20 | 16 | 0 |
|---------------------------|----|----|---|
| opcode<br>= <i>REGIMM</i> | rt |    |   |

| rt bits 1816 Instructions encoded by the rt field wher |    |      |       |         |         | hen opcode fi | ield = REGIN | ſМ.  |     |
|--------------------------------------------------------|----|------|-------|---------|---------|---------------|--------------|------|-----|
| bits                                                   |    | 0    | 1     | 2       | 3       | 4             | 5            | 6    | 7   |
| 2019                                                   |    | 000  | 001   | 010     | 011     | 100           | 101          | 110  | 111 |
| 0                                                      | 00 |      |       | BLTZL   | BGEZL   |               |              |      |     |
| 1                                                      | 01 | TGEI | TGEIU | TLTI    | TLTIU   | TEQI          |              | TNEI |     |
| 2                                                      | 10 |      |       | BLTZALL | BGEZALL |               |              |      |     |
| 3                                                      | 11 |      |       |         |         |               |              |      |     |

| I | A 8.9 | CPU Instruction Encoding Changes (MIPS III) |
|---|-------|---------------------------------------------|
|   |       |                                             |
|   |       |                                             |
|   |       |                                             |
|   |       |                                             |
|   |       |                                             |
|   |       |                                             |
|   |       |                                             |
|   |       |                                             |
|   |       |                                             |
|   |       |                                             |
|   |       |                                             |
|   |       |                                             |
|   |       |                                             |
|   |       |                                             |
|   |       |                                             |
|   |       |                                             |
|   |       |                                             |
|   |       |                                             |

|                                                            |                   | 31        | 26                                     |                           |                                                    |                                     |                                   |                                               |
|------------------------------------------------------------|-------------------|-----------|----------------------------------------|---------------------------|----------------------------------------------------|-------------------------------------|-----------------------------------|-----------------------------------------------|
|                                                            |                   |           | opcode                                 |                           |                                                    |                                     |                                   |                                               |
| n inst                                                     | truction en       | coding is | shown if t                             | he instruction            | on is add                                          | ed or mod                           | ified in th                       | is revision                                   |
| pcode                                                      | bits 2826         |           | Instruction                            | s encoded by o            | pcode field.                                       |                                     |                                   |                                               |
| bits                                                       | 0                 | 1         | 2                                      | 3                         | 4                                                  | 5                                   | 6                                 | 7                                             |
| 129                                                        | 000               | 001       | 010                                    | 011                       | 100                                                | 101                                 | 110                               | 111                                           |
| 000                                                        |                   |           |                                        |                           |                                                    |                                     |                                   |                                               |
| 001                                                        |                   |           |                                        |                           |                                                    |                                     |                                   |                                               |
| 010                                                        |                   |           |                                        | (was COP3)                |                                                    |                                     |                                   |                                               |
| 011                                                        | DADDI             | DADDIU    | LDL                                    | LDR                       |                                                    |                                     |                                   |                                               |
| 100                                                        | Bribbi            | Bribbie   |                                        | EDI                       |                                                    |                                     |                                   | LWU                                           |
| 101                                                        |                   |           |                                        |                           | SDL                                                | SDR                                 |                                   |                                               |
| 110                                                        |                   |           |                                        | *                         | LLD                                                |                                     |                                   | LD                                            |
|                                                            |                   |           |                                        | (was LWC3)                |                                                    |                                     |                                   | (was LDC3)                                    |
| 111                                                        |                   |           |                                        | (was SWC3)                | SCD                                                |                                     |                                   | SD<br>(was SDC3)                              |
| nction                                                     | bits 20           |           | Instruction                            | s encoded by <b>f</b> t   | unction field                                      | l when opcoo                        | la fiold – CE                     |                                               |
| bits                                                       | 0                 | 1         |                                        |                           |                                                    | I                                   | ie neid – 31                      | ECIAL.                                        |
| 53                                                         |                   | 1         | 2                                      | 3                         | 4                                                  | 5                                   | 6                                 | PECIAL.<br>7                                  |
|                                                            | 000               | 001       | 010                                    | 3<br>011                  |                                                    | =                                   |                                   |                                               |
| 000                                                        | 000               |           |                                        |                           | 4                                                  | 5                                   | 6                                 | 7                                             |
| 000<br>001                                                 | 000               |           |                                        |                           | 4<br>100                                           | 5                                   | 6 110                             | 7 111                                         |
| 000<br>001<br>010                                          | 000               |           |                                        |                           | 4<br>100<br>DSLLV                                  | 5 101                               | 6<br>110<br>DSRLV                 | 7<br>111<br>DSRAV                             |
| 000<br>001<br>010<br>011                                   | 000               |           |                                        |                           | 4<br>100                                           | 5                                   | 6 110                             | 7 111                                         |
| 000<br>001<br>010<br>011<br>100                            | 000               |           |                                        |                           | 4<br>100<br>DSLLV                                  | 5<br>101<br>DMULTU                  | 6<br>110<br>DSRLV<br>DDIV         | 7<br>111<br>DSRAV<br>DDIVU                    |
| 000<br>001<br>010<br>011                                   | 000               |           |                                        |                           | 4<br>100<br>DSLLV<br>DMULT                         | 5 101                               | 6<br>110<br>DSRLV                 | 7<br>111<br>DSRAV                             |
| 000<br>001<br>010<br>011<br>100<br>101                     | 000  DSLL         |           |                                        |                           | 4<br>100<br>DSLLV<br>DMULT                         | 5<br>101<br>DMULTU                  | 6<br>110<br>DSRLV<br>DDIV         | 7<br>111<br>DSRAV<br>DDIVU                    |
| 000<br>001<br>010<br>011<br>100<br>101<br>110              |                   |           | 010                                    | 011                       | DSLLV DMULT DADD                                   | 5<br>101<br>DMULTU                  | 6<br>110<br>DSRLV<br>DDIV<br>DSUB | 7<br>111<br>DSRAV<br>DDIVU<br>DSUBU           |
| 000<br>001<br>010<br>011<br>100<br>101<br>110              |                   |           | 010  DSRL  26                          | 011                       | DSLLV DMULT DADD DSLL32                            | 5<br>101<br>DMULTU                  | 6<br>110<br>DSRLV<br>DDIV<br>DSUB | 7<br>111<br>DSRAV<br>DDIVU<br>DSUBU<br>DSRA32 |
| 000<br>001<br>010<br>011<br>100<br>101<br>110              |                   | 001       | 010  DSRL                              | DSRA                      | DSLLV DMULT DADD DSLL32                            | 5<br>101<br>DMULTU                  | 6<br>110<br>DSRLV<br>DDIV<br>DSUB | 7<br>111<br>DSRAV<br>DDIVU<br>DSUBU<br>DSRA32 |
| 000<br>001<br>010<br>011<br>100<br>101<br>110<br>111       | DSLL              | 001       | DSRL  26  opcode  REGIMM               | DSRA 20                   | DSLLV DMULT DADD DSLL32 DSLL32                     | 5<br>101<br>DMULTU<br>DADDU         | DSRLV DDIV DSUB DSRL32            | 7<br>111<br>DSRAV<br>DDIVU<br>DSUBU<br>DSRA32 |
| 000<br>001<br>010<br>011<br>100<br>101<br>110<br>111       | DSLL bits 1816    | 31        | DSRL  26  opcode REGIMM  Instruction   | DSRA  20 s encoded by the | DSLLV DMULT DADD DSLL32 D 16 rt  me rt field with  | 5 101  DMULTU  DADDU  hen opcode fi | DSRLV DDIV DSUB DSRL32            | 7 111  DSRAV  DDIVU  DSUBU  DSRA32            |
| 000<br>001<br>010<br>011<br>100<br>101<br>110<br>111       | DSLL  bits 1816 0 | 31        | DSRL  26  opcode REGIMM  Instruction 2 | DSRA  20 s encoded by the | DSLLV DMULT DADD DSLL32 D 16 rt  ne rt field wid 4 | 5 101  DMULTU  DADDU  hen opcode fi | DSRLV DDIV  DSUB  DSRL32          | 7 111  DSRAV  DDIVU  DSUBU  DSRA32            |
| 000<br>001<br>010<br>011<br>100<br>101<br>110<br>111<br>rt | DSLL bits 1816    | 31        | DSRL  26  opcode REGIMM  Instruction   | DSRA  20 s encoded by the | DSLLV DMULT DADD DSLL32 D 16 rt  me rt field with  | 5 101  DMULTU  DADDU  hen opcode fi | DSRLV DDIV DSUB DSRL32            | 7 111  DSRAV  DDIVU  DSUBU  DSRA32            |
| 000<br>001<br>010<br>011<br>100<br>101<br>110<br>111       | DSLL  bits 1816 0 | 31        | DSRL  26  opcode REGIMM  Instruction 2 | DSRA  20 s encoded by the | DSLLV DMULT DADD DSLL32 D 16 rt  ne rt field wid 4 | 5 101  DMULTU  DADDU  hen opcode fi | DSRLV DDIV  DSUB  DSRL32          | 7 111  DSRAV  DDIVU  DSUBU  DSRA32            |

11



Table A-44 CPU Instruction Encoding Changes - MIPS IV Revision.

| 31 26  | 0 |
|--------|---|
| opcode |   |

An instruction encoding is shown if the instruction is added or modified in this revision.

| op   | code | bits 2826 |     | Instructions | s encoded by o | pcode field. |     |     |     |
|------|------|-----------|-----|--------------|----------------|--------------|-----|-----|-----|
| bits |      | 0         | 1   | 2            | 3              | 4            | 5   | 6   | 7   |
| 3129 |      | 000       | 001 | 010          | 011            | 100          | 101 | 110 | 111 |
| 0    | 000  |           |     |              |                |              |     |     |     |
| 1    | 001  |           |     |              |                |              |     |     |     |
| 2    | 010  |           |     |              | СОР1Х б,л      |              |     |     |     |
| 3    | 011  |           |     |              |                |              |     |     |     |
| 4    | 100  |           |     |              |                |              |     |     |     |
| 5    | 101  |           |     |              |                |              |     |     |     |
| 6    | 110  |           |     |              | PREF           |              |     |     |     |
| 7    | 111  |           |     |              |                |              |     |     |     |

| 31            | 26 | _ | 5 (      |
|---------------|----|---|----------|
| opco<br>= SPE |    |   | function |

| function | bits 20 |           | Instructions encoded by <b>function</b> field when opcode field = SPECIAL. |      |     |     |     |     |  |  |
|----------|---------|-----------|----------------------------------------------------------------------------|------|-----|-----|-----|-----|--|--|
| bits     | 0       | 1         | 2                                                                          | 3    | 4   | 5   | 6   | 7   |  |  |
| 53       | 000     | 001       | 010                                                                        | 011  | 100 | 101 | 110 | 111 |  |  |
| 0 000    |         | MOVCI δ,μ |                                                                            |      |     |     |     |     |  |  |
| 1 001    |         |           | MOVZ                                                                       | MOVN |     |     |     |     |  |  |
| 2 010    |         |           |                                                                            |      |     |     |     |     |  |  |
| 3 011    |         |           |                                                                            |      |     |     |     |     |  |  |
| 4 100    |         |           |                                                                            |      |     |     |     |     |  |  |
| 5 101    |         |           |                                                                            |      |     |     |     |     |  |  |
| 6 110    |         |           |                                                                            |      |     |     |     |     |  |  |
| 7 111    |         |           |                                                                            |      |     |     |     |     |  |  |

|                    | 31 26 | 20 | 16 | 0 |
|--------------------|-------|----|----|---|
| opcode<br>= REGIMM |       | rt |    |   |

|              | rt | bits 1816 Instructions encoded by the <b>rt</b> field when opcode field = REGIMM. |     |     |     |     |     |     |     |
|--------------|----|-----------------------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|
| bits<br>2019 |    | 0                                                                                 | 1   | 2   | 3   | 4   | 5   | 6   | 7   |
|              |    | 000                                                                               | 001 | 010 | 011 | 100 | 101 | 110 | 111 |
| 0            | 00 |                                                                                   |     |     |     |     |     |     |     |
| 1            | 01 |                                                                                   |     |     |     |     |     |     |     |
| 2            | 10 |                                                                                   |     |     |     |     |     |     |     |
| 3            | 11 |                                                                                   |     |     |     |     |     |     |     |

- Key to notes in CPU instruction encoding tables:
- \*(asterisk)This opcode is reserved for future use. An attempt to execute it causes a Reserved Instruction exception.
- (cross)This opcode is reserved for future use. An attempt to execute it produces an undefined result. The result may be a Reserved Instruction exception but this is not guaranteed.
- $\delta(\text{delta})$ (also *italic* opcode name) This opcode indicates an instruction class. The instruction word must be further decoded by examing additional tables that show values for another instruction field.
- $\pi(\mathbf{pi})$ This opcode is a coprocessor operation, not a CPU operation. If the processor state does not allow access to the specified coprocessor, the instruction causes a Coprocessor Unusable exception. It is included in the table because it uses a primary opcode in the instruction encoding map.
- $\kappa(kappa)$ This opcode is removed in a later revision of the architecture. If a MIPS III or MIPS IV processor is operated in MIPS II-only mode this opcode will cause a Reserved Instruction exception.
- $\mu(\text{mu})$ This opcode indicates a class of coprocessor 1 instructions. If the processor state does not allow access to coprocessor 1, the opcode causes a Coprocessor Unusable exception. It is included in the table because the encoding uses a location in what is otherwise a CPU instruction encoding map. Further encoding information for this instruction class is in the FPU Instruction Encoding tables.
- $\rho(\text{rho})$ This opcode is reserved for Coprocessor 0 (System Control Coprocessor) instructions that require base+offset addressing. If the instruction is used for COP0 in an implementation, an attempt to execute it without Coprocessor 0 access privilege will cause a Coprocessor Unusable exception. If the instruction is not used in an implementation, it will cause a Reserved Instruction exception.