| 31 | 27                    | 26   | 25 | 24 |     | 20 | 19  | 15  | 14  | 12  | 11   | 7       | 6      | 0      |         |
|----|-----------------------|------|----|----|-----|----|-----|-----|-----|-----|------|---------|--------|--------|---------|
|    | funct7                |      |    |    | rs2 |    | rs1 | L   | fun | ct3 | 1    | rd      | opc    | ode    | R-type  |
|    | imm[11:0]             |      |    |    |     |    |     | rs1 |     | ct3 | rd   |         | opcode |        | I-type  |
|    | imm[11:5              | 5]   |    |    | rs2 |    | rs1 | L   | fun | ct3 | imn  | n[4:0]  | opc    | ode    | S-type  |
| ir | nm[12 10]             | ):5] |    |    | rs2 |    | rs1 | L   | fun | ct3 | imm[ | 4:1 11] | opc    | ode    | SB-type |
|    | imm[31:12]            |      |    |    |     |    |     |     |     | 1   | rd   | opc     | ode    | U-type |         |
|    | imm[20 10:1 11 19:12] |      |    |    |     |    |     |     |     |     | 1    | rd      | opc    | ode    | UJ-type |

## RV32I Base Instruction Set imm[31:12]

|              |                             |           | n[31:12]  |            | rd         |            | 0111         | LUI rd,imm    |                     |                   |  |
|--------------|-----------------------------|-----------|-----------|------------|------------|------------|--------------|---------------|---------------------|-------------------|--|
|              |                             |           | n[31:12]  |            | rd 0010111 |            | AUIPC rd,imm |               |                     |                   |  |
|              | imm                         | 120 1     | 0:1 11 19 | 9:12]      | rd 1101111 |            | JAL rd,imm   |               |                     |                   |  |
| ir           | imm[11:0]                   |           |           |            | rs1        |            | rd           | 110           | 0111                | JALR rd,rs1,imm   |  |
| imm[12 10    | ):5]                        | _         | rs2       | rs1        |            | 000        | imm[4:1 11]  | 110           | 0011                | BEQ rs1,rs2,imm   |  |
| imm[12]10    | ):5]                        |           | rs2       | rs1        |            | 001        | imm[4:1 11]  | 110           | 0011                | BNE rs1,rs2,imm   |  |
| imm[12]10    | ):5]                        |           | rs2       | rs1        |            | 100        | imm[4:1 11]  | 110           | 0011                | BLT rs1,rs2,imm   |  |
| imm[12]10    | ):5]                        |           | rs2       | rs1        |            | 101        | imm[4:1 11]  | 110           | 0011                | BGE rs1,rs2,imm   |  |
| imm[12 10]   | ):5]                        |           | rs2       | rs1        |            | 110        | imm[4:1 11]  | 110           | 0011                | BLTU rs1,rs2,imm  |  |
| imm[12]10    | ):5]                        |           | rs2       | rs1        | _          | 111        | imm[4:1 11]  | 110           | 0011                | BGEU rs1,rs2,imm  |  |
| ir           | $\frac{1}{\text{nm}[11:0]}$ | ]         |           | rs1        |            | 000        | rd           | 0000011       |                     | LB rd,rs1,imm     |  |
| ir           | $\frac{1}{\text{nm}[11:0]}$ | ĺ         |           | rs1 (      |            | 001        | rd           | 000           | 0011                | LH rd,rs1,imm     |  |
|              | $\frac{1}{\text{nm}[11:0]}$ | _         |           | rs1 010    |            |            | rd           | 000           | 0011                | LW rd,rs1,imm     |  |
|              | $\frac{1}{\text{nm}[11:0]}$ |           |           | rs1 100    |            |            | rd           | 000           | 0011                | LBU rd,rs1,imm    |  |
|              | $\frac{1}{\text{nm}[11:0]}$ | _         |           | rs1        |            | 101        | rd           | 0000011       |                     | LHU rd,rs1,imm    |  |
| imm[11:      |                             |           | rs2       | rs1        |            | 000        | imm[4:0]     |               | 0011                | SB rs1,rs2,imm    |  |
| imm[11:      |                             |           | rs2       | rs1        |            | 001        | imm[4:0]     |               | 0011                | SH rs1,rs2,imm    |  |
| imm[11:      |                             |           | rs2       | rs1        |            | 010        | imm[4:0]     |               | 0011                | SW rs1,rs2,imm    |  |
|              | $\frac{1}{\text{nm}} 11:0$  |           |           | rs1        |            | 000        | rd           |               | 0011                | ADDI rd,rs1,imm   |  |
|              | $\frac{1}{\text{nm}[11:0]}$ | _         |           | rs1        |            | 010        | rd           |               | 0011                | SLTI rd,rs1,imm   |  |
|              | imm[11:0]                   |           |           |            |            | 011        | rd           |               | 0010011 SLTIU rd,rs |                   |  |
|              | imm[11:0]                   |           |           |            |            | 100        | rd           |               | 0011                | XORI rd,rs1,imm   |  |
|              | nm[11:0]                    |           |           | rs1<br>rs1 |            | 110        | rd 00100     |               |                     | ORI rd,rs1,imm    |  |
|              | imm[11:0]                   |           |           |            |            | 111        | rd           |               | 0011                | ANDI rd,rs1,imm   |  |
| 0000000      |                             |           |           |            |            | 001        | rd           |               | 0011                | SLLI rd,rs1,shamt |  |
| 0000000      |                             |           | namt      | rs1        |            | 101        | rd           |               | 0011                | SRLI rd,rs1,shamt |  |
| 0100000      |                             | shamt     |           | rs1        |            | 101        | rd           |               | 0011                | SRAI rd,rs1,shamt |  |
| 0000000      |                             |           |           | rs1        |            | 000        | rd           |               | 0011                | ADD rd,rs1,rs2    |  |
| 0100000      |                             |           | rs2       | rs1        |            | 000        | rd           |               | 0011                | SUB rd,rs1,rs2    |  |
| 0000000      |                             |           |           | rs1        |            | 001        | rd           |               | 0011                | SLL rd,rs1,rs2    |  |
| 0000000      |                             |           |           |            | rs1        |            | rd           |               | 0011                | SLT rd,rs1,rs2    |  |
| 0000000      |                             | rs2 $rs2$ |           | rs1        |            | 010<br>011 | rd           |               | 0011                | SLTU rd,rs1,rs2   |  |
|              | 0000000                     |           | rs2       |            | rs1        |            | rd           |               | 0011                | XOR rd,rs1,rs2    |  |
|              | 0000000 rs2                 |           |           | rs1        |            | 100<br>101 | rd           |               | 0011                | SRL rd,rs1,rs2    |  |
|              | 0100000 rs2                 |           |           | rs1        |            | 101        | rd           |               | 0011                | SRA rd,rs1,rs2    |  |
| 0000000 rs2  |                             |           |           |            |            | 110        | rd           | 0110011       |                     | OR rd,rs1,rs2     |  |
| 0000000 rs2  |                             |           |           | rs1        |            | 111        | rd           | 0110011       |                     | AND rd,rs1,rs2    |  |
| 0000         | pred                        |           | succ      | 0000       |            | 000        | 00000        |               | 1111                | FENCE             |  |
| 0000         | 0000                        |           | 0000      | 0000       |            | 001        | 00000        |               | 1111                | FENCE.I           |  |
|              | 0000000                     |           | 0000      | 0000       |            | 000        | 00000        |               | 0011                | SCALL             |  |
|              | 0000000                     |           |           | 00000 000  |            |            | 00000        | 1110011       |                     | SBREAK            |  |
|              | 0000000                     |           |           | 0000       |            | 010        | rd           |               | 0011                | RDCYCLE rd        |  |
|              | 0100000                     |           |           | 0000       |            | 010        | rd           |               | 0011                | RDCYCLEH rd       |  |
|              | 0000000                     |           |           | 0000       |            | 010        | rd           |               | 0011                | RDTIME rd         |  |
| 110          |                             | 0000      |           | 010        | rd         |            | 0011         | RDTIMEH rd    |                     |                   |  |
| 110          |                             | 0000      |           | 010        | rd         |            | 0011         | RDINSTRET rd  |                     |                   |  |
|              |                             | 00000 010 |           |            | rd         |            | 0011         | RDINSTRETH rd |                     |                   |  |
| 110010000010 |                             |           |           | 0000       |            | 010        | 1 u          | 111           | 0011                | ] IDINSTILLITIA   |  |