







| I-Type ALU Instructions                                                                                                                                                                                        |                  |               |           |           |                        |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------|-----------|-----------|------------------------|
| Instruction                                                                                                                                                                                                    | Meaning          | I-Type Format |           |           |                        |
| addi \$s1, \$s2, 10                                                                                                                                                                                            | \$s1 = \$s2 + 10 | op = 0x8      | rs = \$s2 | rt = \$s1 | imm <sup>16</sup> = 10 |
| addiu \$s1, \$s2, 10                                                                                                                                                                                           | \$s1 = \$s2 + 10 | op = 0x9      | rs = \$s2 | rt = \$s1 | imm <sup>16</sup> = 10 |
| andi \$s1, \$s2, 10                                                                                                                                                                                            | \$s1 = \$s2 & 10 | op = 0xc      | rs = \$s2 | rt = \$s1 | imm <sup>16</sup> = 10 |
| ori \$s1, \$s2, 10                                                                                                                                                                                             | \$s1 = \$s2   10 | op = 0xd      | rs = \$s2 | rt = \$s1 | imm <sup>16</sup> = 10 |
| xori \$s1, \$s2, 10                                                                                                                                                                                            | \$s1 = \$s2 ^ 10 | op = 0xe      | rs = \$s2 | rt = \$s1 | imm <sup>16</sup> = 10 |
| lui \$s1, 10                                                                                                                                                                                                   | \$s1 = 10 << 16  | op = 0xt      | 0         | rt = \$s1 | imm <sup>16</sup> = 10 |
| <ul> <li>In case of overflow, result is not written to destination register</li> <li>addiu: same operation as addi but overflow is ignored</li> <li>Immediate constant for addi and addiu is signed</li> </ul> |                  |               |           |           |                        |
| <ul> <li>No need for subi or subiu instructions</li> </ul>                                                                                                                                                     |                  |               |           |           |                        |
| Immediate constant for andi, ori, xori is unsigned                                                                                                                                                             |                  |               |           |           |                        |
| Lecture Slides on Computer<br>Architecture ICS 233 @ Dr A R                                                                                                                                                    |                  |               |           |           | 5                      |

| MIPS - Arith                                  | metic Instructions                                                                            |   |
|-----------------------------------------------|-----------------------------------------------------------------------------------------------|---|
| 🛛 addi 🛛 (add immediate sigr                  | ned)                                                                                          |   |
| Instruction Mnemonic :<br>addi rd, rs, const  | ;where rs, rd are registers,<br>; const is a 16-bit constant value<br>:overflow detected      |   |
| ➢ Meaning :<br>rd ← rs + const                | ,                                                                                             |   |
| ➢ Example :<br>addi \$s1, \$s2, 100           | ; \$s1 <del>←</del> \$s2 + 100                                                                |   |
| addiu (add immediate un                       | nsigned)                                                                                      |   |
| Instruction Mnemonic :<br>addiu rd, rs, const | ;where rs,  rd are registers,<br>; const is a 16-bit constant value<br>;overflow not detected |   |
| ➢ Meaning :<br>rd ← rs + const                |                                                                                               |   |
| Example :<br>addiu \$s1, \$s2, 100            | ; \$s1 <del>←</del> \$s2 + 100                                                                |   |
| Le<br>Arcł                                    | ecture Slides on Computer<br>hitecture ICS 233 @ Dr A R                                       | 6 |





















| Load and Store Instructions                                                                                                                                                                                                                                                                                      |                                 |                                                                      |                 |                   |                   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|----------------------------------------------------------------------|-----------------|-------------------|-------------------|
| Instruction                                                                                                                                                                                                                                                                                                      | Meaning                         | I-Type Format                                                        |                 | Format            |                   |
| lb rt, imm <sup>16</sup> (rs)                                                                                                                                                                                                                                                                                    | rt = MEM[rs+imm <sup>16</sup> ] | 0x20                                                                 | rs <sup>5</sup> | rt <sup>5</sup>   | imm <sup>16</sup> |
| Ih rt, imm <sup>16</sup> (rs)                                                                                                                                                                                                                                                                                    | rt = MEM[rs+imm <sup>16</sup> ] | 0x21                                                                 | rs <sup>5</sup> | rt <sup>5</sup>   | imm <sup>16</sup> |
| lw rt, imm <sup>16</sup> (rs)                                                                                                                                                                                                                                                                                    | rt = MEM[rs+imm <sup>16</sup> ] | 0x23                                                                 | rs⁵             | rt⁵               | imm <sup>16</sup> |
| Ibu rt, imm <sup>16</sup> (rs)                                                                                                                                                                                                                                                                                   | rt = MEM[rs+imm <sup>16</sup> ] | 0x24 rs <sup>5</sup> rt <sup>5</sup>                                 |                 | imm <sup>16</sup> |                   |
| Ihu rt, imm <sup>16</sup> (rs)                                                                                                                                                                                                                                                                                   | rt = MEM[rs+imm <sup>16</sup> ] | rt = MEM[rs+imm <sup>16</sup> ] 0x25 rs <sup>5</sup> rt <sup>5</sup> |                 | rt⁵               | imm <sup>16</sup> |
| sb rt, imm <sup>16</sup> (rs)                                                                                                                                                                                                                                                                                    | MEM[rs+imm <sup>16</sup> ] = rt | 0x28                                                                 | rs <sup>5</sup> | rt <sup>5</sup>   | imm <sup>16</sup> |
| sh rt, imm <sup>16</sup> (rs)                                                                                                                                                                                                                                                                                    | MEM[rs+imm <sup>16</sup> ] = rt | 0x29                                                                 | rs <sup>5</sup> | rt <sup>5</sup>   | imm <sup>16</sup> |
| sw rt, imm <sup>16</sup> (rs)                                                                                                                                                                                                                                                                                    | MEM[rs+imm <sup>16</sup> ] = rt | 0x2b                                                                 | rs⁵             | rt⁵               | imm <sup>16</sup> |
| <ul> <li>Base or Displacement Addressing is used         <ul> <li>Memory Address = Rs (base) + Immediate<sup>16</sup> (displacement)</li> </ul> </li> <li>Two variations on base addressing         <ul> <li>If Rs = \$7200 = 0 then</li> <li>Address = Immediate<sup>16</sup> (absolute)</li> </ul> </li> </ul> |                                 |                                                                      |                 |                   |                   |
| - If Immediate <sup>16</sup> = 0 then Address = Rs (register indirect)                                                                                                                                                                                                                                           |                                 |                                                                      |                 |                   |                   |
| Lecture Slides on Computer 17<br>Architecture ICS 233 @ Dr A R                                                                                                                                                                                                                                                   |                                 |                                                                      |                 |                   | 17                |





| _       |                                            |                                                                                             |    |
|---------|--------------------------------------------|---------------------------------------------------------------------------------------------|----|
|         | MIPS -                                     | - Data Transfer Instructions                                                                |    |
|         | lb (Load byte with sign exte               | nsion)                                                                                      |    |
| ۶       | Instruction Mnemonic :<br>Ib rd, const(rs) | ;where rs, rd are registers,                                                                |    |
|         |                                            | ;const is a 16-bit displacement                                                             |    |
|         | lb rd, addr                                | ; where addr is the label of the memory<br>location to be accessed                          |    |
| $\succ$ | Meaning :                                  |                                                                                             |    |
|         | rd ← Memory[rs + const]                    | ; load byte from memory to register                                                         |    |
| $\succ$ | Example :                                  |                                                                                             |    |
|         | lb \$s1, 100(\$s2)                         | ; \$s1 ← Memory[\$s2+100]                                                                   |    |
|         | lb \$s1, NUM1                              | ; load register \$s1 with a byte from<br>memory location NUM1                               |    |
|         | lbu (Load byte unsigned – w                | vithout sign extension)                                                                     |    |
| ≻       | Instruction Mnemonic :                     |                                                                                             |    |
|         | lbu rd, const(rs)                          | ;where rs, rd are registers,<br>;const is a 16-bit displacement                             |    |
|         | lbu rd, addr                               | ; where addr is the label of the memory<br>location to be accessed                          |    |
| $\succ$ | Meaning :                                  |                                                                                             |    |
|         | rd ← Memory[rs + const]                    | ; load unsigned byte from memory to register                                                |    |
| ≻       | Example :                                  |                                                                                             |    |
|         | lbu \$s1, 100(\$s2)                        | ; \$s1 ← Memory[\$s2+100]                                                                   |    |
|         | lbu \$s1, NUM1                             | ; load register \$s1 with a byte from<br>memory location NUM1<br>Lecture Slides on Computer | 20 |
|         |                                            | Architecture ICS 233 @ Dr A R                                                               |    |
|         |                                            | Nacoor                                                                                      |    |