| 31                    | 27               | 26 | 25       | 24         |     | 20                  | 19  | 15     | 14   | 12     | 11       | 7   | 6    | 0      |        |
|-----------------------|------------------|----|----------|------------|-----|---------------------|-----|--------|------|--------|----------|-----|------|--------|--------|
|                       | funct7           |    |          |            | rs2 |                     | rs  | s1     | fun  | ct3    |          | rd  | ope  | code   | R-type |
| imm[11:0]             |                  |    |          | rs1 funct3 |     | $\operatorname{rd}$ |     | opcode |      | I-type |          |     |      |        |        |
|                       | imm[11:5]        |    |          |            | rs2 |                     | rs1 |        | fun  | ct3    | imm[4:0] |     | ope  | code   | S-type |
| iı                    | imm[12 10:5] rs2 |    | rs1 func |            | ct3 | imm[4:1 11]         |     | ope    | code | B-type |          |     |      |        |        |
|                       | imm[31:12]       |    |          |            |     |                     |     |        |      |        | rd       | ope | code | U-type |        |
| imm[20 10:1 11 19:12] |                  |    |          |            |     |                     |     |        |      |        | rd       | ope | code | J-type |        |

# RV32I Base Instruction Set

|             |           |                        | - DONO LIBOU | CICCIOII O | ~~          |         |           |
|-------------|-----------|------------------------|--------------|------------|-------------|---------|-----------|
|             |           | imm[31:12]             |              |            | rd          | 0110111 | LUI       |
|             |           | imm[31:12]             |              |            | rd          | 0010111 | AUIPC     |
|             | imr       | n[20 10:1 11 1         | [9:12]       |            | rd          | 1101111 | JAL       |
| imm[11:0]   |           |                        | rs1          | 000        | rd          | 1100111 | JALR      |
| imm[12 10]  | ):5]      | rs2                    | rs1          | 000        | imm[4:1 11] | 1100011 | BEQ       |
| imm[12 10]  | ):5]      | rs2                    | rs1          | 001        | imm[4:1 11] | 1100011 | BNE       |
| imm[12 10]  | ):5]      | rs2                    | rs1          | 100        | imm[4:1 11] | 1100011 | BLT       |
| imm[12 10]  | ):5]      | rs2                    | rs1          | 101        | imm[4:1 11] | 1100011 | BGE       |
| imm[12 10]  | ):5]      | rs2                    | rs1          | 110        | imm[4:1 11] | 1100011 | BLTU      |
| imm[12 10]  | ):5]      | rs2                    | rs1          | 111        | imm[4:1 11] | 1100011 | BGEU      |
| in          | nm[11:0   | 0]                     | rs1          | 000        | rd          | 0000011 | LB        |
| in          | nm[11:0   | 0]                     | rs1          | 001        | rd          | 0000011 | LH        |
| in          | nm[11:0   | 0]                     | rs1          | 010        | rd          | 0000011 | LW        |
| in          | nm[11:0   | 0]                     | rs1          | 100        | rd          | 0000011 | LBU       |
| in          | nm[11:0   | 0]                     | rs1          | 101        | rd          | 0000011 | LHU       |
| imm[11:5    | 5]        | rs2                    | rs1          | 000        | imm[4:0]    | 0100011 | SB        |
| imm[11:5    | 5]        | rs2                    | rs1          | 001        | imm[4:0]    | 0100011 | SH        |
| imm[11:5    | 5]        | rs2                    | rs1          | 010        | imm[4:0]    | 0100011 | SW        |
| in          | nm[11:0   | 0]                     | rs1          | 000        | rd          | 0010011 | ADDI      |
|             | nm[11:0   |                        | rs1          | 010        | rd          | 0010011 | SLTI      |
| in          | nm[11:0   | 0]                     | rs1          | 011        | rd          | 0010011 | SLTIU     |
| imm[11:0]   |           |                        | rs1          | 100        | rd          | 0010011 | XORI      |
| imm[11:0]   |           |                        | rs1          | 110        | rd          | 0010011 | ORI       |
| in          | imm[11:0] |                        |              | 111        | rd          | 0010011 | ANDI      |
| 0000000     | )         | shamt                  | rs1          | 001        | rd          | 0010011 | SLLI      |
| 0000000     | )         | $\operatorname{shamt}$ | rs1          | 101        | rd          | 0010011 | SRLI      |
| 0100000     | )         | shamt                  | rs1          | 101        | rd          | 0010011 | SRAI      |
| 0000000     |           | rs2                    | rs1          | 000        | rd          | 0110011 | ADD       |
| 0100000     |           | rs2                    | rs1          | 000        | rd          | 0110011 | SUB       |
| 0000000     |           | rs2                    | rs1          | 001        | rd          | 0110011 | brack SLL |
| 0000000     | )         | rs2                    | rs1          | 010        | rd          | 0110011 | SLT       |
| 0000000     | )         | rs2                    | rs1          | 011        | rd          | 0110011 | SLTU      |
| 0000000     | )         | rs2                    | rs1          | 100        | rd          | 0110011 | XOR       |
| 0000000     |           | rs2                    | rs1          | 101        | rd          | 0110011 | ceil SRL  |
| 0100000     | )         | rs2                    | rs1          | 101        | rd          | 0110011 | SRA       |
| 0000000     |           | rs2                    | rs1          | 110        | rd          | 0110011 | OR        |
| 0000000     | )         | rs2                    | rs1          | 111        | rd          | 0110011 | AND       |
| 0000        | pre       | d succ                 | 00000        | 000        | 00000       | 0001111 | FENCE     |
| 0000        | 000       |                        | 00000        | 001        | 00000       | 0001111 | FENCE.I   |
| 00000000000 |           | 00000                  | 000          | 00000      | 1110011     | ECALL   |           |
| 00000000001 |           | 00000                  | 000          | 00000      | 1110011     | EBREAK  |           |
| csr         |           |                        | rs1          | 001        | rd          | 1110011 | CSRRW     |
| csr         |           |                        | rs1          | 010        | rd          | 1110011 | CSRRS     |
| csr         |           |                        | rs1          | 011        | rd          | 1110011 | CSRRC     |
|             | csr       |                        | zimm         | 101        | rd          | 1110011 | CSRRWI    |
|             | csr       |                        | zimm         | 110        | rd          | 1110011 | CSRRSI    |
| csr         |           |                        | zimm         | 111        | rd          | 1110011 | CSRRCI    |
|             |           |                        |              |            |             |         |           |

| 31 | 27    | 26                | 25     | 24 | 20  | 19 | 15 | 14   | 12  | 11               | 7    | 6  | 0                     |        |
|----|-------|-------------------|--------|----|-----|----|----|------|-----|------------------|------|----|-----------------------|--------|
|    | funct | 7                 |        |    | rs2 | rs | 1  | func | ct3 | $_{\mathrm{rd}}$ |      | op | code                  | R-type |
|    |       | $_{\mathrm{imm}}$ | [11:0] |    |     | rs | 1  | fun  | ct3 | rd               |      | op | $\operatorname{code}$ | I-type |
| iı | nm[11 | :5]               |        |    | rs2 | rs | 1  | func | ct3 | imm[4            | 1:0] | op | code                  | S-type |

# RV64I Base Instruction Set (in addition to RV32I)

| imm[      | 11:0]                        | rs1 | 110 | rd       | 0000011 | LWU   |  |  |  |  |
|-----------|------------------------------|-----|-----|----------|---------|-------|--|--|--|--|
| imm[      | 11:0]                        | rs1 | 011 | rd       | 0000011 | LD    |  |  |  |  |
| imm[11:5] | rs2                          | rs1 | 011 | imm[4:0] | 0100011 | SD    |  |  |  |  |
| 000000    | shamt                        | rs1 | 001 | rd       | 0010011 | SLLI  |  |  |  |  |
| 000000    | 000000 shamt<br>010000 shamt |     | 101 | rd       | 0010011 | SRLI  |  |  |  |  |
| 010000    |                              |     | 101 | rd       | 0010011 | SRAI  |  |  |  |  |
| imm[      | imm[11:0]                    |     |     | rd       | 0011011 | ADDIW |  |  |  |  |
| 0000000   | shamt                        | rs1 | 001 | rd       | 0011011 | SLLIW |  |  |  |  |
| 0000000   | shamt                        | rs1 | 101 | rd       | 0011011 | SRLIW |  |  |  |  |
| 0100000   | shamt                        | rs1 | 101 | rd       | 0011011 | SRAIW |  |  |  |  |
| 0000000   | rs2                          | rs1 | 000 | rd       | 0111011 | ADDW  |  |  |  |  |
| 0100000   | rs2                          | rs1 | 000 | rd       | 0111011 | SUBW  |  |  |  |  |
| 0000000   | rs2                          | rs1 | 001 | rd       | 0111011 | SLLW  |  |  |  |  |
| 0000000   | rs2                          | rs1 | 101 | rd       | 0111011 | SRLW  |  |  |  |  |
| 0100000   | rs2                          | rs1 | 101 | rd       | 0111011 | SRAW  |  |  |  |  |
|           |                              |     |     |          |         |       |  |  |  |  |

## RV32M Standard Extension

| 0000001 | rs2 | rs1 | 000 | $^{\mathrm{rd}}$ | 0110011 | MUL    |
|---------|-----|-----|-----|------------------|---------|--------|
| 0000001 | rs2 | rs1 | 001 | $^{\mathrm{rd}}$ | 0110011 | MULH   |
| 0000001 | rs2 | rs1 | 010 | rd               | 0110011 | MULHSU |
| 0000001 | rs2 | rs1 | 011 | rd               | 0110011 | MULHU  |
| 0000001 | rs2 | rs1 | 100 | rd               | 0110011 | DIV    |
| 0000001 | rs2 | rs1 | 101 | rd               | 0110011 | DIVU   |
| 0000001 | rs2 | rs1 | 110 | rd               | 0110011 | REM    |
| 0000001 | rs2 | rs1 | 111 | $^{\mathrm{rd}}$ | 0110011 | REMU   |

# RV64M Standard Extension (in addition to RV32M)

|         |     | ,   |     |    | ,       |       |
|---------|-----|-----|-----|----|---------|-------|
| 0000001 | rs2 | rs1 | 000 | rd | 0111011 | MULW  |
| 0000001 | rs2 | rs1 | 100 | rd | 0111011 | DIVW  |
| 0000001 | rs2 | rs1 | 101 | rd | 0111011 | DIVUW |
| 0000001 | rs2 | rs1 | 110 | rd | 0111011 | REMW  |
| 0000001 | rs2 | rs1 | 111 | rd | 0111011 | REMUW |

# RV32A Standard Extension

| 00010 |    | 1  | 00000 | 1   | 010 | 1                | 0101111 | TDW       |
|-------|----|----|-------|-----|-----|------------------|---------|-----------|
| 00010 | aq | rl | 00000 | rs1 | 010 | $^{\mathrm{rd}}$ | 0101111 | LR.W      |
| 00011 | aq | rl | rs2   | rs1 | 010 | $^{\mathrm{rd}}$ | 0101111 | SC.W      |
| 00001 | aq | rl | rs2   | rs1 | 010 | rd               | 0101111 | AMOSWAP.W |
| 00000 | aq | rl | rs2   | rs1 | 010 | rd               | 0101111 | AMOADD.W  |
| 00100 | aq | rl | rs2   | rs1 | 010 | rd               | 0101111 | AMOXOR.W  |
| 01100 | aq | rl | rs2   | rs1 | 010 | rd               | 0101111 | AMOAND.W  |
| 01000 | aq | rl | rs2   | rs1 | 010 | rd               | 0101111 | AMOOR.W   |
| 10000 | aq | rl | rs2   | rs1 | 010 | rd               | 0101111 | AMOMIN.W  |
| 10100 | aq | rl | rs2   | rs1 | 010 | rd               | 0101111 | AMOMAX.W  |
| 11000 | aq | rl | rs2   | rs1 | 010 | rd               | 0101111 | AMOMINU.W |
| 11100 | aq | rl | rs2   | rs1 | 010 | rd               | 0101111 | AMOMAXU.W |