# OSOROM Instruction Set Reference

The Moroso Project

 $\mathrm{June}\ 15,\ 2014$ 

# Contents

| 1 | CPU  | J Architecture                                       | 3         |
|---|------|------------------------------------------------------|-----------|
|   | 1.1  | Instructions                                         | 3         |
|   | 1.2  | Registers                                            | 3         |
|   | 1.3  | ALU Instruction Formats                              | 3         |
|   | 1.4  | VLIW                                                 | 4         |
|   | 1.5  | Virtual Memory                                       | 4         |
|   | 1.6  | Coprocessor Registers                                | 5         |
|   | 1.7  | Exceptions                                           | 5         |
| 2 | Inst | ruction Set Summary                                  | 6         |
|   | 2.1  | Instruction Set Encoding                             | 6         |
| 3 | Inst | ruction Listing                                      | 7         |
| • | 3.1  | ADD - Addition                                       | 8         |
|   | 3.2  | AND - Bitwise And                                    | 9         |
|   | 3.3  |                                                      | 10        |
|   | 3.4  | BL - Branch with Link                                |           |
|   | 3.5  |                                                      | $12^{-1}$ |
|   | 3.6  |                                                      | 13        |
|   | 3.7  | 1                                                    | 14        |
|   | 3.8  | CMPEQ - Compare Equal                                |           |
|   | 3.9  |                                                      | 16        |
|   | 3.10 |                                                      | 17        |
|   |      |                                                      | 18        |
|   |      | <u> </u>                                             | 19        |
|   |      |                                                      | 20        |
|   | 3.14 | ERET - Return from Exception                         | 21        |
|   | 3.15 | FENCE                                                | 22        |
|   | 3.16 | FLUSH - Flush L1 Caches                              | 23        |
|   | 3.17 | LB - Load Byte                                       | 24        |
|   | 3.18 | LH - Load Half-Word                                  | 25        |
|   | 3.19 | LL - Load Linked                                     | 26        |
|   | 3.20 | LW - Load Word                                       | 27        |
|   | 3.21 | MFC - Move From Coprocessor Register                 | 28        |
|   |      | MFHI - Move From Multiply/Division Overflow Register |           |
|   | 3.23 | MOV - Move                                           | 30        |
|   | 3.24 | MTC - Move To Coprocessor Register                   | 31        |

| 3.25 | MTHI - Move To Multiply/Division Overflow Register | 32 |
|------|----------------------------------------------------|----|
| 3.26 | MVN - Move and Invert                              | 33 |
| 3.27 | MULT - Integer Multiplication                      | 34 |
| 3.28 | NOR - Bitwise Logical NOR                          | 35 |
| 3.29 | OR - Bitwise Logical OR                            | 36 |
| 3.30 | RSB - Reverse Subtraction                          | 37 |
| 3.31 | SB - Store Byte                                    | 38 |
|      | SC - Store Conditional                             |    |
| 3.33 | SH - Store Half-Word                               | 10 |
| 3.34 | SUB - Subtraction                                  | 11 |
| 3.35 | SW - Store Word                                    | 12 |
| 3.36 | SXB - Sign-Extend Byte                             | 13 |
| 3.37 | SXH - Sign-Extend Half-Word                        | 14 |
| 3.38 | SYSCALL - TODO XXX                                 | 15 |
| 3.39 | XOR - Bitwise Exclusive OR                         | 16 |

# Chapter 1

# CPU Architecture

#### 1.1 Instructions

Each instruction is a 32-bit word, stored in little-endian order. The top 2 bits of the instruction select a predicate register, and the third bit from the top optionally inverts it. The instruction is only executed if the resulting predicate is true.

## 1.2 Registers

There are 32 32-bit general-purpose registers, R0 through R31. R31 is used as the link register for BL instructions. The program counter is stored separately, and may only be modified through branch instructions and read through BL instructions.

There are three one-bit predicate registers, P0 through P2, that may be written to by compare instructions. A fourth predicate register, P3, is always true. Instructions predicated on P3 will always execute, and writes to P3 are ignored.

#### 1.3 ALU Instruction Formats

ALU instructions may accept immediate values for one of their input operands, which come in two forms: Short immediates are embedded in the instruction and consist of a 10-bit constant and a 4-bit rotate amount. To achieve any even rotation between 0 and 30, the rotate amount is first multiplied by 2, and the constant is rotated right by the result. ALU instructions that accept a single operand use the portion of the instruction normally used for the other operand register to extend the constant to 15 bits. Long immediate operands are 32 bit values, and occupy the memory word following the instruction.

If a register is used as the last source operand of an ALU instruction, it may optionally be shifted by a 5-bit immediate value, as specified with the SHF and SHIFTAMT fields of the instruction. The SHIFTAMT field is the amount to shift, between 0 and 31, and the SHF field specifies the shift type, as follows:

| Encoding | Mnemonic | Shift Type             |
|----------|----------|------------------------|
| 0 0      | LSL      | Logical Shift Left     |
| 0 1      | LSR      | Logical Shift Right    |
| 10       | ASR      | Arithmetic Shift Right |
| 11       | ROR      | Rotate Right           |

ALU instructions taking a single operand may also specify a register shifted by an unsigned value contained in another register Rt. In this case, the same SHF types are available. If the value of the shift register is greater than 31, the following behavior is used: Logical shifts zero the result, arithmetic right shift extends the sign bit of the operand register across the entire result, and rotate rotates the value by Rt % 32.

#### 1.4 VLIW

At each time step, the CPU fetches a "packet" of 4 instructions located contiguously in memory and executes them in parallel. These packets must be aligned to their 16-byte size, and branch targets must also be so aligned.

There are three types of instructions: Control, Memory, and ALU instructions. Only one control instruction may be executed in any given packet; it must occupy the first (lowest-address) slot in its packet. Likewise, only the first two slots in a packet may execute memory instructions. ALU instructions may be located in any slot.

If a long immediate operand is specified for an ALU instruction, the following slot is interpreted as an operand and no operation is issued for that slot. The final slot in a packet may not specify a long immediate operand.

## 1.5 Virtual Memory

Virtual memory is accomplished through a hardware-filled TLB, with 4KB pages and a 2-level page-table structure. Page directories and page tables are one page in size, containing 1024 32-bit entries. Virtual addresses are 32 bits and are broken up into 3 parts: Page Directory Index, Page Table Index, and Page Offset, as follows:

|   | PD INDEX |   |   | PT | INDEX |   |   | OFFSET |   |
|---|----------|---|---|----|-------|---|---|--------|---|
| 1 |          | 2 | 1 |    |       | 2 | 1 |        | 0 |
| 3 |          | 2 | 2 |    |       | 1 | 1 |        |   |

The page directory base is stored in a coprocessor register, PTBR. Writes to this register will flush all entries not marked global from the TLB. Page table entries and page directory entries are each 32 bits and have the same format:

| 3 | 2  | 2 |          |      |      | 1 | 1 |        |   |   |   |   |   |
|---|----|---|----------|------|------|---|---|--------|---|---|---|---|---|
| 1 | 9  | 8 |          |      |      | 2 | 1 |        | 4 | 3 | 2 | 1 | 0 |
| R | SV |   | PHYSICAL | PAGE | BASE |   |   | UNUSED |   | G | K | W | Р |

The four flags in each entry have the following meanings:

- G: Global page. Mappings with this bit set in either level will not be flushed from the TLB when the page table base register is modified.
- K: Kernel-only page. Mappings with this bit set in either level may only be read or written to while the processor is in kernel mode. Attempting to access such mappings from user mode will generate a page fault exception.
- W: Writeable page. Attempting to write to a page without this bit set in both levels will result in a page fault.

• P: Present. Attempting to access a page without this bit set in both levels will result in a page fault.

Since our FPGA has 512MB of physical memory, physical page bases are 17 bits, and offsets are 12 bits. The top bits of an entry are not used but should remain 0 in case we go to 32-bit physical addresses in the future. Bits 11 through 4 are free for programmer use.

## 1.6 Coprocessor Registers

The coprocessor registers are control registers accessible only in kernel mode via the MFC and MTC instructions. They provide information about exceptions to the kernel and are used to configure the processor. The following coprocessor registers are present:

| Encoding | Mnemonic | Purpose                                                                     |
|----------|----------|-----------------------------------------------------------------------------|
| 00000    | PFLAGS   | Processor control flags. Currently only one: Bit 0 is 1 for paging enabled, |
|          |          | 0 for paging disabled.                                                      |
| 00001    | PTB      | Page Table Base Register. Specifies the start of the page directory for     |
|          |          | virtual address translation. Writes to this register flush the TLB.         |
| 00010    | EHA      | Exception Handler Address. Specifies a virtual address to which to trans-   |
|          |          | fer control when an exception or interrupt is encountered.                  |
| 00011    | EPC      | Error PC. The virtual address of the last instruction packet to cause an    |
|          |          | exception, or the first instruction not executed due to an interrupt.       |
| 00100    | EC0      | Error Cause 0. The cause of an exception occurring on lane 0, or the type   |
|          |          | of a received interrupt. See Section 1.7 for a list of causes.              |
| 00101    | EC1      | Error Cause 1. The cause of an exception occurring on lane 1.               |
| 00110    | EC2      | Error Cause 2. The cause of an exception occurring on lane 2.               |
| 00111    | EC3      | Error Cause 3. The cause of an exception occurring on lane 3.               |
| 01000    | EA0      | Error Address 0. If lane 0 makes an invalid memory access, the virtual      |
|          |          | address it attempted to access will be stored in this register.             |
| 01001    | EA1      | Error Address 1. If lane 1 makes an invalid memory access, the virtual      |
|          |          | address it attempted to access will be stored in this register.             |

# 1.7 Exceptions

# Chapter 2

# Instruction Set Summary

# 2.1 Instruction Set Encoding

|                  | 31 30 29 | 28 | 27 | 26 | 25 | 24 23 22 21  | 20 19   | 18 | 17 | 16   | 15   | 14  | 13   | 12   | 11    | 10    | 9 8 7    | 6 5  | 4 3 2 1 0  |
|------------------|----------|----|----|----|----|--------------|---------|----|----|------|------|-----|------|------|-------|-------|----------|------|------------|
| ALU 1-Op Short   | Pred     | 0  |    |    | I  | mmediate Low | 10      |    |    | Rota | ate  |     | Α    | LU   | Opc   | ode   | Rd       |      | Imm High 5 |
| ALU 2-Op Short   | Pred     | 0  |    |    |    | Immediate 10 |         |    |    | Rota | ate  |     | A    | LU   | Opc   | ode   | Rd       |      | Rs         |
| Compare Short    | Pred     | 0  |    |    |    | Immediate 10 |         |    |    | Rota | ate  |     | 0    | 1    | 1     | 1     | Ctype    | Pn   | Rs         |
| ALU Register     | Pred     | 1  | 0  | 1  | 5  | Shift amount | Stype   |    |    | Rt   |      |     | A    | LU   | Opc   | ode   | Rd       |      | Rs         |
| Compare Register | Pred     | 1  | 0  | 1  | 5  | Shift amount | Stype   |    |    | Rt   |      |     | 0    | 1    | 1     | 1     | Ctype    | Pn   | Rs         |
| Load             | Pred     | 1  | 0  | 0  | 1  |              |         |    |    |      |      |     |      |      |       |       |          |      |            |
| Store            | Pred     | 1  | 0  | 0  | 1  | Offset Hig   | gh 6    |    |    | Rt   |      |     | Μ    | LS   | U OI  | ocode | Offset I | ow 5 | Rs         |
| Branch immediate | Pred     | 1  | 1  | 0  | L  |              |         |    |    |      |      | Off | fset | 25   |       |       |          |      |            |
| Branch register  | Pred     | 1  | 1  | 0  | L  |              |         |    |    | Of   | fset | 20  |      |      |       |       |          |      | Rs         |
| Control          | Pred     | 1  | 0  | 0  | 0  | 1 Ctrl Opco  | de High |    |    | Rt   |      |     | Ctı  | ı Oı | ocode | e Low | Rd       |      | Rs         |
| ALU 1-Op Regsh   | Pred     | 1  | 0  | 0  | 0  | 0 0 0 1      | Stype   |    |    | Rt   |      |     | Α    | LU   | Opc   | ode   | Rd       |      | Rs         |
| ALU Long         | Pred     | 1  | 0  | 0  | 0  | 0 0 0 0      | 0 0     | 0  | 0  | 0    | 0    | 0   | Α    | LU   | Opc   | ode   | Rd       |      | Rs         |

 $31 \ \ \, 30 \ \ \, 29 \ \ \, 28 \ \ \, 27 \ \ \, 26 \ \ \, 25 \ \ \, 24 \ \ \, 23 \ \ \, 22 \ \ \, 21 \ \ \, 20 \ \ \, 19 \ \ \, 18 \ \ \, 17 \ \ \, 16 \ \ \, 15 \ \ \, 14 \ \ \, 13 \ \ \, 12 \ \ \, 11 \ \ \, 10 \ \ \, 9 \ \ \, 8 \ \ \, 7 \ \ \, 6 \ \ \, 5 \ \ \, 4 \ \ \, 3 \ \ \, 2 \ \ \, 1 \ \ \, 0$ 

# Chapter 3

# Instruction Listing

#### **ADD** - Addition 3.1

#### **Encoding** 3.1.1

|   | 1 0 9 | 0 | 1 | O | S | 4   | 3   | 2   | Т  | U  | 9  | 0 | 1 | O   | S    | 4 | 3 | 2 | 1 | U | 9 | 0 | 1  | O | S | 4 | 3 | 2  | Т | U |     |
|---|-------|---|---|---|---|-----|-----|-----|----|----|----|---|---|-----|------|---|---|---|---|---|---|---|----|---|---|---|---|----|---|---|-----|
|   | PRED  | 0 |   |   |   | CC  | ONS | TA: | NT |    |    |   | ] | ROT | 'ATI | Ξ | 0 | 0 | 0 | 0 |   |   | RD |   |   |   |   | RS |   |   |     |
|   | PRED  | 1 | 0 | 1 | 1 | SHI | FT  | AM. | Γ  | SI | HF |   |   | RT  |      |   | 0 | 0 | 0 | 0 |   |   | RD |   |   |   |   | RS |   |   |     |
| ĺ | PRED  | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 0  | 0  | 0  | 0 | 0 | 0   | 0    | 0 | 0 | 0 | 0 | 0 |   |   | RD |   |   |   |   | RS |   |   | LIM |

#### 3.1.2 **Syntax**

- ADD[PN] Rd, Rs, #Imm
- ADD[PN] Rd, Rs, Rt [SHF #Imm]

#### 3.1.3 Type

ADD is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.1.4Behavior

Adds the two operands together into the destination register. If two register operands are specified, the second may optionally be shifted by an immediate value before the addition is performed.

TODO optional overflow exceptions???

## 3.2 AND - Bitwise And

### 3.2.1 Encoding

| PRED | 0 |   |   |   | CC  | ONS | TA: | NT |    |    |   | I | ROT | 'AT | E | 0 | 0 | 0 | 1 | RD | RS |     |
|------|---|---|---|---|-----|-----|-----|----|----|----|---|---|-----|-----|---|---|---|---|---|----|----|-----|
| PRED | 1 | 0 | 1 | 5 | SHI | FT  | AM. | Γ  | SI | HF |   |   | RT  |     |   | 0 | 0 | 0 | 1 | RD | RS |     |
| PRED | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 0  | 0  | 0  | 0 | 0 | 0   | 0   | 0 | 0 | 0 | 0 | 1 | RD | RS | LIM |

#### 3.2.2 Syntax

- AND[PN] Rd, Rs, #Imm
- AND[PN] Rd, Rs, Rt [SHF #Imm]

## 3.2.3 Type

AND is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.2.4 Behavior

Computes the bitwise logical AND of the two operands, storing the result in the destination register. If two register operands are specified, the second may optionally be shifted by an immediate value before the computation is performed.

## 3.3 B - Branch

### 3.3.1 Encoding

|      |   | • |   |   | - | <br> | <br> | <br> | • |   |       | _  |    |     |    | <br> | <br>• | <br> | _ | <br> | _ |  |
|------|---|---|---|---|---|------|------|------|---|---|-------|----|----|-----|----|------|-------|------|---|------|---|--|
| PRED | 1 | 1 | 0 | 0 |   |      |      |      |   |   |       |    | OF | 'FS | ΕT |      |       |      |   |      |   |  |
| PRED | 1 | 1 | 1 | 0 |   |      |      |      |   | ( | 1 H H | SE |    |     |    |      |       |      |   | RS   |   |  |

### 3.3.2 Syntax

- B[PN] <label>
- B[PN] (Rs + OFF)

#### 3.3.3 Type

Branch is a Control operation. It may only be placed as the first instruction in a packet.

#### 3.3.4 Behavior

Transfers control to the address specified. The OFFSET field is shifted left by 4 places and sign-extended to 32 bits, then added to either the source register or, if none is specified, the address of the branch instruction. If the specified base register is not aligned to a 16-byte value, the target is rounded down to the nearest aligned value before control is transferred. Other instructions in the same packet as the branch instruction are executed before control is transferred.

## 3.4 BL - Branch with Link

## 3.4.1 Encoding

| PRED | 1 | 1 | 0 | 1 | OFFSET |    |
|------|---|---|---|---|--------|----|
| PRED | 1 | 1 | 1 | 1 | OFFSET | RS |

### 3.4.2 Syntax

- BL[PN] <label>
- BL[PN] (Rs + OFF)

#### 3.4.3 Type

Branch with Link is a Control operation. It may only be placed as the first instruction in a packet.

#### 3.4.4 Behavior

BL functions identically to the Branch instruction, except that the address of the BL instruction is placed in R31.

# 3.5 BREAK - TODO XXX

# 3.5.1 Encoding

| 3 | 3  | 3   | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |   |   |   |   |   |   |   |   |   |
|---|----|-----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1 | L  | 0   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|   | ΡI | REI | D | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х |

## 3.6 CMPBC - Compare Bits Clear

#### 3.6.1 Encoding

 $3 \ \ 3 \ \ 2 \ \ 2 \ \ 2 \ \ 2 \ \ 2 \ \ 2 \ \ 2 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1$ 

| 1 | 0  | 9 | 8 | 7 | 6 | 5 | 5 | 4  | 3   | 3   | 2   | 1  | 0 | 9  | 8 | 7 | 6   | 5   | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1 | 0 |  |
|---|----|---|---|---|---|---|---|----|-----|-----|-----|----|---|----|---|---|-----|-----|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|--|
| P | RE | D | 0 |   |   |   |   | CC | ONS | IS: | TA  | NT |   |    |   |   | ROT | 'AT | Ε | 0 | 1 | 1 | 1 | 1 | 1 | 1 | P | D |   |   | RS |   |   |  |
| P | RE | D | 1 | 0 | 1 |   | S | HI | ΓFT | 'TA | AM' | Γ  | S | HF |   |   | RT  | ı   |   | 0 | 1 | 1 | 1 | 1 | 1 | 1 | P | D |   |   | RS |   |   |  |
| P | RE | D | 1 | 0 | 0 | ( | 0 | 0  | 0   | )   | 0   | 0  | 0 | 0  | 0 | 0 | 0   | 0   | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | P | D |   |   | RS |   |   |  |

#### 3.6.2 Syntax

- CMPBC[PN] Pd, Rs, #Imm
- CMPBC[PN] Pd, Rs, Rt [SHF #Imm]

#### 3.6.3 Type

CMPBC is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.6.4 Behavior

CMPBC checks each bit of Rs corresponding to a 1 bit in the second operand, writing 1 into the destination predicate if all such bits are 0, and writing 0 otherwise – that is, it computes the unary OR of the bits in (~Rs & OP2) and stores the result in the desired predicate.

## 3.7 CMPBS - Compare Bits Set

#### 3.7.1 Encoding

| 1 | 0   | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2    | 1  | 0  | 9  | 8 | 7 | 6   | 5   | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1 | 0 |     |
|---|-----|---|---|---|---|---|-----|-----|------|----|----|----|---|---|-----|-----|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|-----|
| P | RE  | D | 0 |   |   |   | C   | ONS | STA  | NT |    |    |   | ] | ROT | 'AT | Е | 0 | 1 | 1 | 1 | 1 | 1 | 0 | P | D |   |   | RS |   |   | ]   |
| P | RE: | D | 1 | 0 | 1 |   | SHI | FT  | 'AM' | Γ  | SI | HF |   |   | RT  |     |   | 0 | 1 | 1 | 1 | 1 | 1 | 0 | Р | D |   |   | RS |   |   |     |
| Р | RE: | D | 1 | 0 | 0 | 0 | 0   | 0   | 0    | 0  | 0  | 0  | 0 | 0 | 0   | 0   | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | Р | D |   |   | RS |   |   | LIM |

### 3.7.2 Syntax

- CMPBS[PN] Pd, Rs, #Imm
- CMPBS[PN] Pd, Rs, Rt [SHF #Imm]

#### 3.7.3 Type

CMPBS is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.7.4 Behavior

CMPBS checks each bit of Rs corresponding to a 1 bit in the second operand, writing 1 into the destination predicate if any such bit is 1, and writing 0 otherwise – that is, it computes the unary OR of the bits in (Rs & OP2) and stores the result in the desired predicate.

## 3.8 CMPEQ - Compare Equal

#### 3.8.1 Encoding

 $3 \ \ 3 \ \ 2 \ \ 2 \ \ 2 \ \ 2 \ \ 2 \ \ 2 \ \ 2 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1$ 

| 1 0 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2   | 1  | 0  | 9  | 8 | 7 | 6   | 5   | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1 | 0 |     |
|-------|---|---|---|---|-----|-----|-----|----|----|----|---|---|-----|-----|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|-----|
| PRED  | 0 |   |   |   | CC  | ONS | TAI | NT |    |    |   | ] | ROT | 'AT | Ε | 0 | 1 | 1 | 1 | 0 | 1 | 0 | Р | D |   |   | RS |   |   |     |
| PRED  | 1 | 0 | 1 |   | SHI | FT  | AMT | Γ  | SI | HF |   |   | RT  |     |   | 0 | 1 | 1 | 1 | 0 | 1 | 0 | P | D |   |   | RS |   |   |     |
| PRED  | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 0  | 0  | 0  | 0 | 0 | 0   | 0   | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | P | D |   |   | RS |   |   | LIM |

#### 3.8.2 Syntax

- CMPEQ[PN] Pd, Rs, #Imm
- CMPEQ[PN] Pd, Rs, Rt [SHF #Imm]

#### 3.8.3 Type

CMPEQ is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.8.4 Behavior

CMPEQ tests whether its two operands are equal, writing 1 into the destination predicate if they are and 0 otherwise.

## 3.9 CMPLES - Compare Less Than or Equal (Signed)

#### 3.9.1 Encoding

| 1 0 9 | 8 | 7 6 | 5 | 4  | 3   | 2 | 1  | 0 | 9 | 8 | 7 | 6   | 5   | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 5 | 4 | 3 | 2  | 1 | 0 |
|-------|---|-----|---|----|-----|---|----|---|---|---|---|-----|-----|---|---|---|---|---|---|---|---|-----|---|---|----|---|---|
| PRED  | 0 |     |   | CC | ONS |   | NT |   |   |   | F | ROT | 'AT | Ε | 0 | 1 | 1 | 1 | 1 | 0 | 1 | PD  |   |   | RS |   |   |

| PRED | 0 |   |   |   | CC  | ONS | TAl | NT |    |    |   | I | ROT | 'AT | E | 0 | 1 | 1 | 1 | 1 | 0 | 1 | PD | RS |     |
|------|---|---|---|---|-----|-----|-----|----|----|----|---|---|-----|-----|---|---|---|---|---|---|---|---|----|----|-----|
| PRED | 1 | 0 | 1 | : | SHI | FT  | AM' | Γ  | SI | HF |   |   | RT  |     |   | 0 | 1 | 1 | 1 | 1 | 0 | 1 | PD | RS |     |
| PRED | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 0  | 0  | 0  | 0 | 0 | 0   | 0   | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | PD | RS | LIM |

### 3.9.2 Syntax

- CMPLES[PN] Pd, Rs, #Imm
- CMPLES[PN] Pd, Rs, Rt [SHF #Imm]

#### 3.9.3 Type

CMPLES is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.9.4 Behavior

CMPLES interprets its operands as 32-bit two's-complement signed integers, and writes 1 into the specified predicate register if the value of Rs is less than or equal to the value of the second operand, and 0 otherwise.

## 3.10 CMPLEU - Compare Less Than or Equal (Unsigned)

#### 3.10.1 Encoding

| 9 8 7 6 5 4 3 2 1 0 | 8 7 6 5 4 3 2 1 0 | 98765 | 4 3 2 1 0 |
|---------------------|-------------------|-------|-----------|
|---------------------|-------------------|-------|-----------|

| PRED | 0 |   |   |   | CC  | ONS | TA  | NT |    |    |   | I | ROT | 'AT | E | 0 | 1 | 1 | 1 | 0 | 0 | 1 | PD | RS |     |
|------|---|---|---|---|-----|-----|-----|----|----|----|---|---|-----|-----|---|---|---|---|---|---|---|---|----|----|-----|
| PRED | 1 | 0 | 1 | 1 | SHI | FT  | AM. | Γ  | SI | ΙF |   |   | RT  |     |   | 0 | 1 | 1 | 1 | 0 | 0 | 1 | PD | RS |     |
| PRED | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 0  | 0  | 0  | 0 | 0 | 0   | 0   | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | PD | RS | LIM |

#### 3.10.2 Syntax

- CMPLEU[PN] Pd, Rs, #Imm
- CMPLEU[PN] Pd, Rs, Rt [SHF #Imm]

#### 3.10.3 Type

CMPLEU is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.10.4 Behavior

CMPLEU interprets its operands as 32-bit unsigned integers, and writes 1 into the specified predicate register if the value of Rs is less than or equal to the value of the second operand, and 0 otherwise.

## 3.11 CMPLTS - Compare Less Than (Signed)

#### 3.11.1 Encoding

| 1 0 | 9 | 8 | 7 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|-----|---|---|-----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|
|-----|---|---|-----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|

| PRED | 0 |   |   |   | C   | ONS | TA  | NT |    |    |   | I | ROT | 'AT | E | 0 | 1 | 1 | 1 | 1 | 0 | 0 | PD | RS |     |
|------|---|---|---|---|-----|-----|-----|----|----|----|---|---|-----|-----|---|---|---|---|---|---|---|---|----|----|-----|
| PRED | 1 | 0 | 1 | 1 | SHI | FT  | AM. | Γ  | SI | HF |   |   | RT  |     |   | 0 | 1 | 1 | 1 | 1 | 0 | 0 | PD | RS |     |
| PRED | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 0  | 0  | 0  | 0 | 0 | 0   | 0   | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | PD | RS | LIM |

#### 3.11.2 Syntax

- CMPLTS[PN] Pd, Rs, #Imm
- CMPLTS[PN] Pd, Rs, Rt [SHF #Imm]

#### 3.11.3 Type

CMPLTS is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.11.4 Behavior

CMPLTS interprets its operands as 32-bit two's-complement signed integers, and writes 1 into the specified predicate register if the value of Rs is less than to the value of the second operand, and 0 otherwise.

## 3.12 CMPLTU - Compare Less Than (Unsigned)

#### 3.12.1 Encoding

| 1 0 | 9 | 8 | 7 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|-----|---|---|-----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|
|-----|---|---|-----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|

| PRED | 0 |   |   |   | CC  | ONS | TA  | NT |    |    |   | I | ROT | 'AT | E | 0 | 1 | 1 | 1 | 0 | 0 | 0 | PD | RS |     |
|------|---|---|---|---|-----|-----|-----|----|----|----|---|---|-----|-----|---|---|---|---|---|---|---|---|----|----|-----|
| PRED | 1 | 0 | 1 |   | SHI | FT  | AM. | Γ  | SI | ΙF |   |   | RT  |     |   | 0 | 1 | 1 | 1 | 0 | 0 | 0 | PD | RS |     |
| PRED | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 0  | 0  | 0  | 0 | 0 | 0   | 0   | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | PD | RS | LIM |

#### 3.12.2 Syntax

- CMPLTU[PN] Pd, Rs, #Imm
- CMPLTU[PN] Pd, Rs, Rt [SHF #Imm]

## 3.12.3 Type

CMPLTU is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.12.4 Behavior

CMPLTU interprets its operands as 32-bit unsigned integers, and writes 1 into the specified predicate register if the value of Rs is less than to the value of the second operand, and 0 otherwise. P3 is pinned to 1. Writes into P3 from compare instructions are ignored.

# 3.13 DIV - Integer Division

## 3.13.1 Encoding

| 3 | 3   | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1  | 1 | 1 | 1 | 1 | 1 | 1 |   |   |    |   |   |   |   |    |   |   |
|---|-----|---|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|---|---|---|---|---|---|----|---|---|---|---|----|---|---|
| _ | -   | - | - |   | - | - | _ | - | _ | _ | - | - | - |   | -  | - | _ | - | _ | _ | - | - | - | •  | - | - | _ | - | _  | _ | 0 |
| P | RE: | D | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | Х |   |   | RT |   |   | Х | Х | Х | Х |   |   | RD |   |   |   |   | RS |   |   |

## 3.13.2 Syntax

• DIV[PN] Rd, Rs, Rt

### 3.13.3 Type

DIV is a Control operation. It may only be placed as the first instruction in a packet.

#### 3.13.4 Behavior

Performs the integer division Rs / Rt, writing the quotient into Rd and the remainder into the multiply/divide overflow register.

## 3.14 ERET - Return from Exception

#### 3.14.1 Encoding

|   | 3 | 3  | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |   |   |   |   |   |   |   |   |   |
|---|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|   | 1 | 0  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ſ | P | RE | D | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х |

#### 3.14.2 Syntax

• ERET[PN]

#### 3.14.3 Type

ERET is a Control operation. It may only be placed as the first instruction in a packet. It may only be used when the processor is in kernel mode.

#### 3.14.4 Behavior

ERET returns the processor to user mode from kernel mode, and branches to the memory address contained in the Error PC control register. Other instructions in the same packet as the ERET instruction are executed in kernel mode before control is transferred. This instruction also clears the memory link bit.

## **3.15 FENCE**

### 3.15.1 Encoding

| 3 | 3  | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |   |   |   |   |   |   |   |   |   |
|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1 | 0  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| P | RE | D | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | Х | X | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х | X | Х | X | X |

## 3.15.2 Syntax

• FENCE[PN]

### 3.15.3 Type

FENCE is a Control operation. It may only be placed as the first instruction in a packet.

#### 3.15.4 Behavior

Our architecture doesn't reorder requests, so right now FENCE is a no-op. If we have to add behavior to it in the future, memory instructions in the same packet as the FENCE will probably go after it, but please don't count on that right now.

## 3.16 FLUSH - Flush L1 Caches

#### 3.16.1 Encoding

| 3 | 3  | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1  | 1  |   |   |   |   |   |   |   |    |   |   |  |
|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----|----|---|---|---|---|---|---|---|----|---|---|--|
| 1 | 0  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1 | 0 |  |
| P | RE | D | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | С | Х | Х | X | X | Х | X | Х | TY | PE | Х | Х | X | Х | Х |   |   | RS |   |   |  |

### 3.16.2 Syntax

• FLUSH[PN] TYPE, Rs

#### 3.16.3 Type

FLUSH is a Control operation. It may only be placed as the first instruction in a packet.

#### 3.16.4 Behavior

FLUSH invalidates the line in the specified L1 cache corresponding to the virtual address contained in Rs. For instruction or data cache flushes, attempting to flush a virtual address whose access would cause a page fault will also cause a page fault. If a dirty data cache line is flushed, the new value is immediately written out to the L2 cache, where it will be visible to DMA peripherals. Values for the TYPE field are as follows:

| Value | Mnemonic | Type                 |
|-------|----------|----------------------|
| 0 0   | DATA     | L1 Data Cache        |
| 0 1   | INST     | L1 Instruction Cache |
| 1 0   | DTLB     | Data TLB             |
| 1 1   | ITLB     | Instruction TLB      |

## 3.17 LB - Load Byte

## 3.17.1 Encoding

| 3 | 3  | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1   | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |   |    |   |   |   |   |    |   |   |
|---|----|---|---|---|---|---|---|---|---|---|---|-----|----|---|---|---|---|---|---|---|---|---|---|----|---|---|---|---|----|---|---|
| 1 | 0  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9   | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2  | 1 | 0 |
| P | RE | D | 1 | 0 | 0 | 1 |   |   |   |   | C | )FF | SE | Γ |   |   |   |   | 0 | 0 | 0 |   |   | RD |   |   |   |   | RS |   |   |

#### 3.17.2 Syntax

• LB[PN] Rd, (Rs [+ OFFSET])

### 3.17.3 Type

LB is a Memory operation. It may only be placed in the first or second slot in an instruction packet.

### 3.17.4 Behavior

LB loads a byte from the specified address into Rd. The address is computed by sign-extending the OFFSET field to 32 bits and adding it to the value of Rs. The high 24 bits of Rd are zeroed.

## 3.18 LH - Load Half-Word

### 3.18.1 Encoding

| 3 | 3   | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1   | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |   |    |   |   |   |   |    |   |   |
|---|-----|---|---|---|---|---|---|---|---|---|---|-----|----|---|---|---|---|---|---|---|---|---|---|----|---|---|---|---|----|---|---|
| 1 | 0   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9   | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2  | 1 | 0 |
| P | RE. | D | 1 | 0 | 0 | 1 |   |   |   |   | ( | )FF | SE | Γ |   |   |   |   | 0 | 0 | 1 |   |   | RD |   |   |   |   | RS |   |   |

#### 3.18.2 Syntax

• LH[PN] Rd, (Rs [+ OFFSET])

### 3.18.3 Type

LH is a Memory operation. It may only be placed in the first or second slot in an instruction packet.

#### 3.18.4 Behavior

LH loads two bytes from the specified address into Rd. The address is computed by sign-extending the OFFSET field to 32 bits and adding it to the value of Rs. Only 2-byte aligned addresses may be accessed - the low bit of the address is ignored. The high 16 bits of Rd are zeroed.

## 3.19 LL - Load Linked

#### 3.19.1 Encoding

| 3 | 3   | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1  | 1    | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |   |    |   |   |   |   |    |   |   |
|---|-----|---|---|---|---|---|---|---|---|---|---|----|------|---|---|---|---|---|---|---|---|---|---|----|---|---|---|---|----|---|---|
| 1 | 0   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9  | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2  | 1 | 0 |
| P | RE. | D | 1 | 0 | 0 | 1 |   |   |   |   | C | FF | 'SE' | Γ |   |   |   |   | 0 | 1 | 1 |   |   | RD |   |   |   |   | RS |   |   |

### 3.19.2 Syntax

• LL[PN] Rd, (Rs [+ OFFSET])

#### 3.19.3 Type

LL is a Memory operation. It may only be placed in the first or second slot in an instruction packet.

#### 3.19.4 Behavior

LL loads a word from the specified address into Rd. The address is computed by sign-extending the OFFSET field to 32 bits and adding it to the value of Rs. Only 4-byte aligned addresses may be accessed - the low 2 bits of the address are ignored.

Additionally, LL sets the link bit. A future SC operation will only complete if no interrupt, exception, or ERET clears the link bit in the intervening period.

## 3.20 LW - Load Word

### 3.20.1 Encoding

| 3 | 3  | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1   | 1    | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |   |    |   |   |   |   |    |   |   |
|---|----|---|---|---|---|---|---|---|---|---|---|-----|------|---|---|---|---|---|---|---|---|---|---|----|---|---|---|---|----|---|---|
| 1 | 0  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9   | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2  | 1 | 0 |
| P | RE | D | 1 | 0 | 0 | 1 |   |   |   |   | C | )FF | 'SE' | Γ |   |   |   |   | 0 | 1 | 0 |   |   | RD |   |   |   |   | RS |   |   |

### 3.20.2 Syntax

• LW[PN] Rd, (Rs [+ OFFSET])

### 3.20.3 Type

LW is a Memory operation. It may only be placed in the first or second slot in an instruction packet.

#### 3.20.4 Behavior

LW loads a word from the specified address into Rd. The address is computed by sign-extending the OFFSET field to 32 bits and adding it to the value of Rs. Only 4-byte aligned addresses may be accessed - the low 2 bits of the address are ignored.

## 3.21 MFC - Move From Coprocessor Register

#### 3.21.1 Encoding

| 3 | 3   | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |   |    |   |   |   |   |    |   |   |
|---|-----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|---|---|----|---|---|
| 1 | 0   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2  | 1 | 0 |
| P | RE. | D | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | Х | X | Х | Х | Х | Х | Х | Х | Х | Х |   |   | RD |   |   |   | С | PR | 3 |   |

#### 3.21.2 Syntax

• MFC[PN] Rd, CPRs

### 3.21.3 Type

MFC is a Control operation. It may only be placed as the first instruction in a packet. It may only be used when the processor is in kernel mode.

#### 3.21.4 Behavior

MFC moves the contents of the specified coprocessor register into the specified general-purpose register. See TODO XXX Link for a description of the available coprocessor registers and their mnemonics.

## 3.22 MFHI - Move From Multiply/Division Overflow Register

#### 3.22.1 Encoding

| 3 3 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |   |    |   |   |   |   |   |   |   |
|-------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|---|---|---|---|---|
| 1 0 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PRED  | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | Х | Х | Х | Х | Х | Х | Х | Х | Х | Х |   |   | RD |   |   | Х | Х | Х | Х | Х |

#### **3.22.2** Syntax

• MFHI[PN] Rd

### 3.22.3 Type

MFHI is a Control operation. It may only be placed as the first instruction in a packet.

#### 3.22.4 Behavior

MFHI moves the contents of the multiply/division overflow register into the specified general-purpose register. This register stores the high bits of results of multiplication operations, or the remainders generated by division operations.

#### 3.23 MOV - Move

#### 3.23.1 Encoding

| 0 9 8 7 6 5 4 3 2 1 0 9 | 3 7 6 5 4 3 2 1 0 | 9 8 7 6 5 4 3 2 1 0 |
|-------------------------|-------------------|---------------------|
|-------------------------|-------------------|---------------------|

| PRED | 0 |   |   |   | CO  | ONS | TL  | OW |    |    |   | ] | ROT | 'AT | E | 1 | 0 | 0 | 0 | RD | CONSTHI |     |
|------|---|---|---|---|-----|-----|-----|----|----|----|---|---|-----|-----|---|---|---|---|---|----|---------|-----|
| PRED | 1 | 0 | 1 | : | SHI | FT  | AM' | Γ  | SI | HF | Х | X | Х   | Х   | Х | 1 | 0 | 0 | 0 | RD | RS      |     |
| PRED | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 1  | SI | HF |   |   | RT  |     |   | 1 | 0 | 0 | 0 | RD | RS      |     |
| PRED | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 0  | 0  | 0  | 0 | 0 | 0   | 0   | 0 | 1 | 0 | 0 | 0 | RD | RS      | LIM |

#### 3.23.2 Syntax

- MOV[PN] Rd, #Imm
- MOV[PN] Rd, Rs [SHF #Imm]
- MOV[PN] Rd, Rs SHF Rt

#### 3.23.3 Type

MOV is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.23.4 Behavior

MOV moves the value of its source operand into the specified destination register. If the second operand is a register, it may be shifted by an immediate value or by the contents of a register before being stored.

## 3.24 MTC - Move To Coprocessor Register

### 3.24.1 Encoding

| 3 3 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |   |    |   |   |   |   |    |   |   |
|-------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|---|---|----|---|---|
| 1 0 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2  | 1 | 0 |
| PRED  | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | Х | Х | Х | Х | X | Х | X | Х | Х | Х |   | С | PR | D |   |   |   | RS |   |   |

#### 3.24.2 Syntax

• MTC[PN] CPRd, Rs

### 3.24.3 Type

MTC is a Control operation. It may only be placed as the first instruction in a packet. It may only be used when the processor is in kernel mode.

#### 3.24.4 Behavior

MTC moves the contents of the selected general-purpose register into the specified coprocessor register. See TODO XXX Link for a description of the available coprocessor registers and their mnemonics.

# 3.25 MTHI - Move To Multiply/Division Overflow Register

## 3.25.1 Encoding

| 3 3 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |   |   |   |   |   |   |    |   |   |
|-------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|
| 1 0 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1 | 0 |
| PRED  | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | Х | Х | Х | X | X | X | X | Х | X | Х | X | Х | X | X | Х |   |   | RS |   |   |

## 3.25.2 Syntax

• MTHI[PN] Rs

### 3.25.3 Type

MTHI is a Control operation. It may only be placed as the first instruction in a packet.

### 3.25.4 Behavior

 $\operatorname{MTHI}$  moves the value of the specified general-purpose register into the multiply/division overflow register.

## 3.26 MVN - Move and Invert

#### 3.26.1 Encoding

| 1 0 9 | 8             | 7 | 6 | 5 | 4  | 3     | 2     | 1   | 0 | 9 | 8 | 7 | 6  | 5    | 4 | 3 | 2             | 1             | 0 | 9 | 8 | 7  | 6 | 5 | 4 | 3   | 2   | 1   | 0 |   |
|-------|---------------|---|---|---|----|-------|-------|-----|---|---|---|---|----|------|---|---|---------------|---------------|---|---|---|----|---|---|---|-----|-----|-----|---|---|
| DDED  | $\overline{}$ |   |   |   | CI | חווכי | י זיד | זגר |   |   |   | Т | ОТ | ית א | 7 | 1 | $\overline{}$ | $\overline{}$ | 1 |   |   | חם |   |   |   | CO. | мст | TIT |   | 1 |

| PRED | 0 |   |   |   | CO  | ONS | TL  | OW |    |    |   | ] | ROT | 'AT | Е | 1 | 0 | 0 | 1 | RD | CONSTHI |     |
|------|---|---|---|---|-----|-----|-----|----|----|----|---|---|-----|-----|---|---|---|---|---|----|---------|-----|
| PRED | 1 | 0 | 1 |   | SHI | FT  | AM' | Γ  | SI | ΙF | Х | X | Х   | Х   | Х | 1 | 0 | 0 | 1 | RD | RS      |     |
| PRED | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 1  | SI | ΙF |   |   | RT  |     |   | 1 | 0 | 0 | 1 | RD | RS      |     |
| PRED | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 0  | 0  | 0  | 0 | 0 | 0   | 0   | 0 | 1 | 0 | 0 | 1 | RD | RS      | LIM |

#### 3.26.2 Syntax

- MVN[PN] Rd, #Imm
- MVN[PN] Rd, Rs [SHF #Imm]
- MVN[PN] Rd, Rs SHF Rt

#### 3.26.3 Type

MVN is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.26.4 Behavior

MVN inverts its source operand, storing the result in the specified destination register. If the second operand is a register, it may be shifted by an immediate value or by the contents of a register before being inverted and stored.

## 3.27 MULT - Integer Multiplication

### 3.27.1 Encoding

| P | RE | D | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | S |   |   | RT |   |   | Х | Х | Х | Х |   |   | RD |   |   |   |   | RS |   |   |  |
|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|---|---|---|---|---|---|----|---|---|---|---|----|---|---|--|
| 1 | 0  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2  | 1 | 0 |  |
| 3 | 3  | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1  | 1 | 1 | 1 | 1 | 1 | 1 |   |   |    |   |   |   |   |    |   |   |  |

#### 3.27.2 Syntax

- MULT[PN] Rd, Rs, Rt
- MULTS[PN] Rd, Rs, Rt

#### 3.27.3 Type

MULT is a Control operation. It may only be placed as the first instruction in a packet.

#### 3.27.4 Behavior

MULT performs an integer multiplication on its two register operands. If the S bit is set, the operands are interpreted as two's complement signed integers; otherwise they are interpreted as unsigned. The low 32 bits of the 64 bit result are placed in the specified destination register, and the high 32 bits are placed in the special-purpose multiply/division overflow register, where they are accessible via the MFHI instruction.

#### NOR - Bitwise Logical NOR 3.28

#### 3.28.1 **Encoding**

6 5 4

| 1 0 3 | O | '             | U | J | -    | J   | _               |    | U   | 9  | O | ' | U   | J    | 7 | J             | _      | _ | U             | 9 | O | '  | U | J | - | J | _  | <br>U |
|-------|---|---------------|---|---|------|-----|-----------------|----|-----|----|---|---|-----|------|---|---------------|--------|---|---------------|---|---|----|---|---|---|---|----|-------|
| PRED  | 0 |               |   |   | CO   | )NS | TAI             | NT |     |    |   |   | ROT | 'ATI | Ε | 0             | 0      | 1 | 0             |   |   | RD |   |   |   |   | RS |       |
| משמם  | 1 | $\overline{}$ | 1 |   | TITE | TT. | ۸ ۱ <i>۸</i> ۱۲ | r  | CIT | TT |   |   | ЪΤ  | 1    |   | $\overline{}$ | $\sim$ | 1 | $\overline{}$ |   |   | חח |   |   |   |   | חכ |       |

| PRED | 0 |   |   |   | CU  | JNS | TA  | NT |    |    |   | F | ROT | AT. | E | 0 | 0 | 1 | 0 | RD | RS |     |
|------|---|---|---|---|-----|-----|-----|----|----|----|---|---|-----|-----|---|---|---|---|---|----|----|-----|
| PRED | 1 | 0 | 1 | : | SHI | FT  | AMT | Γ  | SI | HF |   |   | RT  |     |   | 0 | 0 | 1 | 0 | RD | RS |     |
| PRED | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 0  | 0  | 0  | 0 | 0 | 0   | 0   | 0 | 0 | 0 | 1 | 0 | RD | RS | LIM |

#### 3.28.2 **Syntax**

- NOR[PN] Rd, Rs, #Imm
- NOR[PN] Rd, Rs, Rt [SHF #Imm]

#### 3.28.3 Type

NOR is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.28.4 **Behavior**

Computes the bitwise logical NOR of the two operands, storing the result in the destination register. If two register operands are specified, the second may optionally be shifted by an immediate value before the computation is performed.

## 3.29 OR - Bitwise Logical OR

### 3.29.1 Encoding

 $3 \ \ 3 \ \ 2 \ \ 2 \ \ 2 \ \ 2 \ \ 2 \ \ 2 \ \ 2 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1 \ \ 1$ 

| 1 0 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2    | 1  | 0  | 9  | 8 | 7 | 6   | 5  | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2  | 1 | 0 |
|-------|---|---|---|---|-----|-----|------|----|----|----|---|---|-----|----|---|---|---|---|---|---|---|----|---|---|---|---|----|---|---|
| PRED  | 0 |   |   |   | C   | ONS | STA  | NT |    |    |   | ] | ROT | ΆT | E | 0 | 0 | 1 | 1 |   |   | RD |   |   |   |   | RS |   |   |
| PRED  | 1 | 0 | 1 |   | SHI | FT  | 'AM' | Г  | SI | HF |   |   | RT  |    |   | 0 | 0 | 1 | 1 |   |   | RD |   |   |   |   | RS |   |   |
| PRED  | 1 | 0 | 0 | 0 | 0   | 0   | 0    | 0  | 0  | 0  | 0 | 0 | 0   | 0  | 0 | 0 | 0 | 1 | 1 |   |   | RD |   |   |   |   | RS |   |   |

#### 3.29.2 Syntax

- OR[PN] Rd, Rs, #Imm
- OR[PN] Rd, Rs, Rt [SHF #Imm]

#### 3.29.3 Type

OR is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.29.4 Behavior

Computes the bitwise logical OR of the two operands, storing the result in the destination register. If two register operands are specified, the second may optionally be shifted by an immediate value before the computation is performed.

## 3.30 RSB - Reverse Subtraction

#### 3.30.1 Encoding

| 1 0 9 | 8 | 1 | 6 | 5 | 4  | 3   | 2   | 1 | U | 9 | 8 | 1 | 6   | 5   | 4 | 3 | 2 | 1 | U | 9 | 8 | 1  | 6 | 5 | 4 | 3 | 2  | 1 | U |  |
|-------|---|---|---|---|----|-----|-----|---|---|---|---|---|-----|-----|---|---|---|---|---|---|---|----|---|---|---|---|----|---|---|--|
| PRED  | 0 |   |   |   | CC | ONS | TAI | T |   |   |   | F | ROT | ATI | Ξ | 0 | 1 | 0 | 1 |   |   | RD |   |   |   |   | RS |   |   |  |

| PRED | 0 |   |   |   | CC  | ONS | TA: | NT |    |    |   | I | ROT | 'AT | E | 0 | 1 | 0 | 1 | RD | RS |     |
|------|---|---|---|---|-----|-----|-----|----|----|----|---|---|-----|-----|---|---|---|---|---|----|----|-----|
| PRED | 1 | 0 | 1 | 5 | SHI | FT  | AM. | Γ  | Sl | HF |   |   | RT  |     |   | 0 | 1 | 0 | 1 | RD | RS |     |
| PRED | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 0  | 0  | 0  | 0 | 0 | 0   | 0   | 0 | 0 | 1 | 0 | 1 | RD | RS | LIM |

## 3.30.2 Syntax

- RSB[PN] Rd, Rs, #Imm
- RSB[PN] Rd, Rs, Rt [SHF #Imm]

#### 3.30.3 Type

RSB is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.30.4 Behavior

Subtracts the value stored in RS from the value of the second operand, storing the result in the destination register. If two register operands are specified, the second may optionally be shifted by an immediate value before the computation is performed.

# 3.31 SB - Store Byte

#### 3.31.1 Encoding

| 3 | 3  | 2 | 2 | 2 | 2 | 2 | 2 | 2   | 2  | 2   | 2   | 1  | 1 | 1 | 1  | 1 | 1 | 1 | 1 | 1 | 1 |   |    |     |    |   |   |   |    |   |   |
|---|----|---|---|---|---|---|---|-----|----|-----|-----|----|---|---|----|---|---|---|---|---|---|---|----|-----|----|---|---|---|----|---|---|
| 1 | 0  | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2  | 1   | 0   | 9  | 8 | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8  | 7   | 6  | 5 | 4 | 3 | 2  | 1 | 0 |
| P | RE | D | 1 | 0 | 0 | 1 |   | OFI | SE | TH: | IGH | Ī. |   |   | RT |   |   | М | 1 | 0 | 0 | 0 | FF | SET | LO | W |   |   | RS |   |   |

#### 3.31.2 Syntax

• SB[PN] Rt, (Rs [+ OFFSET])

### 3.31.3 Type

SB is a Memory operation. It may only be placed in the first or second slot in an instruction packet.

#### 3.31.4 Behavior

SB stores the low byte of Rt at the provided address. The address is computed by sign-extending the OFFSET field to 32 bits and adding it to the value of Rs.

### 3.32 SC - Store Conditional

#### 3.32.1 Encoding

| 3 | 3  | 2 | 2 | 2 | 2 | 2 | 2 | 2   | 2  | 2   | 2   | 1 | 1 | 1 | 1  | 1 | 1 | 1 | 1 | 1 | 1 |   |    |     |    |   |   |   |    |   |   |
|---|----|---|---|---|---|---|---|-----|----|-----|-----|---|---|---|----|---|---|---|---|---|---|---|----|-----|----|---|---|---|----|---|---|
| 1 | 0  | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2  | 1   | 0   | 9 | 8 | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8  | 7   | 6  | 5 | 4 | 3 | 2  | 1 | 0 |
| P | RE | D | 1 | 0 | 0 | 1 |   | OFE | SE | TH: | IGH | I |   |   | RT |   |   | М | 1 | 1 | 1 | 0 | FF | SET | LO | W |   |   | RS |   |   |

#### 3.32.2 Syntax

• SC[PN] Rt, (Rs [+ OFFSET])

#### 3.32.3 Type

SC is a Memory operation. It may only be placed in the first or second slot in an instruction packet.

#### 3.32.4 Behavior

SC stores the value in Rt at the provided address, if the processor's link bit is set. The address is computed by sign-extending the OFFSET field to 32 bits and adding it to the value of Rs. Only 4-byte aligned addresses may be accessed - the low 2 bits of the address are ignored.

The link bit is set by executing the LL instruction, and is cleared by the SC or ERET instructions, or any time an exception or interrupt is dispatched. SC only completes if the link bit is set when it is executed - thus, if it completes, all instructions since the last LL instruction are known to have been executed atomically. The SC instruction writes a 1 into predicate register 0 if the store completes successfully, or a 0 if it fails.

## 3.33 SH - Store Half-Word

#### 3.33.1 Encoding

| 3 | 3   | 2 | 2 | 2 | 2 | 2 | 2 | 2   | 2  | 2   | 2   | 1  | 1 | 1 | 1  | 1 | 1 | 1 | 1 | 1 | 1 |   |    |     |    |   |   |   |    |   |   |
|---|-----|---|---|---|---|---|---|-----|----|-----|-----|----|---|---|----|---|---|---|---|---|---|---|----|-----|----|---|---|---|----|---|---|
| 1 | 0   | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2  | 1   | 0   | 9  | 8 | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8  | 7   | 6  | 5 | 4 | 3 | 2  | 1 | 0 |
| P | RE. | D | 1 | 0 | 0 | 1 |   | OFF | SE | TH: | IGH | Ī. |   |   | RT |   |   | М | 1 | 0 | 1 | 0 | FF | SET | LO | W |   |   | RS |   |   |

### 3.33.2 Syntax

• SH[PN] Rt, (Rs [+ OFFSET])

#### 3.33.3 Type

SH is a Memory operation. It may only be placed in the first or second slot in an instruction packet.

#### 3.33.4 Behavior

SH stores the low two bytes of Rt at the provided address. The address is computed by sign-extending the OFFSET field to 32 bits and adding it to the value of Rs. The address must be aligned to a multiple of 2; the low bit of the address is ignored.

## 3.34 SUB - Subtraction

#### 3.34.1 Encoding

| 1 0 9 | 8 | 7 | 6 | 5 | 4   | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1 | 0 |  |
|-------|---|---|---|---|-----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----|---|---|--|
|       |   |   |   |   | ~ ~ |   |   |   |   |   |   |   |   |   | _ |   |   | _ | _ | 1 |   |   |   |   |   |   | ~~ |   |   |  |

| PRED | 0 |   |   |   | C   | ONS | TA  | NT |    |    |   | I | ROT | 'AT | Е | 0 | 1 | 0 | 0 | RD | RS |     |
|------|---|---|---|---|-----|-----|-----|----|----|----|---|---|-----|-----|---|---|---|---|---|----|----|-----|
| PRED | 1 | 0 | 1 |   | SHI | FT  | AM' | Γ  | SI | ΗF |   |   | RT  |     |   | 0 | 1 | 0 | 0 | RD | RS |     |
| PRED | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 0  | 0  | 0  | 0 | 0 | 0   | 0   | 0 | 0 | 1 | 0 | 0 | RD | RS | LIM |

#### 3.34.2 Syntax

- SUB[PN] Rd, Rs, #Imm
- SUB[PN] Rd, Rs, Rt [SHF #Imm]

## 3.34.3 Type

SUB is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.34.4 Behavior

Subtracts the value of the second operand from the value in Rs, storing the result in the destination register. If two register operands are specified, the second may optionally be shifted by an immediate value before the computation is performed.

## 3.35 SW - Store Word

#### 3.35.1 Encoding

| 3 | 3   | 2 | 2 | 2 | 2 | 2 | 2 | 2   | 2  | 2   | 2   | 1  | 1 | 1 | 1  | 1 | 1 | 1 | 1 | 1 | 1 |   |    |     |    |   |   |   |    |   |   |
|---|-----|---|---|---|---|---|---|-----|----|-----|-----|----|---|---|----|---|---|---|---|---|---|---|----|-----|----|---|---|---|----|---|---|
| 1 | 0   | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2  | 1   | 0   | 9  | 8 | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8  | 7   | 6  | 5 | 4 | 3 | 2  | 1 | 0 |
| P | RE. | D | 1 | 0 | 0 | 1 |   | OFI | SE | TH: | IGH | Ī. |   |   | RT |   |   | М | 1 | 1 | 0 | 0 | FF | SET | LO | W |   |   | RS |   |   |

### 3.35.2 Syntax

• SW[PN] Rt, (Rs [+ OFFSET])

### 3.35.3 Type

SW is a Memory operation. It may only be placed in the first or second slot in an instruction packet.

#### 3.35.4 Behavior

SW stores the contents of Rt at the provided address. The address is computed by sign-extending the OFFSET field to 32 bits and adding it to the value of Rs. The address must be aligned to a multiple of 4; the low two bits of the address are ignored.

## 3.36 SXB - Sign-Extend Byte

#### 3.36.1 Encoding

| 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|

| PRED | 0 |   |   |   | CO  | ONS | TL  | OW |    |    |   | ] | ROT | 'AT | E | 1 | 0 | 1 | 0 | RD | CONSTHI |     |
|------|---|---|---|---|-----|-----|-----|----|----|----|---|---|-----|-----|---|---|---|---|---|----|---------|-----|
| PRED | 1 | 0 | 1 |   | SHI | FT  | AM' | Γ  | SI | HF | Х | X | Х   | Х   | Х | 1 | 0 | 0 | 1 | RD | RS      |     |
| PRED | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 1  | SI | HF |   |   | RT  |     |   | 1 | 0 | 1 | 0 | RD | RS      |     |
| PRED | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 0  | 0  | 0  | 0 | 0 | 0   | 0   | 0 | 1 | 0 | 1 | 0 | RD | RS      | LIM |

#### 3.36.2 Syntax

- SXB[PN] Rd, #Imm
- SXB[PN] Rd, Rs [SHF #Imm]
- SXB[PN] Rd, Rs SHF Rt

#### 3.36.3 Type

SXB is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.36.4 Behavior

SXB moves the low byte of its source operand into the specified destination register, sign-extending it across the rest of the register. If the second operand is a register, it may be shifted by an immediate value or by the contents of a register before being stored.

#### SXH - Sign-Extend Half-Word 3.37

#### 3.37.1 **Encoding**

1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0

| _ 0 0 |   |   |   |   | -    | _           |     | _  |    |    |   |   |     |      | - |   |   |   |   | <br> |    | <br> | <br> |     |     |  |
|-------|---|---|---|---|------|-------------|-----|----|----|----|---|---|-----|------|---|---|---|---|---|------|----|------|------|-----|-----|--|
| PRED  | 0 |   |   |   | CO   | NS'         | TLC | DW |    |    |   | I | ROT | 'ATI |   | 1 | 0 | 1 | 1 |      | RD |      | CO   | NS' | ГНІ |  |
| PRED  | 1 | 0 | 1 | 5 | SHIE | ?T <i>I</i> | AMT | •  | SF | ΙF | Х | X | Х   | Х    | Х | 1 | 0 | 1 | 1 |      | RD |      |      | RS  |     |  |

| ייייי דיייי | " |   |   |   | 0.0 | J110 | ,   | U 11 |    |    |   | 1 * | 10 1 |   | _ | - | • | - | - | 100 | OUNDINE |     |
|-------------|---|---|---|---|-----|------|-----|------|----|----|---|-----|------|---|---|---|---|---|---|-----|---------|-----|
| PRED        | 1 | 0 | 1 | : | SHI | FT   | AM' | Γ    | SH | ΙF | Х | X   | Х    | X | Х | 1 | 0 | 1 | 1 | RD  | RS      |     |
| PRED        | 1 | 0 | 0 | 0 | 0   | 0    | 0   | 1    | SH | ΙF |   |     | RT   |   |   | 1 | 0 | 1 | 1 | RD  | RS      |     |
| PRED        | 1 | 0 | 0 | 0 | 0   | 0    | 0   | 0    | 0  | 0  | 0 | 0   | 0    | 0 | 0 | 1 | 0 | 1 | 1 | RD  | RS      | LIM |

#### 3.37.2**Syntax**

- SXH[PN] Rd, #Imm
- SXH[PN] Rd, Rs [SHF #Imm]
- SXH[PN] Rd, Rs SHF Rt

#### 3.37.3Type

SXH is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.37.4Behavior

SXH moves the low two bytes of its source operand into the specified destination register, signextending it across the rest of the register. If the second operand is a register, it may be shifted by an immediate value or by the contents of a register before being stored.

# 3.38 SYSCALL - TODO XXX

# 3.38.1 Encoding

| 3 | 3   | 3  | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |   |   |   |   |   |   |   |   |   |
|---|-----|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1 | . ( | 0  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|   | PR  | EΙ | ) | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | Х | Х | Х | Х | Х | Х | Х | Х | Х | X | Х | X | Х | Х | Х | Х | X | X | Х | X |

## 3.39 XOR - Bitwise Exclusive OR

#### 3.39.1 Encoding

| 1 0 9 | 8             | 7 | 6 | 5 | 4          | 3    | 2   | 1   | 0 | 9 | 8 | 7 | 6   | 5     | 4  | 3 | 2 | 1 | 0 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2  | 1 | 0 |   |
|-------|---------------|---|---|---|------------|------|-----|-----|---|---|---|---|-----|-------|----|---|---|---|---|---|---|----|---|---|---|---|----|---|---|---|
| חשמת  | $\overline{}$ |   |   |   | <u>ر ر</u> | חוופ | тΛλ | ידו |   |   |   | I | דחכ | ית אי | C' | Λ | 1 | 1 |   |   |   | חם |   |   |   |   | DC |   |   | 1 |

| PRED | 0 |   |   |   | CC  | ONS | TAl | NT |    |    |   | I | ROT | 'AT | E | 0 | 1 | 1 | 0 | RD | RS |     |
|------|---|---|---|---|-----|-----|-----|----|----|----|---|---|-----|-----|---|---|---|---|---|----|----|-----|
| PRED | 1 | 0 | 1 | 5 | SHI | FT  | AM' | Γ  | SI | HF |   |   | RT  |     |   | 0 | 1 | 1 | 0 | RD | RS |     |
| PRED | 1 | 0 | 0 | 0 | 0   | 0   | 0   | 0  | 0  | 0  | 0 | 0 | 0   | 0   | 0 | 0 | 1 | 1 | 0 | RD | RS | LIM |

#### 3.39.2 Syntax

- XOR[PN] Rd, Rs, #Imm
- XOR[PN] Rd, Rs, Rt [SHF #Imm]

#### 3.39.3 Type

XOR is an ALU operation. It may be placed in any slot of a packet. If the long immediate form is used it must not be located in the last slot in a packet, and no instruction may be specified in the following slot.

#### 3.39.4 Behavior

Computes the bitwise logical XOR of the two operands, storing the result in the destination register. If two register operands are specified, the second may optionally be shifted by an immediate value before the computation is performed.