### 5' Esercitazione

https://politecnicomilano.webex.com/meet/gianenrico.conti

# Gian Enrico Conti MIPS architecture OPCODES

Architettura dei Calcolatori e Sistemi Operativi 2021-22



# **Outline**

#### Formato Istruzioni

Istruzioni per formato

# Formato istruzioni

### Esistono 3 tipi di formati istruzioni nel processore MIPS

- Istruzioni R
- Istruzioni I
- Istruzioni J

| Nome                    | Campi |                           |       |                         |       | Commenti                                         |                                                                                     |
|-------------------------|-------|---------------------------|-------|-------------------------|-------|--------------------------------------------------|-------------------------------------------------------------------------------------|
| Dimensione<br>del campo | 6 bit | 5 bit                     | 5 bit | 5 bit                   | 5 bit | 6 bit                                            | Tutte le istruzioni MIPS sono a 32 bit                                              |
| Formato R               | codop | rs                        | rt    | rd                      | shamt | funz                                             | Formato delle istruzioni aritmetiche                                                |
| Formato I               | codop | rs                        | rt    | indirizzo /<br>costante |       |                                                  | Formato delle istruzioni di trasferimento dati<br>di salto condizionato e immediate |
| Formato J               | codop | indirizzo di destinazione |       |                         |       | Formato delle istruzioni di salto incondizionato |                                                                                     |

#### I campi definiti sono

codopcodice operativo

– rs primo registro sorgente

– rt secondo registro sorgente

rdregistro destinazione

shamtshift amount

funzcodice funzione

costantevalore costante

indirizzo di destinazione

# Istruzioni per formato

| Istruzioni MIPS                     | Nome  | Formato | Pseudoistruzioni MIPS        | Nome  | Formato |
|-------------------------------------|-------|---------|------------------------------|-------|---------|
| add                                 | add   | R       | move                         | move  | R       |
| subtract                            | sub   | R       | multiply                     | mult  | R       |
| add immediate                       | addi  | I       | multiply immediate           | multi | I       |
| load word                           | ٦w    | I       | load immediate               | li    | I       |
| store word                          | SW    | I       | branch less than             | blt   |         |
| load half                           | 1 h   | I       | branch less than or equal    | ble   | I       |
| load half unsigned                  | 1hu   | I       | branch greater than          | bgt   | I       |
| store half                          | sh    | I       | branch greater than or equal | bge   |         |
| load byte                           | 1 b   | I       |                              |       |         |
| load byte unsigned                  | 1 bu  | I       |                              |       |         |
| store byte                          | sb    | I       |                              |       |         |
| load linked                         | 11    | I       |                              |       |         |
| store conditional                   | Sc    | I       |                              |       |         |
| load upper immediate                | lui   | I       |                              |       |         |
| and                                 | and   | R       |                              |       |         |
| or                                  | or    | R       |                              |       |         |
| nor                                 | nor   | R       |                              |       |         |
| and immediate                       | andi  | I       |                              |       |         |
| or immediate                        | ori   | I       |                              |       |         |
| shift left logical                  | s11   | R       |                              |       |         |
| shift right logical                 | srl   | R       |                              |       |         |
| branch equal                        | beq   | I       |                              |       |         |
| branch not equal                    | bne   | I       |                              |       |         |
| set less than                       | slt   | R       |                              |       |         |
| set less than<br>immediate          | slti  | I       |                              |       |         |
| set less than<br>immediate unsigned | sltiu | I       |                              |       |         |
| jump                                | j     | J       |                              |       |         |
| jump register                       | jr    | R       |                              |       |         |
| jump and link                       | jal   | J       |                              |       |         |

#### **MIPS Reference Sheet**

(https://uweb.engr.arizona.edu/~ece369/Resources/spim/MIPSReference.pdf)

#### **Instruction Encodings**

| Register  | 000000ss | sssttttt | dddddaaa | aaffffff |
|-----------|----------|----------|----------|----------|
| Immediate | 00000088 | sssttttt | iiiiiiii | iiiiiiii |
| Jump      | ooooooii | iiiiiiii | iiiiiiii | iiiiiiii |

#### Opcode Table

| Instruction | Opcode/Function | Syntax    |
|-------------|-----------------|-----------|
| add         | 100000          | ArithLog  |
| addu        | 100001          | ArithLog  |
| addi        | 001000          | ArithLogI |
| addiu       | 001001          | ArithLogI |
| and         | 100100          | ArithLog  |
| andi        | 001100          | ArithLogI |
| div         | 011010          | DivMult   |
| divu        | 011011          | DivMult   |
| mult        | 011000          | DivMult   |
| multu       | 011001          | DivMult   |
| nor         | 100111          | ArithLog  |
| or          | 100101          | ArithLog  |
| ori         | 001101          | ArithLogI |
| sll         | 000000          | Shift     |
| sllv        | 000100          | ShiftV    |
| sra         | 000011          | Shift     |
| srav        | 000111          | ShiftV    |
| srl         | 000010          | Shift     |
| srlv        | 000110          | ShiftV    |
| sub         | 100010          | ArithLog  |
| subu        | 100011          | ArithLog  |
| xor         | 100110          | ArithLog  |
| xori        | 001110          | ArithLogI |
| lhi         | 011001          | LoadI     |
| llo         | 011000          | LoadI     |

| Instruction | Opcode/Function | Syntax                |
|-------------|-----------------|-----------------------|
| $_{ m slt}$ | 101010          | ArithLog              |
| sltu        | 101001          | ArithLog              |
| slti        | 001010          | ArithLogI             |
| sltiu       | 001001          | ArithLogI             |
| beq         | 000100          | Branch                |
| bgtz        | 000111          | BranchZ               |
| blez        | 000110          | BranchZ               |
| bne         | 000101          | Branch                |
| j           | 000010          | $\operatorname{Jump}$ |
| jal         | 000011          | $_{ m Jump}$          |
| jalr        | 001001          | JumpR                 |
| jr          | 001000          | JumpR                 |
| lb          | 100000          | LoadStore             |
| lbu         | 100100          | LoadStore             |
| lh          | 100001          | LoadStore             |
| lhu         | 100101          | LoadStore             |
| lw          | 100011          | LoadStore             |
| sb          | 101000          | LoadStore             |
| sh          | 101001          | LoadStore             |
| sw          | 101011          | LoadStore             |
| mfhi        | 010000          | MoveFrom              |
| mflo        | 010010          | MoveFrom              |
| mthi        | 010001          | MoveTo                |
| mtlo        | 010011          | MoveTo                |
| trap        | 011010          | Trap                  |

Some samples..

# **EXAMPLE:** R-type



add \$s4, \$t1, \$t2

In Mars:

| 0     |                    |            |                   | Text Segment            |  |  |
|-------|--------------------|------------|-------------------|-------------------------|--|--|
| Progr | Program Arguments: |            |                   |                         |  |  |
| Bkpt  | Address            | Code       | Basic             | Source                  |  |  |
|       | 0x00400000         | 0x012aa020 | add \$20,\$9,\$10 | 1: add \$s4, \$t1, \$t2 |  |  |
|       |                    |            |                   |                         |  |  |
|       |                    |            |                   |                         |  |  |

Rd: 20

**Rs:9** 

Rt: 10

Op = 00000

E dalla tabella prec.:

| Instruction | Opcode/Function | Syntax   |
|-------------|-----------------|----------|
| add         | 100000          | ArithLog |

# **EXAMPLE:** R-type

add \$s4, \$t1, \$t2

| 000000 | 01001 | 01010 | 10100 | 00000 | 1000000 |
|--------|-------|-------|-------|-------|---------|
|--------|-------|-------|-------|-------|---------|

add \$s4, \$t1, \$t2

Rd: 20 10100

Rs: 9 01001

Rt: 10 01010

# **EXAMPLE: lw, sw**

```
.text
lw $t0, -4(sp)
sw $s0, 16(sp)
                                                                       Text Segment
                         Program Arguments:
In Mars:
                         Bkpt Address
                                       Code
                                                Basic
                                                                   Source
                              0x00400000 0x8fa8fffc lw $8,0xffffffffc($29) 1: lw $t0, -4($sp)
                              0x00400004 0xafb00010 sw $16,0x00000010($29) 2: sw $s0, 16($sp)
                                                                      100011
Rd:
                                                      sb
                                                                      101000
      (SP)$29 = 29
Rs:
                                                      \operatorname{sh}
                                                                      101001
Rt:
       $8
                                                                      101011
                                                      sw
       $10
```

### **EXAMPLE:** salto

## beq \$at, \$zero, There

addi \$at, \$zero, 10 #dont care addi \$at, \$zero, 20 #dont care

There: sub \$at, \$at, 30 #dont care

In Mars:

| Code | Basic | Source | Sour

Rd: 0

Rs: 1

Si noti salto di 3 (3 istruz. = 12 celle)

# **EXAMPLE: lw, sw**

```
beq $at, $zero, There
li $t1,10
li $t2,20
add $t1, $t1, $t2
There: sub $at, $at,30
```

| 9101  | 001010 | Ammugi    |
|-------|--------|-----------|
| sltiu | 001001 | ArithLogI |
| beq   | 000100 | Branch    |
| bgtz  | 000111 | BranchZ   |
| blez  | 000110 | BranchZ   |

Rd: 0 Rs: 1



Offset= 3x4=12

### How to...

https://www.eg.bucknell.edu/~csci320/mips\_web/





#### Result

add \$t1 \$t1 \$t2

Binary: 00000001001010100100100000100000

Hex: 0x012A4820

| 31 | 26      | 25 21 | 20 16 | 15 11 | 10 6  | 5 0    |
|----|---------|-------|-------|-------|-------|--------|
|    | SPECIAL | \$t1  | \$t2  | \$t1  | 0     | ADD    |
|    | 000000  | 01001 | 01010 | 01001 | 00000 | 100000 |
|    | 6       | 5     | 5     | 5     | 5     | 6      |

#### ADD

#### Add Word

| Format:<br>ADD rd, rs, rt [R- | type]    |       | MIPS A | rchitecture E | xtension: MIPS I |
|-------------------------------|----------|-------|--------|---------------|------------------|
| 31                            | 26 25 21 | 20 16 | 15 11  | 10 6          | 5 0              |
| SPECIAL                       | rs       | rt    | rd     | 0             | ADD              |
| 000000                        |          |       |        | 00000         | 100000           |
| 6                             | 5        | 5     | 5      | 5             | 6                |