# RISC-V REFERENCE

### **RISC-V Instruction Set**

#### **Core Instruction Formats**

| 31           | 27                    | 26   | 25 | 24  | 20  | 19  |        | 15          | 14  | 12   | 11   | 7      | 6      | (      | 0 |        |
|--------------|-----------------------|------|----|-----|-----|-----|--------|-------------|-----|------|------|--------|--------|--------|---|--------|
| funct7       |                       |      | rs | 32  | rs1 |     | funct3 |             | rd  |      | opco | ode    |        | R-type |   |        |
| imm[11:0]    |                       | )]   |    | rs1 |     | fun | ct3    | rd          |     | opco | ode  |        | I-type |        |   |        |
| im           | m[1                   | 1:5] |    | rs  | 32  | 1   | s1     |             | fun | ct3  | imr  | n[4:0] | opco   | ode    |   | S-type |
| imm[12 10:5] |                       | rs   | 2  | rs1 |     | fun | ct3    | imm[4:1 11] |     | opco | ode  |        | B-type |        |   |        |
| imm[31:12]   |                       |      |    |     |     |     |        |             | rd  | opco | ode  |        | U-type |        |   |        |
|              | imm[20 10:1 11 19:12] |      |    |     |     |     |        |             |     | rd   | opco | ode    |        | J-type |   |        |

# **RV32I Base Integer Instructions**

| Inst   | Name                    | FMT | Opcode  | F3  | F7   | Description (C)              | Note         |
|--------|-------------------------|-----|---------|-----|------|------------------------------|--------------|
| add    | ADD                     | R   | 0000011 | 0x0 | 0x00 | rd = rs1 + rs2               |              |
| sub    | SUB                     | R   | 0000011 | 0x0 | 0x20 | rd = rs1 - rs2               |              |
| xor    | XOR                     | R   | 0000011 | 0x4 | 0x00 | rd = rs1 ^ rs2               |              |
| or     | OR                      | R   | 0000011 | 0x6 | 0x00 | rd = rs1   rs2               |              |
| and    | AND                     | R   | 0000011 | 0x7 | 0x00 | rd = rs1 & rs2               |              |
| sll    | Shift Left Logical      | R   | 0000011 | 0x1 | 0x00 | rd = rs1 << rs2              |              |
| srl    | Shift Right Logical     | R   | 0000011 | 0x2 | 0x00 | rd = rs1 >> rs2              |              |
| sra    | Shift Right Arith*      | R   | 0000011 | 0x3 | 0x20 | rd = rs1 >> rs2              | msb-extends  |
| slt    | Set Less Than           | R   | 0110011 | 0x2 |      | rd = (rs1 < rs2)?1:0         |              |
| sltu   | Set Less Than (U)       | R   | 0110011 | 0x3 |      | rd = (rs1 < rs2)?1:0         | zero-extends |
| addi   | ADD Immediate           | I   | 0010011 | 0x0 | 0x00 | rd = rs1 + imm               |              |
| xori   | XOR Immediate           | I   | 0010011 | 0x0 | 0x00 | rd = rs1 ^ imm               |              |
| ori    | OR Immediate            | I   | 0010011 | 0x0 | 0x00 | rd = rs1   imm               |              |
| andi   | AND Immediate           | I   | 0010011 | 0x0 | 0x00 | rd = rs1 & imm               |              |
| slli   | Shift Left Logical Imm  | I   | 0010011 | 0x1 | 0x00 | rd = rs1 << imm              |              |
| srli   | Shift Right Logical Imm | I   | 0010011 | 0x1 | 0x00 | rd = rs1 >> imm              |              |
| srai   | Shift Right Arith Imm   | I   | 0010011 | 0x3 | 0x20 | rd = rs1 >> imm              | msb-extends  |
| slt    | Set Less Than Imm       | I   | 0010011 | 0x2 |      | rd = (rs1 < imm)?1:0         |              |
| sltu   | Set Less Than Imm (U)   | I   | 0010011 | 0x3 |      | rd = (rs1 < imm)?1:0         | zero-extends |
| lb     | Load Byte               | I   | 0000011 | 0x0 |      | rd = M[rs1+imm][0:7]         |              |
| lh     | Load Half               | I   | 0000011 | 0x1 |      | rd = M[rs1+imm][0:15]        |              |
| lw     | Load Word               | I   | 0000011 | 0x2 |      | rd = M[rs1+imm][0:31]        |              |
| 1bu    | Load Byte (U)           | I   | 0000011 | 0x4 |      | rd = M[rs1+imm][0:7]         | zero-extends |
| 1hu    | Load Half (U)           | I   | 0000011 | 0x5 |      | rd = M[rs1+imm][0:15]        | zero-extends |
| sb     | Store Byte              | S   | 0100011 | 0x0 |      | M[rs1+imm][0:7] = rs2[0:7]   |              |
| sh     | Store Half              | S   | 0100011 | 0x1 |      | M[rs1+imm][0:15] = rs2[0:15] |              |
| SW     | Store Word              | S   | 0100011 | 0x2 |      | M[rs1+imm][0:31] = rs2[0:31] |              |
| beq    | Branch ==               | В   | 1100011 | 0x0 |      | if(rs1 == rs2) PC += imm     |              |
| bne    | Branch !=               | В   | 1100011 | 0x1 |      | if(rs1 != rs2) PC += imm     |              |
| blt    | Branch <                | В   | 1100011 | 0x4 |      | if(rs1 < rs2) PC += imm      |              |
| bge    | Branch ≤                | В   | 1100011 | 0x5 |      | if(rs1 >= rs2) PC += imm     |              |
| bltu   | Branch < (U)            | В   | 1100011 | 0x6 |      | if(rs1 < rs2) PC += imm      | zero-extends |
| bgeu   | Branch $\geq$ (U)       | В   | 1100011 | 0x7 |      | if(rs1 >= rs2) PC += imm     | zero-extends |
| jal    | Jump And Link           | J   | 1101111 |     |      | rd = PC+4; PC += imm         |              |
| jalr   | Jump And Link Reg       | I   | 1100111 | 0x0 |      | rd = PC+4; PC = rs1          |              |
| lui    | Load Upper Imm          | U   | 0110111 |     |      | rd = imm << 12               |              |
| auipc  | Add Upper Imm to PC     | U   | 0010111 |     |      | rd = PC + (imm << 12)        |              |
| ecall  | Environment Call        | I   | 1110011 | 0x0 | 0x00 | Transfer control to OS       | imm: 0x000   |
| ebreak | Environment Break       | I   | 1110011 | 0x0 | 0x00 | Transfer control to debugger | imm: 0x001   |

#### **Standard Extensions**

### **RV32M Multiply Extension**

| Inst  | Name             | FMT | Opcode  | F3  | F7   | Description (C)         |
|-------|------------------|-----|---------|-----|------|-------------------------|
| mul   | MUL              | R   | 0110011 | 0x0 | 0x01 | rd = (rs1 * rs2)[31:0]  |
| mulh  | MUL High         | R   | 0110011 | 0x1 | 0x01 | rd = (rs1 * rs2)[63:32] |
| mulsu | MUL High (S) (U) | R   | 0110011 | 0x2 | 0x01 | rd = (rs1 * rs2)[63:32] |
| mulu  | MUL High (U)     | R   | 0110011 | 0x3 | 0x01 | rd = (rs1 * rs2)[63:32] |
| div   | DIV              | R   | 0110011 | 0x4 | 0x01 | rd = rs1 / rs2          |
| divu  | DIV (U)          | R   | 0110011 | 0x5 | 0x01 | rd = rs1 / rs2          |
| rem   | Remainder        | R   | 0110011 | 0x6 | 0x01 | rd = rs1 % rs2          |
| remu  | Remainder (U)    | R   | 0110011 | 0x7 | 0x01 | rd = rs1 % rs2          |

#### **RV32A Atomic Extension**

- aq: acquire access bit this operation must occur before later memory ops
- rl: release access bit this operation must occur after earlier memory ops

| 31        | 27   | 26     | 25      | 24 |     | 20   | 19  |     | 15  | 14    | 12 1                           | 1             | 7 6              | 0    |
|-----------|------|--------|---------|----|-----|------|-----|-----|-----|-------|--------------------------------|---------------|------------------|------|
| funct5    |      | aq     | rl      |    | rs2 |      |     | rs1 |     | funct | 3                              | rd            | opcode           |      |
| 5         |      | 1      | 1       |    | 5   |      |     | 5   |     | 3     |                                | 5             | 7                |      |
| Inst      | Nan  | ie     |         |    | FMT | Opco | ode | F3  | F5  | De    | scrip                          | otion (C)     |                  |      |
| lr.w      | Load | l Rese | erved   |    | R   | 0101 | 111 | 0x2 | 0x0 | 2 rd  | = M                            | rs1], reserv  | e M[rs1]         |      |
| SC.W      | Stor | e Con  | ditiona | al | R   | 0101 | 111 | 0x2 | 0x0 | 3 if  | (res                           | served) { M[r | rs1] = rs2; rd = | 0 }  |
|           |      |        |         |    |     |      |     |     |     | els   | se {                           | rd = 1 }      |                  |      |
| amoswap.w | Ator | nic Sv | vap     |    | R   | 0101 | 111 | 0x2 | 0x0 | 1 rd  | = M                            | [rs1]; swap(r | d, rs2); M[rs1]  | = rd |
| amoadd.w  | Ator | nic Al | DD      |    | R   | 0101 | 111 | 0x2 | 0x0 | 7 rd  | = M                            | [rs1] + rs2;  | M[rs1] = rd      |      |
| amoand.w  | Ator | nic Al | ND      |    | R   | 0101 | 111 | 0x2 | 0x0 | C rd  | rd = M[rs1] & rs2; M[rs1] = rd |               |                  |      |
| amoor.w   | Ator | nic O  | R       |    | R   | 0101 | 111 | 0x2 | 0x0 | A rd  | = M                            | rs1]   rs2;   | M[rs1] = rd      |      |
| amoxor.w  | Ator | nix X0 | OR      |    | R   | 0101 | 111 | 0x2 | 0x0 | 4 rd  | = M                            | rs1] ^ rs2;   | M[rs1] = rd      |      |
| amomax.w  | Ator | nic M  | AX      |    | R   | 0101 | 111 | 0x2 | 0x1 | 4 rd  | = ma                           | ax(M[rs1], rs | 2); M[rs1] = rd  |      |
| amomin.w  | Ator | nic M  | IN      |    | R   | 0101 | 111 | 0x2 | 0x1 | ∂ rd  | = m:                           | in(M[rs1], rs | 2); M[rs1] = rd  |      |

# RV32F / D Floating-Point Extensions

| Inst      | Name | FMT | Opcode | F3 | F5 | Description (C) |
|-----------|------|-----|--------|----|----|-----------------|
| flw       |      | R   |        |    |    |                 |
| fsw       |      | R   |        |    |    |                 |
| fmadd.s   |      | R   |        |    |    |                 |
| fmsub.s   |      | R   |        |    |    |                 |
| fnmsub.s  |      | R   |        |    |    |                 |
| fnmadd.s  |      | R   |        |    |    |                 |
| fadd.s    |      | R   |        |    |    |                 |
| fsub.s    |      | R   |        |    |    |                 |
| fmul.s    |      | R   |        |    |    |                 |
| fdiv.s    |      | R   |        |    |    |                 |
| fsqrt.s   |      | R   |        |    |    |                 |
| fsgnj.s   |      | R   |        |    |    |                 |
| fsgnjn.s  |      | R   |        |    |    |                 |
| fsgnjx.s  |      | R   |        |    |    |                 |
| fmin.s    |      | R   |        |    |    |                 |
| fmax.s    |      | R   |        |    |    |                 |
| fcvt.w.s  |      | R   |        |    |    |                 |
| fcvt.wu.s |      | R   |        |    |    |                 |
| fmv.x.w   |      | R   |        |    |    |                 |
| feq.s     |      | R   |        |    |    |                 |
| flt.s     |      | R   |        |    |    |                 |
| fle.s     |      | R   |        |    |    |                 |
| fclass.s  |      | R   |        |    |    |                 |
| fcvt.s.w  |      | R   |        |    |    |                 |
| fcvt.s.wu |      | R   |        |    |    |                 |
| fmv.w.x   |      | R   |        |    |    |                 |

# **Pseudo Instructions**

| Pseudoinstruction         | Base Instruction(s)                                                | Meaning                         |
|---------------------------|--------------------------------------------------------------------|---------------------------------|
| la rd, symbol             | <pre>auipc rd, symbol[31:12] addi rd, rd, symbol[11:0]</pre>       | Load address                    |
| l{b h w d} rd, symbol     | <pre>auipc rd, symbol[31:12] l{b h w d} rd, symbol[11:0](rd)</pre> | Load global                     |
| s{b h w d} rd, symbol, rt | <pre>auipc rt, symbol[31:12] s{b h w d} rd, symbol[11:0](rt)</pre> | Store global                    |
| fl{w d} rd, symbol, rt    | <pre>auipc rt, symbol[31:12] fl{w d} rd, symbol[11:0](rt)</pre>    | Floating-point load global      |
| fs{w d} rd, symbol, rt    | auipc rt, symbol[31:12] fs{w d} rd, symbol[11:0](rt)               | Floating-point store global     |
| nop                       | addi x0, x0, 0                                                     | No operation                    |
| li rd, immediate          | Myriad sequences                                                   | Load immediate                  |
| mv rd, rs                 | addi rd, rs, 0                                                     | Copy register                   |
| not rd, rs                | xori rd, rs, -1                                                    | One's complement                |
| neg rd, rs                | sub rd, x0, rs                                                     | Two's complement                |
| negw rd, rs               | subw rd, x0, rs                                                    | Two's complement word           |
| sext.w rd, rs             | addiw rd, rs, 0                                                    | Sign extend word                |
| seqz rd, rs               | sltiu rd, rs, 1                                                    | Set if = zero                   |
| snez rd, rs               | sltu rd, rs, r                                                     | Set if $\neq$ zero              |
| sltz rd, rs               |                                                                    | Set if < zero                   |
|                           | slt rd, rs, x0                                                     | Set if < zero                   |
| sgtz rd, rs               | slt rd, x0, rs                                                     |                                 |
| fmv.s rd, rs              | fsgnj.s rd, rs, rs                                                 | Copy single-precision register  |
| fabs.s rd, rs             | fsgnjx.s rd, rs, rs                                                | Single-precision absolute value |
| fneg.s rd, rs             | fsgnjn.s rd, rs, rs                                                | Single-precision negate         |
| fmv.d rd, rs              | fsgnj.d rd, rs, rs                                                 | Copy double-precision register  |
| fabs.d rd, rs             | fsgnjx.d rd, rs, rs                                                | Double-precision absolute value |
| fneg.d rd, rs             | fsgnjn.d rd, rs, rs                                                | Double-precision negate         |
| beqz rs, offset           | beq rs, x0, offset                                                 | Branch if = zero                |
| bnez rs, offset           | bne rs, x0, offset                                                 | Branch if $\neq$ zero           |
| blez rs, offset           | bge x0, rs, offset                                                 | Branch if $\leq$ zero           |
| bgez rs, offset           | bge rs, x0, offset                                                 | Branch if $\geq$ zero           |
| bltz rs, offset           | blt rs, x0, offset                                                 | Branch if $<$ zero              |
| bgtz rs, offset           | blt x0, rs, offset                                                 | Branch if > zero                |
| bgt rs, rt, offset        | blt rt, rs, offset                                                 | Branch if >                     |
| ble rs, rt, offset        | bge rt, rs, offset                                                 | Branch if $\leq$                |
| bgtu rs, rt, offset       | bltu rt, rs, offset                                                | Branch if $>$ , unsigned        |
| bleu rs, rt, offset       | bgeu rt, rs, offset                                                | Branch if $\leq$ , unsigned     |
| j offset                  | jal x0, offset                                                     | Jump                            |
| jal offset                | jal x1, offset                                                     | Jump and link                   |
| jr rs                     | jalr x0, rs, 0                                                     | Jump register                   |
| jalr rs                   | jalr x1, rs, 0                                                     | Jump and link register          |
| ret                       | jalr x0, x1, 0                                                     | Return from subroutine          |
| aall affaat               | <pre>auipc x1, offset[31:12]</pre>                                 | Call for avvey asheresting      |
| call offset               | jalr x1, x1, offset[11:0]                                          | Call far-away subroutine        |
| tail offset               | auipc x6, offset[31:12]<br>jalr x0, x6, offset[11:0]               | Tail call far-away subroutine   |
| fence                     | fence iorw, iorw                                                   | Fence on all memory and I/O     |
| 1 EIICE                   | TEHCE TOTW, TOTW                                                   | rence on an memory and 1/0      |

# Registers

| Register | ABI Name | Description           | Saver  |
|----------|----------|-----------------------|--------|
| x0       | zero     | Zero constant         | _      |
| x1       | ra       | Return address        | Caller |
| x2       | sp       | Stack pointer         | _      |
| x3       | gp       | Global pointer        | _      |
| x4       | tp       | Thread pointer        | Callee |
| x5       | t0-t2    | Temporaries           | Caller |
| x8       | s0 / fp  | Saved / frame pointer | Callee |
| x9       | s1       | Saved register        | Callee |
| x10-x11  | a0-a1    | Fn args/return values | Caller |
| x12-x17  | a2-a7    | Fn args               | Caller |
| x18-x27  | s2-s11   | Saved registers       | Callee |
| x28-x31  | t3-t6    | Temporaries           | Caller |
| f0-7     | ft0-7    | FP temporaries        | Caller |
| f8-9     | fs0-1    | FP saved registers    | Callee |
| f10-11   | fa0-1    | FP args/return values | Caller |
| f12-17   | fa2-7    | FP args               | Caller |
| f18-27   | fs2-11   | FP saved registers    | Callee |
| f28-31   | ft8-11   | FP temporaries        | Caller |