## Jeu d'instructions R12 (version 2.0)

|             | Encodage sur 12 bits                        |    |   |    |            |           |            |         |        |          |                                             |                                         |                                             |
|-------------|---------------------------------------------|----|---|----|------------|-----------|------------|---------|--------|----------|---------------------------------------------|-----------------------------------------|---------------------------------------------|
| Instruction | 11                                          | 10 | 9 | 8  | nco<br>7   | dage<br>6 | sur 1      | 4       | s<br>3 | 2        | 1                                           | 0                                       | Description                                 |
| nop         |                                             |    |   |    | sans effet |           |            |         |        |          | (                                           | )                                       | Aucune opération                            |
| add         | 1                                           |    |   |    |            |           |            |         |        |          | 1                                           |                                         | Regs[rd] ← Regs[rs1] + Regs[rs2]            |
| sub         | 0                                           |    |   |    |            |           |            |         |        |          | 2                                           | 2                                       | Regs[rd] ← Regs[rs1] - Regs[rs2]            |
| mult        |                                             |    |   |    |            |           |            |         |        |          | 3                                           | 3                                       | Regs[rd] ← Regs[rs1] * Regs[rs2]            |
| div         |                                             |    |   |    | 1          |           |            |         |        |          | (                                           | )                                       | Regs[rd] ← Regs[rs1] / Regs[rs2]            |
| mod         | 1                                           |    |   |    |            |           |            | rs2     |        | ,        |                                             | Regs[rd] ← Regs[rs1] % Regs[rs2]        |                                             |
| and         |                                             |    |   |    |            |           |            |         |        | 2        | 2                                           | Regs[rd] ← Regs[rs1] & Regs[rs2]        |                                             |
| or          |                                             |    |   |    |            |           |            |         |        | 3        | 3                                           | Regs[rd] ← Regs[rs1]   Regs[rs2]        |                                             |
| xor         |                                             |    |   |    | 1          |           |            |         |        |          | (                                           | )                                       | Regs[rd] ← Regs[rs1] ^ Regs[rs2]            |
| -           | 2                                           |    |   |    |            | ,         |            |         |        |          |                                             | Réservé pour expansion future           |                                             |
| -           |                                             |    |   |    |            | 2         |            |         |        |          | 2                                           | Réservé pour expansion future           |                                             |
| not         |                                             |    |   |    |            | rs1       |            |         |        | 3        | Regs[rd] ← Regs[rs1] ^ 1₁₂                  |                                         |                                             |
| addi        | 3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11 |    |   | rd |            |           |            |         |        |          | Regs[rd] ← Regs[rs1] + imm                  |                                         |                                             |
| subi        |                                             |    |   |    |            |           |            |         |        |          |                                             | Regs[rd] ← Regs[rs1] - imm              |                                             |
| multi       |                                             |    |   |    |            |           |            |         |        |          | Regs[rd] ← Regs[rs1] * imm                  |                                         |                                             |
| divi        |                                             |    |   |    |            |           |            |         |        | i()      |                                             | Regs[rd] ← Regs[rs1] / imm              |                                             |
| modi        |                                             |    |   |    |            |           |            |         |        |          |                                             | Regs[rd] ← Regs[rs1] % imm              |                                             |
| shli        |                                             |    |   |    |            |           |            | imm (no |        | n signe) | Regs[rd] ← Regs[rs1] << imm                 |                                         |                                             |
| shri        |                                             |    |   |    |            |           |            |         |        |          | Regs[rd] ← Regs[rs1] >> imm                 |                                         |                                             |
| ld          |                                             |    |   |    |            |           |            |         |        |          |                                             | Regs[rd] ← MEM[Regs[rs1] + imm]         |                                             |
| sd          |                                             |    |   |    |            |           |            |         |        |          |                                             | MEM[Regs[rs1] + imm] ← Regs[rd]         |                                             |
| jalr        |                                             |    |   | 1  |            |           |            |         |        |          |                                             | Regs[rd] ← PC + 1, PC ← Regs[rs1] + imm |                                             |
| jal         | 13                                          |    |   |    | 1          |           |            |         |        |          |                                             |                                         | Regs[rd] ← PC + 1, PC ← PC + imm            |
| bz          | 14<br>15                                    |    |   |    | <u> </u>   | rs        | imm (signé |         |        | )        | if (Regs[rs] == 0) PC $\leftarrow$ PC + imm |                                         |                                             |
| bnz         |                                             |    |   |    |            |           |            |         |        |          |                                             |                                         | if (Regs[rs] != 0) PC $\leftarrow$ PC + imm |