## Jeu d'instructions R12 (version 1.0)

|             | Encodage sur 12 bits |     |               |          |         |   |    |     |   |                                                            |
|-------------|----------------------|-----|---------------|----------|---------|---|----|-----|---|------------------------------------------------------------|
| Instruction | 11 10                | 9   | 8             | 7 6      | 5       | 4 | 3  | 2 1 | 0 | Description                                                |
| add         |                      | rs1 |               | rs2      | 0       |   |    |     |   | Regs[rd] ← Regs[rs1] + Regs[rs2]                           |
| sub         |                      |     |               |          | :       | 1 | 0  |     |   | Regs[rd] ← Regs[rs1] - Regs[rs2]                           |
| mult        |                      |     |               |          | 7       | 2 |    | 0   | ) | Regs[rd] ← Regs[rs1] * Regs[rs2]                           |
| div         |                      |     |               |          |         | 3 |    |     |   | Regs[rd] ← Regs[rs1] / Regs[rs2]                           |
| mod         |                      |     |               |          | (       | 9 |    |     |   | Regs[rd] ← Regs[rs1] % Regs[rs2]                           |
| and         |                      |     | -1            |          | :       | 1 | 1  |     |   | Regs[rd] ← Regs[rs1] & Regs[rs2]                           |
| or          |                      |     | <b>&gt;</b> Τ |          | 7       | 2 |    |     |   | Regs[rd] ← Regs[rs1]   Regs[rs2]                           |
| xor         |                      |     |               |          |         | 3 |    |     |   | Regs[rd] ← Regs[rs1] ^ Regs[rs2]                           |
| beq         |                      |     |               |          | (       | 9 | 2  |     |   | if (Regs[rs1] == Regs[rs2]) PC ← Regs[rd]                  |
| bne         |                      |     |               |          | :       | 1 |    |     |   | if (Regs[rs1] != Regs[rs2]) PC ← Regs[rd]                  |
| blt         |                      |     |               |          | 7       | 2 |    |     |   | if (Regs[rs1] < Regs[rs2]) PC ← Regs[rd]                   |
| ble         |                      |     |               |          |         | 3 |    |     |   | if (Regs[rs1] <= Regs[rs2]) PC ← Regs[rd]                  |
| addi        | rd                   | rs  |               |          |         |   | 3  |     |   | Regs[rd] ← Regs[rs] + imm                                  |
| subi        |                      |     |               |          |         |   |    | 4   |   | Regs[rd] ← Regs[rs] - imm                                  |
| multi       |                      |     |               |          |         |   |    | 5   |   | Regs[rd] ← Regs[rs] * imm                                  |
| divi        |                      |     |               |          |         |   |    |     |   | Regs[rd] ← Regs[rs] / imm                                  |
| modi        |                      |     |               | <u>.</u> |         |   |    |     |   | Regs[rd] ← Regs[rs] % imm                                  |
| shli        |                      |     | S             | Lr       | nm      |   | 8  |     |   | Regs[rd] ← Regs[rs] << imm                                 |
| shri        |                      |     |               |          |         |   |    |     |   | Regs[rd] ← Regs[rs] >> imm                                 |
| ld          |                      |     |               |          |         |   | 10 |     |   | Regs[rd] ← Mem[Regs[rs] + imm]                             |
| sd          |                      |     |               |          |         |   |    |     |   | Mem[Regs[rd] + imm] ← Regs[rs]                             |
| jalr        |                      |     |               |          |         |   | 12 |     |   | Regs[rd] ← PC + 1, PC ← Regs[rs] + imm                     |
| jal         |                      |     |               |          | (signé) |   |    | 13  |   | Regs[rd] $\leftarrow$ PC + 1, PC $\leftarrow$ PC + 1 + imm |
| bz          |                      |     | imm           | (sig     |         |   |    | 14  |   | if (Regs[rd] == 0) PC ← PC + 1 + imm                       |
| bnz         |                      |     |               |          |         |   |    | 15  |   | if (Regs[rd] != 0) PC ← PC + 1 + imm                       |