| 31 | 25           | 24 20      | ) 19 | 15  | 14  | 12   | 11               | 7                   | 6    |      | 0       |         |
|----|--------------|------------|------|-----|-----|------|------------------|---------------------|------|------|---------|---------|
|    |              | imm[31:12] |      |     |     |      |                  | $\operatorname{rd}$ | op   | code |         | Type-U  |
|    |              | 9:12]      |      |     |     |      | $^{\mathrm{rd}}$ | op                  | code |      | Type-UJ |         |
|    | imm[1        | 1:0]       |      | rs1 | fur | nct3 |                  | $^{\mathrm{rd}}$    | op   | code |         | Type-I  |
|    | imm[12 10:5] | rs2        |      | rs1 | fur | nct3 | imn              | n[4:1 11]           | op   | code |         | Type-SB |
|    | imm[11:5]    | rs2        |      | rs1 | fur | nct3 | im               | m[4:0]              | op   | code |         | Type-S  |
|    | funct7       | rs2        |      | rs1 | fur | nct3 |                  | $^{\mathrm{rd}}$    | op   | code |         | Type-R  |

RV32I Base Integer Instruction Set

|              | imm[31:12]                                            | ase integer in |       | rd          | 0110111          | LUI rd, imm         |  |  |
|--------------|-------------------------------------------------------|----------------|-------|-------------|------------------|---------------------|--|--|
|              | imm[31:12]                                            |                |       | rd          | 0010111          | AUIPC rd, imm       |  |  |
|              | $\frac{\text{imm}[31.12]}{\text{imm}[20 10:1 11 19:}$ | .19]           |       | rd          | 1101111          | JAL rd, disp        |  |  |
| imm[1        |                                                       | rs1            | 000   | rd          | 1100111          | JALR rd, rs1, imm   |  |  |
| imm[12 10:5] | rs2                                                   | rs1            | 000   | imm[4:1 11] | 1100111          | BEQ rs1, rs2, disp  |  |  |
| imm[12 10:5] | rs2                                                   | rs1            | 000   | imm[4:1 11] | 1100011          | BNE rs1, rs2, disp  |  |  |
| imm[12 10:5] | rs2                                                   | rs1            | 100   | imm[4:1 11] | 1100011          | BLT rs1, rs2, disp  |  |  |
| imm[12 10:5] | rs2                                                   | rs1            | 100   | imm[4:1 11] | 1100011          | BGE rs1, rs2, disp  |  |  |
| imm[12 10:5] | rs2                                                   | rs1            | 110   | imm[4:1 11] | 1100011          | BLTU rs1, rs2, disp |  |  |
| imm[12 10:5] | rs2                                                   | rs1            | 111   | imm[4:1 11] | 1100011          | BGEU rs1, rs2, disp |  |  |
| imm[12]10.5] |                                                       | rs1            | 000   | rd          | 0000011          | LB rd, imm(rs1)     |  |  |
| imm[1        |                                                       | rs1            | 000   | rd          | 0000011          | LH rd, imm(rs1)     |  |  |
| imm[1        |                                                       | rs1            | 010   | rd          | 0000011          | LW rd, imm(rs1)     |  |  |
| imm[1        |                                                       | rs1            | 100   | rd          | 0000011          | LBU rd, imm(rs1)    |  |  |
|              | 1                                                     |                |       |             |                  |                     |  |  |
| imm[1        |                                                       | rs1            | 101   | rd          | 0000011          | LHU rd, imm(rs1)    |  |  |
| imm[11:5]    | rs2                                                   | rs1            | 000   | imm[4:0]    | 0100011          | SB rs2, imm(rs1)    |  |  |
| imm[11:5]    | rs2                                                   | rs1            | 001   | imm[4:0]    | 0100011          | SH rs2, imm(rs1)    |  |  |
| imm[11:5]    | rs2                                                   | rs1            | 010   | imm[4:0]    | 0100011          | SW rs2, imm(rs1)    |  |  |
| imm[1        |                                                       | rs1            | 000   | rd          | 0010011          | ADDI rd, rs1, imm   |  |  |
| imm[1        |                                                       | rs1            | 010   | rd          | 0010011          | SLTI rd, rs1, imm   |  |  |
| imm[1        | -                                                     | rs1            | 011   | rd          | 0010011          | SLTIU rd, rs1, imm  |  |  |
| imm[1        |                                                       | rs1            | 100   | rd          | 0010011          | XORI rd, rs1, imm   |  |  |
| imm[1        | 1                                                     | rs1            | 110   | rd          | 0010011          | ORI rd, rs1, imm    |  |  |
| imm[1        |                                                       | rs1            | 111   | rd          | 0010011          | ANDI rd, rs1, imm   |  |  |
| 000000 0     | shamt5                                                | rs1            | 001   | rd          | 0010011          | SLLI rd, rs1, imm   |  |  |
| 000000 0     | shamt5                                                | rs1            | 101   | rd          | 0010011          | SRLI rd, rs1, imm   |  |  |
| 010000 0     | shamt5                                                | rs1            | 101   | rd          | 0010011          | SRAI rd, rs1, imm   |  |  |
| 0000000      | rs2                                                   | rs1            | 000   | rd          | 0110011          | ADD rd, rs1, rs2    |  |  |
| 0100000      | rs2                                                   | rs1            | 000   | rd          | 0110011          | SUB rd, rs1, rs2    |  |  |
| 0000000      | rs2                                                   | rs1            | 001   | rd          | 0110011          | SLL rd, rs1, rs2    |  |  |
| 0000000      | rs2                                                   | rs1            | 010   | rd          | 0110011          | SLT rd, rs1, rs2    |  |  |
| 0000000      | rs2                                                   | rs1            | 011   | rd          | 0110011          | SLTU rd, rs1, rs2   |  |  |
| 0000000      | rs2                                                   | rs1            | 100   | rd          | 0110011          | XOR rd, rs1, rs2    |  |  |
| 0000000      | rs1                                                   | 101            | rd    | 0110011     | SRL rd, rs1, rs2 |                     |  |  |
| 0100000      | rs1                                                   | 101            | rd    | 0110011     | SRA rd, rs1, rs2 |                     |  |  |
| 0000000      | rs2                                                   | rs1            | 110   | rd          | 0110011          | OR rd, rs1, rs2     |  |  |
| 0000000      | rs2                                                   | rs1            | 111   | rd          | 0110011          | AND rd, rs1, rs2    |  |  |
| 0000 pred    | 00000                                                 | 000            | 00000 | 0001111     | FENCE            |                     |  |  |
| 0000000      | 00000                                                 | 00000          | 001   | 00000       | 0001111          | FENCE.I             |  |  |

## RV64I Base Integer Instruction Set (in addition to RV32I)

|           | O O     |     |     |                  | ,       |
|-----------|---------|-----|-----|------------------|---------|
| im        | m[11:0] | rs1 | 110 | rd               | 0000011 |
| im        | m[11:0] | rs1 | 011 | $^{\mathrm{rd}}$ | 0000011 |
| imm[11:5] | rs2     | rs1 | 011 | imm[4:0]         | 0100011 |
| 000000    | shamt6  | rs1 | 001 | rd               | 0010011 |
| 000000    | shamt6  | rs1 | 101 | rd               | 0010011 |
| 010000    | shamt6  | rs1 | 101 | $^{\mathrm{rd}}$ | 0010011 |
| im        | m[11:0] | rs1 | 000 | $^{\mathrm{rd}}$ | 0011011 |
| 0000000   | shamt5  | rs1 | 001 | $^{\mathrm{rd}}$ | 0011011 |

LWU rd, imm(rs1) LD rd, imm(rs1) SD rs2, imm(rs1) SLLI rd, rs1, imm SRLI rd, rs1, imm SRAI rd, rs1, imm ADDIW rd, rs1, imm SLLIW rd, rs1, imm

| 31   | 25      | 24 | 20  | 19 |     | 15 | 14   | 12  | 11 | 7  | 6 | 0      |        |
|------|---------|----|-----|----|-----|----|------|-----|----|----|---|--------|--------|
|      | imm[11: | 0] |     |    | rs1 |    | fun  | ct3 |    | rd |   | opcode | Type-I |
| func | t7      |    | rs2 |    | rs1 |    | fune | ct3 |    | rd |   | opcode | Type-R |

RV64I Base Integer Instruction Set (in addition to RV32I) contd

| 0000000 | shamt5 | rs1 | 101 | rd | 0011011 |
|---------|--------|-----|-----|----|---------|
| 0100000 | shamt5 | rs1 | 101 | rd | 0011011 |
| 0000000 | rs2    | rs1 | 000 | rd | 0111011 |
| 0100000 | rs2    | rs1 | 000 | rd | 0111011 |
| 0000000 | rs2    | rs1 | 001 | rd | 0111011 |
| 0000000 | rs2    | rs1 | 101 | rd | 0111011 |
| 0100000 | rs2    | rs1 | 101 | rd | 0111011 |

SRLIW rd, rs1, imm SRAIW rd, rs1, imm ADDW rd, rs1, rs2 SUBW rd, rs1, rs2 SLLW rd, rs1, rs2 SRLW rd, rs1, rs2 SRAW rd, rs1, rs2

RV32M Standard Extension for Integer Multiply and Divide

| 0000001 | rs2 | rs1 | 000 | rd | 0110011 |
|---------|-----|-----|-----|----|---------|
| 0000001 | rs2 | rs1 | 001 | rd | 0110011 |
| 0000001 | rs2 | rs1 | 010 | rd | 0110011 |
| 0000001 | rs2 | rs1 | 011 | rd | 0110011 |
| 0000001 | rs2 | rs1 | 100 | rd | 0110011 |
| 0000001 | rs2 | rs1 | 101 | rd | 0110011 |
| 0000001 | rs2 | rs1 | 110 | rd | 0110011 |
| 0000001 | rs2 | rs1 | 111 | rd | 0110011 |
|         |     |     |     |    |         |

MUL rd, rs1, rs2 MULH rd, rs1, rs2 MULHSU rd, rs1, rs2 MULHU rd, rs1, rs2 DIV rd, rs1, rs2 DIVU rd, rs1, rs2 REM rd, rs1, rs2 REMU rd, rs1, rs2

RV64M Standard Extension for Integer Multiply and Divide (in addition to RV32M)

| 0000001 | rs2 | rs1 | 000 | rd | 0111011 |
|---------|-----|-----|-----|----|---------|
| 0000001 | rs2 | rs1 | 100 | rd | 0111011 |
| 0000001 | rs2 | rs1 | 101 | rd | 0111011 |
| 0000001 | rs2 | rs1 | 110 | rd | 0111011 |
| 0000001 | rs2 | rs1 | 111 | rd | 0111011 |

MULW rd, rs1, rs2 DIVW rd, rs1, rs2 DIVUW rd, rs1, rs2 REMW rd, rs1, rs2 REMUW rd, rs1, rs2

RV32A Standard Extension for Atomic Instructions

| 00010 | aqrl | 00000 | rs1 | 010 | rd | 0101111 |
|-------|------|-------|-----|-----|----|---------|
| 00011 | aqrl | rs2   | rs1 | 010 | rd | 0101111 |
| 00001 | aqrl | rs2   | rs1 | 010 | rd | 0101111 |
| 00000 | aqrl | rs2   | rs1 | 010 | rd | 0101111 |
| 00100 | aqrl | rs2   | rs1 | 010 | rd | 0101111 |
| 01000 | aqrl | rs2   | rs1 | 010 | rd | 0101111 |
| 01100 | aqrl | rs2   | rs1 | 010 | rd | 0101111 |
| 10000 | aqrl | rs2   | rs1 | 010 | rd | 0101111 |
| 10100 | aqrl | rs2   | rs1 | 010 | rd | 0101111 |
| 11000 | aqrl | rs2   | rs1 | 010 | rd | 0101111 |
| 11100 | aqrl | rs2   | rs1 | 010 | rd | 0101111 |
|       |      |       |     |     |    |         |

LR.W rd, (rs1)
SC.W rd, rs2, (rs1)
AMOSWAP.W rd, rs2, (rs1)
AMOADD.W rd, rs2, (rs1)
AMOXOR.W rd, rs2, (rs1)
AMOOR.W rd, rs2, (rs1)
AMOOR.W rd, rs2, (rs1)
AMOOR.W rd, rs2, (rs1)
AMOMIN.W rd, rs2, (rs1)
AMOMAX.W rd, rs2, (rs1)
AMOMINU.W rd, rs2, (rs1)
AMOMINU.W rd, rs2, (rs1)
AMOMAXU.W rd, rs2, (rs1)

RV64A Standard Extension for Atomic Instructions (in addition to RV32A)

|       |      |       |     |     |    | ,       |
|-------|------|-------|-----|-----|----|---------|
| 00010 | aqrl | 00000 | rs1 | 011 | rd | 0101111 |
| 00011 | aqrl | rs2   | rs1 | 011 | rd | 0101111 |
| 00001 | aqrl | rs2   | rs1 | 011 | rd | 0101111 |
| 00000 | aqrl | rs2   | rs1 | 011 | rd | 0101111 |
| 00100 | aqrl | rs2   | rs1 | 011 | rd | 0101111 |
| 01000 | aqrl | rs2   | rs1 | 011 | rd | 0101111 |
| 01100 | aqrl | rs2   | rs1 | 011 | rd | 0101111 |
| 10000 | aqrl | rs2   | rs1 | 011 | rd | 0101111 |
| 10100 | aqrl | rs2   | rs1 | 011 | rd | 0101111 |
| 11000 | aqrl | rs2   | rs1 | 011 | rd | 0101111 |
| 11100 | aqrl | rs2   | rs1 | 011 | rd | 0101111 |

LR.D rd, (rs1)
SC.D rd, rs2, (rs1)
AMOSWAP.D rd, rs2, (rs1)
AMOADD.D rd, rs2, (rs1)
AMOXOR.D rd, rs2, (rs1)
AMOOR.D rd, rs2, (rs1)
AMOAND.D rd, rs2, (rs1)
AMOMIN.D rd, rs2, (rs1)
AMOMAX.D rd, rs2, (rs1)
AMOMINU.D rd, rs2, (rs1)
AMOMINU.D rd, rs2, (rs1)
AMOMINU.D rd, rs2, (rs1)
AMOMAXU.D rd, rs2, (rs1)

| 31 |        | 25        | $^{24}$ | 20  | 19 |     | 15 | 14  | 12  | 11 | 7                | 6 |        | 0 |         |
|----|--------|-----------|---------|-----|----|-----|----|-----|-----|----|------------------|---|--------|---|---------|
|    |        | imm[11:0] |         |     |    | rs1 |    | fun | ct3 |    | rd               |   | opcode |   | Type-I  |
|    | imm[11 | :5]       |         | rs2 |    | rs1 |    | fun | ct3 | im | nm[4:0]          |   | opcode |   | Type-S  |
|    | rs3    | funct2    |         | rs2 |    | rs1 |    | fun | ct3 |    | $^{\mathrm{rd}}$ |   | opcode |   | Type-R4 |
|    | funct7 | 7         |         | rs2 |    | rs1 |    | fun | ct3 |    | rd               |   | opcode |   | Type-R  |

RV32S Standard Extension for Supervisor-level Instructions

| 0000000      | 00000 | 00000    | 000 | 00000 | 1110011 | SCALL    |
|--------------|-------|----------|-----|-------|---------|----------|
| 0000000      | 00001 | 00000    | 000 | 00000 | 1110011 | SBREAK   |
| 0001000      | 00000 | 00000    | 000 | 00000 | 1110011 | SRET     |
| 0001000      | 00001 | rs1      | 000 | 00000 | 1110011 | SFENCE.  |
| 0001000      | 00010 | 00000    | 000 | 00000 | 1110011 | WFI      |
| 0011000      | 00110 | 00000    | 000 | 00000 | 1110011 | MRTH     |
| 0011000      | 00101 | 00000    | 000 | 00000 | 1110011 | MRTS     |
| 0010000      | 00101 | 00000    | 000 | 00000 | 1110011 | HRTS     |
| 1100000000   | 00    | 00000    | 010 | rd    | 1110011 | RDCYCL   |
| 1100000000   | 01    | 00000    | 010 | rd    | 1110011 | RDTIME   |
| 1100000000   | 10    | 00000    | 010 | rd    | 1110011 | RDINSTR  |
| 1100100000   | 00    | 00000    | 010 | rd    | 1110011 | RDCYCL   |
| 1100100000   | 01    | 00000    | 010 | rd    | 1110011 | RDTIME   |
| 1100100000   | 10    | 00000    | 010 | rd    | 1110011 | RDINSTR  |
| imm[11:0]    |       | rs1      | 001 | rd    | 1110011 | CSRRW r  |
| imm[11:0]    |       | rs1      | 010 | rd    | 1110011 | CSRRS rd |
| imm[11:0]    |       | rs1      | 011 | rd    | 1110011 | CSRRC re |
| imm[11:0]    |       | imm5     | 101 | rd    | 1110011 | CSRRWI   |
| imm[11:0]    |       | imm5     | 110 | rd    | 1110011 | CSRRSI r |
| imm[11:0]    |       | imm5     | 111 | rd    | 1110011 | CSRRCI r |
| 111111[11:0] |       | 11111113 | 111 | l Id  | 1110011 |          |

SFENCE.VM
WFI
MRTH
MRTS
HRTS
HRTS
RDCYCLE rd, csr, rs1
RDTIME rd, csr, rs1
RDINSTRET rd, csr, rs1
RDCYCLEH rd, csr, rs1
RDTIMEH rd, csr, rs1
RDTIMEH rd, csr, rs1
CSRRW rd, csr, rs1
CSRRS rd, csr, rs1
CSRRC rd, csr, rs1
CSRRWI rd, csr, irs1
CSRRWI rd, csr, irs1
CSRRSI rd, csr, irs1
CSRRCI rd, csr, irs1
CSRRCI rd, csr, irs1

RV32F Standard Extension for Single-Precision Floating-Point

|        |           |       |     |            | olon r loating |         |
|--------|-----------|-------|-----|------------|----------------|---------|
|        | imm[11:0] |       | rs1 | 010        | rd             | 0000111 |
| imm[11 | :5]       | rs2   | rs1 | 010        | imm[4:0]       | 0100111 |
| rs3    | 00        | rs2   | rs1 | $_{ m rm}$ | rd             | 1000011 |
| rs3    | 00        | rs2   | rs1 | rm         | rd             | 1000111 |
| rs3    | 00        | rs2   | rs1 | rm         | rd             | 1001011 |
| rs3    | 00        | rs2   | rs1 | rm         | rd             | 1001111 |
| 000000 | 0         | rs2   | rs1 | rm         | rd             | 1010011 |
| 000010 | 0         | rs2   | rs1 | rm         | rd             | 1010011 |
| 000100 | 0         | rs2   | rs1 | rm         | rd             | 1010011 |
| 000110 | 0         | rs2   | rs1 | rm         | rd             | 1010011 |
| 001000 | 0         | rs2   | rs1 | 000        | rd             | 1010011 |
| 001000 | 0         | rs2   | rs1 | 001        | rd             | 1010011 |
| 001000 | 0         | rs2   | rs1 | 010        | rd             | 1010011 |
| 001010 | 0         | rs2   | rs1 | 000        | rd             | 1010011 |
| 001010 | 0         | rs2   | rs1 | 001        | rd             | 1010011 |
| 010110 | 0         | 00000 | rs1 | rm         | rd             | 1010011 |
| 101000 | 0         | rs2   | rs1 | 000        | rd             | 1010011 |
| 101000 | 0         | rs2   | rs1 | 001        | rd             | 1010011 |
| 101000 | 0         | rs2   | rs1 | 010        | rd             | 1010011 |
| 110000 | 0         | 00000 | rs1 | rm         | rd             | 1010011 |
| 110000 | 0         | 00001 | rs1 | rm         | rd             | 1010011 |
| 110100 | 0         | 00000 | rs1 | rm         | rd             | 1010011 |
| 110100 | 0         | 00001 | rs1 | rm         | rd             | 1010011 |
| 111000 | 0         | 00000 | rs1 | 000        | rd             | 1010011 |
| 111000 | 0         | 00000 | rs1 | 001        | rd             | 1010011 |
| 111100 | 0         | 00000 | rs1 | 000        | rd             | 1010011 |

FLW frd, imm(rs1) FSW frs2, imm(rs1) FMADD.S frd, frs1, frs2, frs3 FMSUB.S frd, frs1, frs2, frs3 FNMSUB.S frd, frs1, frs2, frs3 FNMADD.S frd, frs1, frs2, frs3 FADD.S frd, frs1, frs2  $FSUB.S\ frd,\,frs1,\,frs2$ FMUL.S frd, frs1, frs2 FDIV.S frd, frs1, frs2 FSGNJ.S frd, frs1, frs2 FSGNJN.S frd, frs1, frs2 FSGNJX.S frd, frs1, frs2 FMIN.S frd, frs1, frs2 FMAX.S frd, frs1, frs2 FSQRT.S frd, frs1, frs2 FLE.S frd, rs1, frs2 FLT.S frd, rs1, frs2 FEQ.S frd, rs1, frs2  $FCVT.W.S\ rd,\,frs1$ FCVT.WU.S rd, frs1FCVT.S.W frd, rs1 FCVT.S.WU frd, rs1 FMV.X.S rd, frs1 FCLASS.S rd, frs1 FMV.S.X frd, rs1

|               | 31 |        | 25        | $^{24}$ | 20  | 19 |     | 15  | 14  | 12      | 11 | 7                   | 6 |        | 0 |         |
|---------------|----|--------|-----------|---------|-----|----|-----|-----|-----|---------|----|---------------------|---|--------|---|---------|
|               |    |        | imm[11:0] |         |     |    | rs1 |     | fun | ct3     |    | $\operatorname{rd}$ |   | opcode |   | Type-I  |
|               |    | funct7 | ,         |         | rs2 |    | rs1 |     | fun | ct3     |    | rd                  |   | opcode |   | Type-R  |
| imm[11:5] rs2 |    |        |           |         | rs1 |    | fun | ct3 | in  | nm[4:0] |    | opcode              |   | Type-S |   |         |
|               |    | rs3    | funct2    |         | rs2 |    | rs1 |     | fun | ct3     |    | rd                  |   | opcode |   | Type-R4 |

RV32F Standard Extension for Single-Precision Floating-Point contd

| 00000000011 | 00000 | 010 | rd | 1110011 | FRCSR rd, csr, rs1     |
|-------------|-------|-----|----|---------|------------------------|
| 00000000010 | 00000 | 010 | rd | 1110011 | FRRM rd, csr, rs1      |
| 00000000001 | 00000 | 010 | rd | 1110011 | FRFLAGS rd, csr, rs1   |
| 00000000011 | rs1   | 001 | rd | 1110011 | FSCSR rd, csr, rs1     |
| 00000000010 | rs1   | 001 | rd | 1110011 | FSRM rd, csr, rs1      |
| 00000000001 | rs1   | 001 | rd | 1110011 | FSFLAGS rd, csr, rs1   |
| 00000000010 | imm5  | 101 | rd | 1110011 | FSRMI rd, csr, irs1    |
| 00000000001 | imm5  | 101 | rd | 1110011 | FSFLAGSI rd, csr, irs1 |

RV64F Standard Extension for Single-Precision Floating-Point (in addition to RV32F)

|         |       | 0   |    | •  | ,       |                    |
|---------|-------|-----|----|----|---------|--------------------|
| 1100000 | 00010 | rs1 | rm | rd | 1010011 | FCVT.L.S rd, frs1  |
| 1100000 | 00011 | rs1 | rm | rd | 1010011 | FCVT.LU.S rd, frs1 |
| 1101000 | 00010 | rs1 | rm | rd | 1010011 | FCVT.S.L frd, rs1  |
| 1101000 | 00011 | rs1 | rm | rd | 1010011 | FCVT.S.LU frd, rs1 |

RV32D Standard Extension for Double-Precision Floating-Point

|         | imm[11:0 |       | rs1 | 011 | rd       | 0000111 | FLD frd, imm(rs1)              |
|---------|----------|-------|-----|-----|----------|---------|--------------------------------|
|         |          |       |     |     |          |         |                                |
| imm[11: |          | rs2   | rs1 | 011 | imm[4:0] | 0100111 | FSD frs2, imm(rs1)             |
| rs3     | 01       | rs2   | rs1 | rm  | rd       | 1000011 | FMADD.D frd, frs1, frs2, frs3  |
| rs3     | 01       | rs2   | rs1 | rm  | rd       | 1000111 | FMSUB.D frd, frs1, frs2, frs3  |
| rs3     | 01       | rs2   | rs1 | rm  | rd       | 1001011 | FNMSUB.D frd, frs1, frs2, frs3 |
| rs3     | 01       | rs2   | rs1 | rm  | rd       | 1001111 | FNMADD.D frd, frs1, frs2, frs3 |
| 000000  | 1        | rs2   | rs1 | rm  | rd       | 1010011 | FADD.D frd, frs1, frs2         |
| 000010  | 1        | rs2   | rs1 | rm  | rd       | 1010011 | FSUB.D frd, frs1, frs2         |
| 000100  | 1        | rs2   | rs1 | rm  | rd       | 1010011 | FMUL.D frd, frs1, frs2         |
| 000110  | 1        | rs2   | rs1 | rm  | rd       | 1010011 | FDIV.D frd, frs1, frs2         |
| 001000  | 1        | rs2   | rs1 | 000 | rd       | 1010011 | FSGNJ.D frd, frs1, frs2        |
| 001000  | 1        | rs2   | rs1 | 001 | rd       | 1010011 | FSGNJN.D frd, frs1, frs2       |
| 001000  | 1        | rs2   | rs1 | 010 | rd       | 1010011 | FSGNJX.D frd, frs1, frs2       |
| 001010  | 1        | rs2   | rs1 | 000 | rd       | 1010011 | FMIN.D frd, frs1, frs2         |
| 001010  | 1        | rs2   | rs1 | 001 | rd       | 1010011 | FMAX.D frd, frs1, frs2         |
| 010000  | 0        | 00001 | rs1 | rm  | rd       | 1010011 | FCVT.S.D frd, frs1             |
| 010000  | 1        | 00000 | rs1 | rm  | rd       | 1010011 | FCVT.D.S frd, frs1             |
| 010110  | 1        | 00000 | rs1 | rm  | rd       | 1010011 | FSQRT.D frd, frs1              |
| 101000  | 1        | rs2   | rs1 | 000 | rd       | 1010011 | FLE.D frd, rs1, frs2           |
| 101000  | 1        | rs2   | rs1 | 001 | rd       | 1010011 | FLT.D frd, rs1, frs2           |
| 101000  | 1        | rs2   | rs1 | 010 | rd       | 1010011 | FEQ.D frd, rs1, frs2           |
| 110000  | 1        | 00000 | rs1 | rm  | rd       | 1010011 | FCVT.W.D rd, frs1              |
| 110000  | 1        | 00001 | rs1 | rm  | rd       | 1010011 | FCVT.WU.D rd, frs1             |
| 110100  | 1        | 00000 | rs1 | rm  | rd       | 1010011 | FCVT.D.W frd, rs1              |
| 110100  | 1        | 00001 | rs1 | rm  | rd       | 1010011 | FCVT.D.WU frd, rs1             |
| 111000  | 1        | 00000 | rs1 | 001 | rd       | 1010011 | FCLASS.D rd, frs1              |
|         |          |       |     |     |          |         |                                |

## RV64D Standard Extension for Double-Precision Floating-Point (in addition to RV32D)

| 1100001 | 00010 | rs1 | $^{\mathrm{rm}}$ | rd | 1010011 |
|---------|-------|-----|------------------|----|---------|
| 1100001 | 00011 | rs1 | rm               | rd | 1010011 |
| 1110001 | 00000 | rs1 | 000              | rd | 1010011 |
| 1101001 | 00010 | rs1 | rm               | rd | 1010011 |
| 1101001 | 00011 | rs1 | rm               | rd | 1010011 |
| 1111001 | 00000 | rs1 | 000              | rd | 1010011 |

FCVT.L.D rd, frs1 FCVT.LU.D rd, frs1 FMV.X.D rd, frs1 FCVT.D.L frd, rs1 FCVT.D.LU frd, rs1 FMV.D.X frd, rs1

| 15     | 13 | 12           | 10          | 9      | 7     | 6    | 5 | 4    | 2 | 1 |    | 0 |          |
|--------|----|--------------|-------------|--------|-------|------|---|------|---|---|----|---|----------|
| funct3 |    |              |             | imm8   |       |      |   | rd'  |   |   | op |   | Type-CIW |
| funct3 |    | im           | ım3         | 1      | rs1'  | imm2 | 2 | rd'  |   |   | op |   | Type-CL  |
| funct3 |    | im           | ım3         | 1      | rs1'  | imm2 | 2 | rs2' |   |   | op |   | Type-CS  |
| funct3 |    | $_{ m imm1}$ | imm1 rd/rs1 |        |       |      |   | imm5 |   |   |    |   | Type-CI  |
| funct3 |    |              |             |        | imm11 |      |   |      |   |   | op |   | Type-CJ  |
| funct3 |    | im           | ım3         | 1      | rs1'  | imm5 |   |      |   |   | op |   | Type-CB  |
| func   | t4 |              |             | rd/rs1 |       |      |   | rs2  |   |   | op |   | Type-CR  |
| funct3 |    |              | imm         | 6      |       |      |   | rs2  |   |   | op |   | Type-CSS |

RV32C Standard Extension for Compressed Instructions

| 000        | 100 520 5 |                              | n[5:4 9:6 2 3]      | npressed in | rd'          | 00   | C.ADDI4SPN rd, rs1, imm                 |
|------------|-----------|------------------------------|---------------------|-------------|--------------|------|-----------------------------------------|
| 000        | •         | [5:3]                        |                     | :[7.6]      | rd'          | 00   | C.FLD frd, imm(rs1)                     |
|            |           | L J                          | rs1'                | imm[7:6]    |              |      |                                         |
| 010        |           | [5:3]                        | rs1'                | imm[2 6]    | rd'          | 00   | C.LW rd, imm(rs1)                       |
| 011        |           | [5:3]                        | rs1'                | imm[2 6]    | rd'          | 00   | C.FLW frd, imm(rs1)                     |
| 101        |           | [5:3]                        | rs1'                | imm[7:6]    | rs2'         | 00   | C.FSD frs2, imm(rs1)                    |
| 110        |           | [5:3]                        | rs1'                | imm[2 6]    | rs2'         | 00   | C.SW rs2, imm(rs1)                      |
| 111        |           | [5:3]                        | rs1'                | imm[2 6]    | rs2'         | 00   | C.FSW frs2, imm(rs1)                    |
| 000        | 0         |                              | 00000               |             | 00000        | 01   | C.NOP                                   |
| 000        | imm[5]    |                              | rs1/rd              |             | nm[4:0]      | 01   | C.ADDI rd, rs1, imm                     |
| 001        |           |                              | imm[11 4 9:8 10 6   | 1 1 2       |              | 01   | C.JAL rd, disp                          |
| 010        | imm[5]    |                              | rs1/rd              |             | mm[4:0]      | 01   | C.LI rd, rs1, imm                       |
| 011        | imm[17]   |                              | $\operatorname{rd}$ |             | m[16:12]     | 01   | C.LUI rd, imm                           |
| 011        | imm[9]    |                              | rs1/rd              |             | 1[4 6 8:7 5] | 01   | C.ADDI16SP rd, rs1, imm                 |
| 100        | imm[5]    | 00                           | rs1'/rd'            |             | nm[4:0]      | 01   | C.SRLI rd, rs1, imm                     |
| 100        | imm[5]    | 01                           | rs1'/rd'            |             | nm[4:0]      | 01   | C.SRAI rd, rs1, imm                     |
| 100        | imm[5]    | 10                           | rs1'/rd'            | imm[4:0]    |              | 01   | C.ANDI rs1, rs2, disp                   |
| 100        | 0         | 11                           | rs1'/rd'            | 00          | rs2'         | 01   | C.SUB rd, rs1, rs2                      |
| 100        | 0:        | 11                           | rs1'/rd'            | 01          | rs2'         | 01   | C.XOR rd, rs1, rs2                      |
| 100        | 0:        | 11                           | rs1'/rd'            | 10          | rs2'         | 01   | C.OR rd, rs1, rs2                       |
| 100        | 0:        | 11                           | rs1'/rd'            | 11          | rs2'         | 01   | C.AND rd, rs1, rs2                      |
| 100        | 1:        | 11                           | rs1'/rd'            | 00          | rs2'         | 01   | C.SUBW rd, rs1, rs2                     |
| 100        | 1:        | 11                           | rs1'/rd'            | 01          | rs2'         | 01   | C.ADDW rd, rs1, rs2                     |
| 101        |           |                              | imm[11 4 9:8 10 6   | 7 3:1 5]    |              | 01   | C.J rd, disp                            |
| 110        | imm       | 8 4:3]                       | rs1'                |             | 1[7:6 2:1 5] | 01   | C.BEQZ rs1, rs2, disp                   |
| 111        | imm       | 8 4:3                        | rs1'                | imn         | n[7:6 2:1 5] | 01   | C.BNEZ rs1, rs2, disp                   |
| 000        | imm[5]    |                              | rd                  |             | nm[4:0]      | 10   | C.SLLI rd, rs1, imm                     |
| 001        | imm[5]    |                              | rd                  |             | m[4:3 8:6]   | 10   | C.FLDSP frd, imm(rs1)                   |
| 010 imm[5] |           |                              | rd                  |             | m[4:2 7:6]   | 10   | C.LWSP rd, imm(rs1)                     |
| 011 imm[5] |           |                              | rd                  |             | m[4:2 7:6]   | 10   | C.FLWSP frd, imm(rs1)                   |
| 1000       |           |                              | rs1                 |             | 00000        | 10   | C.JR rd, rs1, imm                       |
| 1000       |           |                              | rd                  |             | rs2          | 10   | C.MV rd, rs1, rs2                       |
|            |           | 00                           | 000                 | 00          | 000          | 10   | C.EBREAK                                |
| 1001       |           |                              | rs1                 |             | 00000        | 10   | C.JALR rd, rs1, imm                     |
| 1001       |           |                              | rd                  |             | rs2          | 10   | C.ADD rd, rs1, rs2                      |
| 101        |           | imm[5:3                      |                     |             | rs2          | 10   | C.FSDSP frs2, imm(rs1)                  |
| 110        |           | imm[5:3 8:0]<br>imm[5:2 7:6] |                     |             | rs2          | 10   | C.SWSP rs2, imm(rs1)                    |
| 111        |           | imm[5:2                      |                     |             | rs2          | 10   | C.FSWSP frs2, imm(rs1)                  |
|            |           |                              | 1]                  |             | -~-          | 1 10 | _ = = = · · · · · · · · · · · · · · · · |

## RV64C Standard Extension for Compressed Instructions (in addition to RV32C)

| 011 | imn    | n[5:3]  | rs1'   | [mm[7:6]] | rd'        | 00 |
|-----|--------|---------|--------|-----------|------------|----|
| 111 | imn    | n[5:3]  | rs1'   | imm[7:6]  | rs2'       | 00 |
| 001 | imm[5] |         | rs1/rd | ir        | 01         |    |
| 011 | imm[5] |         | rs1/rd | imı       | m[4:3 8:6] | 10 |
| 111 |        | imm[5:3 | [8:6]  |           | 10         |    |

C.LD rd, imm(rs1) C.SD rs2, imm(rs1) C.ADDIW rd, rs1, imm C.LDSP rd, imm(rs1) C.SDSP rs2, imm(rs1)