# #4: Encoding MIPS Instructions

# Computer Architecture 2021/2022 Ricardo Rocha

Computer Science Department, Faculty of Sciences, University of Porto

### **Instruction Set**

The words of a computer's language are called **instructions** and the vocabulary of commands understood by a given architecture is called an **instruction set**. Common groups of instructions are:

- Arithmetic instructions
- Logical instructions
- Data transfer instructions
- Conditional branch instructions
- Unconditional jump instructions

## Registers

MIPS has 32 registers, numbered from 0 to 31, each with 32 bits.

To identify a register in MIPS we thus need 5 bits  $(2^5=32)$ .

| Name               | Register number | Usage                                        |
|--------------------|-----------------|----------------------------------------------|
| \$zero             | 0               | The constant value 0                         |
| \$ v 0-\$ v 1      | 2–3             | Values for results and expression evaluation |
| \$a0-\$a3          | 4–7             | Arguments                                    |
| \$t0-\$t7          | 8–15            | Temporaries                                  |
| \$s0 <b>-</b> \$s7 | 16–23           | Saved                                        |
| \$t8-\$t9          | 24–25           | More temporaries                             |
| \$gp               | 28              | Global pointer                               |
| \$sp               | 29              | Stack pointer                                |
| \$fp               | 30              | Frame pointer                                |
| \$ra               | 31              | Return address                               |

### **Instruction Format**

MIPS instructions are encoded in binary, as 32-bit instruction words, called machine code. The layout of an instruction is called the instruction format. Only 3 different formats exist.

| Name       |        |        | Fie    | Comments          |                         |        |                                        |
|------------|--------|--------|--------|-------------------|-------------------------|--------|----------------------------------------|
| Field size | 6 bits | 5 bits | 5 bits | 5 bits            | 5 bits                  | 6 bits | All MIPS instructions are 32 bits long |
| R-format   | ор     | rs     | rt     | rd                | rd shamt funct          |        | Arithmetic instruction format          |
| I-format   | ор     | rs     | rt     | address/immediate |                         |        | Transfer, branch, imm. format          |
| J-format   | ор     |        | ta     | rget addres       | Jump instruction format |        |                                        |

### **Instruction Fields**

| Name       |        |        | Fie    | Comments          |                |                         |                                        |
|------------|--------|--------|--------|-------------------|----------------|-------------------------|----------------------------------------|
| Field size | 6 bits | 5 bits | 5 bits | 5 bits            | 5 bits         | 6 bits                  | All MIPS instructions are 32 bits long |
| R-format   | ор     | rs     | rt     | rd                | rd shamt funct |                         | Arithmetic instruction format          |
| I-format   | ор     | rs     | rt     | address/immediate |                |                         | Transfer, branch, imm. format          |
| J-format   | ор     |        | ta     | arget addre       | SS             | Jump instruction format |                                        |

#### MIPS fields have names to make them easier to discuss:

- op basic operation of the instruction, traditionally called the opcode
- rs the first register source operand
- rt the second register source operand
- rd the register destination operand, which gets the result of the operation
- **shamt** shift amount to be used in shift instructions, zero otherwise
- funct often called the function code, selects the specific variant of the operation in the opcode field

## **Instruction Opcodes**

|        | op(31:26):  |                 |        |        |        |        |        |        |  |  |
|--------|-------------|-----------------|--------|--------|--------|--------|--------|--------|--|--|
| 28–26  | 0(000)      | 1(001)          | 2(010) | 3(011) | 4(100) | 5(101) | 6(110) | 7(111) |  |  |
| 31–29  |             |                 |        |        |        |        |        |        |  |  |
| 0(000) | <u>Rfmt</u> | <u>Bltz/gez</u> | j      | jal    | beq    | bne    | blez   | bgtz   |  |  |
| 1(001) | addi        | addiu           | slti   | sltiu  | ANDi   | ORi    | xORi   | lui    |  |  |
| 2(010) | TLB         | <u>F1Pt</u>     |        |        |        |        |        |        |  |  |
| 3(011) |             |                 |        |        |        |        |        |        |  |  |
| 4(100) | 1b          | 1h              | lwl    | 1 w    | lbu    | 1hu    | lwr    |        |  |  |
| 5(101) | sb          | sh              | swl    | SW     |        |        | swr    |        |  |  |
| 6(110) | 1wc0        | lwc1            |        |        |        |        |        |        |  |  |
| 7(111) | swc0        | swc1            |        |        |        |        |        |        |  |  |

### **R-format Function Codes**

|        | op(31:26)=000000 (R-format), funct(5:0) |        |                        |                      |         |        |        |              |  |  |
|--------|-----------------------------------------|--------|------------------------|----------------------|---------|--------|--------|--------------|--|--|
| 2–0    | 0(000)                                  | 1(001) | 2(010)                 | 3(011)               | 4(100)  | 5(101) | 6(110) | 7(111)       |  |  |
| 5–3    |                                         |        |                        |                      |         |        |        |              |  |  |
| 0(000) | shift left<br>logical                   |        | shift right<br>logical | sra                  | sllv    |        | srlv   | srav         |  |  |
| 1(001) | jump register                           | jalr   |                        |                      | syscall | break  |        |              |  |  |
| 2(010) | mfhi                                    | mthi   | mflo                   | mtlo                 |         |        |        |              |  |  |
| 3(011) | mult                                    | multu  | div                    | divu                 |         |        |        |              |  |  |
| 4(100) | add                                     | addu   | subtract               | subu                 | and     | or     | xor    | not or (nor) |  |  |
| 5(101) |                                         |        | set 1.t.               | set l.t.<br>unsigned |         |        |        |              |  |  |
| 6(110) |                                         |        |                        |                      |         |        |        |              |  |  |
| 7(111) |                                         |        |                        |                      |         |        |        |              |  |  |

## From Assembly to Machine Code

Consider the instruction: add \$t0, \$s1, \$s2. Its decimal representation is:

- op = o (arithmetic)
- rs = 17 (\$S1)
- rt = 18 (\$s2)
- rd = 8 (\$to)
- shamt = o (not used)
- funct = 32 (add)

| 0 17 | 18 | 8 | 0 | 32 |
|------|----|---|---|----|
|------|----|---|---|----|

### And the binary representation is:

| 000000 | 10001  | 10010  | 01000  | 00000  | 100000 |
|--------|--------|--------|--------|--------|--------|
| 6 bits | 5 bits | 5 bits | 5 bits | 5 bits | 6 bits |

## From Assembly to Machine Code

| Name       |        |        | Fie    | Comments          |                |        |                                        |
|------------|--------|--------|--------|-------------------|----------------|--------|----------------------------------------|
| Field size | 6 bits | 5 bits | 5 bits | 5 bits            | 5 bits         | 6 bits | All MIPS instructions are 32 bits long |
| R-format   | ор     | rs     | rt     | rd                | rd shamt funct |        | Arithmetic instruction format          |
| I-format   | ор     | rs     | rt     | address/immediate |                |        | Transfer, branch, imm. format          |
| J-format   | ор     |        | ta     | rget addres       | SS             |        | Jump instruction format                |

In branch (I-format) and jump (J-format) instructions, the **address** and **target address** fields need to be shifted left 2 bits to correctly represent a valid instruction address (32-bits aligned).

```
beq $$1, $$2, 25 (25<<2 = 100)
j 2500 (2500<<2 = 10000)
```