

**RISC-V RV32I Reference Card**  
(V2.1)

| inst                 | operands                   | name                     | type | opcode          | funct3     | funct7          | description                                                      |      | asm example |             |  |
|----------------------|----------------------------|--------------------------|------|-----------------|------------|-----------------|------------------------------------------------------------------|------|-------------|-------------|--|
| register arithmetic  | <b>add</b> rd, rs1, rs2    | add                      | R    | <b>011 0011</b> | <b>000</b> | <b>000 0000</b> | r[rd] = r[rs1] + r[rs2]                                          |      | add         | t3, t1, t2  |  |
|                      | <b>sub</b> rd, rs1, rs2    | subtract                 | R    | <b>011 0011</b> | <b>000</b> | <b>010 0000</b> | r[rd] = r[rs1] - r[rs2]                                          |      | sub         | t3, t1, t2  |  |
|                      | <b>sll</b> rd, rs1, rs2    | shift left logical       | R    | <b>011 0011</b> | <b>001</b> | <b>000 0000</b> | r[rd] = r[rs1] << r[rs2][4:0]                                    |      | sll         | t3, t1, t2  |  |
|                      | <b>slt</b> rd, rs1, rs2    | set less than            | R    | <b>011 0011</b> | <b>010</b> | <b>000 0000</b> | r[rd] = (r[rs1] < r[rs2]) ? 1 : 0                                | slt  | t3, t1, t2  |             |  |
|                      | <b>sltu</b> rd, rs1, rs2   | set less than unsigned   | R    | <b>011 0011</b> | <b>011</b> | <b>000 0000</b> | r[rd] = (r[rs1] <= r[rs2]) ? 1 : 0                               | sltu | t3, t1, t2  |             |  |
|                      | <b>xor</b> rd, rs1, rs2    | exclusive or             | R    | <b>011 0011</b> | <b>100</b> | <b>000 0000</b> | r[rd] = r[rs1] ^ r[rs2]                                          |      | xor         | t3, t1, t2  |  |
|                      | <b>srl</b> rd, rs1, rs2    | shift right logical      | R    | <b>011 0011</b> | <b>101</b> | <b>000 0000</b> | r[rd] = r[rs1] >> r[rs2][4:0]                                    |      | srl         | t3, t1, t2  |  |
|                      | <b>sra</b> rd, rs1, rs2    | shift right arithmetic   | R    | <b>011 0011</b> | <b>101</b> | <b>010 0000</b> | r[rd] = r[rs1] >>> r[rs2][4:0]                                   |      | sra         | t3, t1, t2  |  |
|                      | <b>or</b> rd, rs1, rs2     | or                       | R    | <b>011 0011</b> | <b>110</b> | <b>000 0000</b> | r[rd] = r[rs1]   r[rs2]                                          |      | or          | t3, t1, t2  |  |
|                      | <b>and</b> rd, rs1, rs2    | and                      | R    | <b>011 0011</b> | <b>111</b> | <b>000 0000</b> | r[rd] = r[rs1] & r[rs2]                                          |      | and         | t3, t1, t2  |  |
| immediate arithmetic | <b>addi</b> rd, rs1, imm   | add immediate            | I    | <b>001 0011</b> | <b>000</b> |                 | r[rd] = r[rs1] + signext(imm)                                    |      | addi        | t2, t1, 5   |  |
|                      | <b>slli</b> rd, rs1, shamt | shift left logical imm.  | I    | <b>001 0011</b> | <b>001</b> | <b>000 0000</b> | r[rd] = r[rs1] << shamt                                          |      | slli        | t2, t1, 2   |  |
|                      | <b>slti</b> rd, rs1, imm   | set less than imm.       | I    | <b>001 0011</b> | <b>010</b> |                 | r[rd] = r[rs1] < signext(imm)                                    |      | slti        | t2, t1, 5   |  |
|                      | <b>sltiu</b> rd, rs1, imm  | set less than imm. uns.  | I    | <b>001 0011</b> | <b>011</b> |                 | r[rd] = r[rs1] <= signext(imm)                                   |      | sltiu       | t2, t1, 5   |  |
|                      | <b>xori</b> rd, rs1, imm   | exclusive or imm.        | I    | <b>001 0011</b> | <b>100</b> |                 | r[rd] = r[rs1] ^ signext(imm)                                    |      | xori        | t2, t1, 5   |  |
|                      | <b>srli</b> rd, rs1, shamt | shift right logical imm. | I    | <b>001 0011</b> | <b>101</b> | <b>000 0000</b> | r[rd] = r[rs1] >> shamt                                          |      | srli        | t2, t1, 2   |  |
|                      | <b>srai</b> rd, rs1, shamt | shift right arith. imm.  | I    | <b>001 0011</b> | <b>101</b> | <b>010 0000</b> | r[rd] = r[rs1] >>> shamt                                         |      | srai        | t2, t1, 2   |  |
|                      | <b>ori</b> rd, rs1, imm    | or immediate             | I    | <b>001 0011</b> | <b>110</b> |                 | r[rd] = r[rs1]   signext(imm)                                    |      | ori         | t2, t1, 5   |  |
|                      | <b>andi</b> rd, rs1, imm   | and immediate            | I    | <b>001 0011</b> | <b>111</b> |                 | r[rd] = r[rs1] & signext(imm)                                    |      | andi        | t2, t1, 5   |  |
| load                 | <b>lui</b> rd, imm         | load upper imm.          | U    | <b>011 0111</b> |            |                 | r[rd] = {imm, 12'b0}                                             |      | lui         | t1, 0xacafe |  |
|                      | <b>auipc</b> rd, imm       | add upper imm. to pc     | U    | <b>001 0111</b> |            |                 | r[rd] = pc + {imm, 12'b0}                                        |      | auipc       | t1, 0xacafe |  |
| store                | <b>lb</b> rd, offset(rs1)  | load byte                | I    | <b>000 0011</b> | <b>000</b> |                 | data = mem[r[rs1] + signext(imm)]<br>r[rd] = signext(data[7:0])  |      | lb          | t2, 5(t1)   |  |
|                      | <b>lh</b> rd, offset(rs1)  | load half-word           | I    | <b>000 0011</b> | <b>001</b> |                 | data = mem[r[rs1] + signext(imm)]<br>r[rd] = signext(data[15:0]) |      | lh          | t2, 2(t1)   |  |
|                      | <b>lw</b> rd, offset(rs1)  | load word                | I    | <b>000 0011</b> | <b>010</b> |                 | r[rd] = mem[r[rs1] + signext(imm)]                               |      | lw          | t2, 4(t1)   |  |
|                      | <b>lbu</b> rd, offset(rs1) | load byte unsigned       | I    | <b>000 0011</b> | <b>100</b> |                 | data = mem[r[rs1] + signext(imm)]<br>r[rd] = zeroext(data[7:0])  |      | lbu         | t2, 5(t1)   |  |
|                      | <b>lhu</b> rd, offset(rs1) | load half-word uns.      | I    | <b>000 0011</b> | <b>101</b> |                 | data = mem[r[rs1] + signext(imm)]<br>r[rd] = zeroext(data[15:0]) |      | lhu         | t2, 2(t1)   |  |

\*slli, srli, and srai use 5-bit shamt (shift amount) instead of imm field. Format: [31-25]: funct7, [24:20]: shamt, [19-15]: rs1; [14:12]: funct3; [11:7]: rd; [6:0]: opcode.

#### Format of instruction types

|          |                       |          |             |             |             |             |
|----------|-----------------------|----------|-------------|-------------|-------------|-------------|
| <b>R</b> | funct7[6:0]           | rs2[4:0] | rs1[4:0]    | funct3[2:0] | rd[4:0]     | opcode[6:0] |
|          | 31 25 24              | 20 19    | 15 14       | 12 11       | 7 6         | 0           |
| <b>I</b> | imm[11:0]             | rs1[4:0] | funct3[2:0] | rd[4:0]     | opcode[6:0] |             |
|          | 31                    | 20 19    | 15 14       | 12 11       | 7 6         | 0           |
| <b>S</b> | imm[11:5]             | rs2[4:0] | rs1[4:0]    | funct3[2:0] | imm[4:0]    | opcode[6:0] |
|          | 31 25 24              | 20 19    | 15 14       | 12 11       | 7 6         | 0           |
| <b>B</b> | imm[12 10:5]          | rs2[4:0] | rs1[4:0]    | funct3[2:0] | imm[4:1 11] | opcode[6:0] |
|          | 31 25 24              | 20 19    | 15 14       | 12 11       | 7 6         | 0           |
| <b>U</b> | imm[31:12]            |          |             | rd[4:0]     | opcode[6:0] |             |
|          | 31                    |          |             | 12 11       | 7 6         | 0           |
| <b>J</b> | imm[20 10:1 11 19:12] |          |             | rd[4:0]     | opcode[6:0] |             |
|          | 31                    |          |             | 12 11       | 7 6         | 0           |

**RISC-V RV32I Reference Card**  
(V2.1)

| inst               | operands                            | name                                    | type | opcode          | funct3     | description                                                                      | asm example                                          |
|--------------------|-------------------------------------|-----------------------------------------|------|-----------------|------------|----------------------------------------------------------------------------------|------------------------------------------------------|
| store              | <b>sb</b> <b>rs2, offset(rs1)</b>   | store byte                              | S    | <b>010 0011</b> | <b>000</b> | target = r[rs1] + signext(imm)<br>mem[target] = r[rs2][7:0]                      | sb t2, 5(t1)                                         |
|                    | <b>sh</b> <b>rs2, offset(rs1)</b>   | store half-word                         | S    | <b>010 0011</b> | <b>001</b> | target = r[rs1] + signext(imm)<br>mem[target] = r[rs2][15:0]                     | sh t2, 2(t1)                                         |
|                    | <b>sw</b> <b>rs2, offset(rs1)</b>   | store word                              | S    | <b>010 0011</b> | <b>010</b> | target = r[rs1] + signext(imm)<br>mem[target] = r[rs2]                           | sw t2, 4(t1)                                         |
| conditional branch | <b>beq</b> <b>rs1, rs2, offset</b>  | branch if equal                         | B    | <b>110 0011</b> | <b>000</b> | if (r[rs1] == r[rs2])<br>pc += signext({imm, 1'b0})                              | beq t2, t1, label<br>if r1 == r2 go to label         |
|                    | <b>bne</b> <b>rs1, rs2, offset</b>  | branch if not equal                     | B    | <b>110 0011</b> | <b>001</b> | if (r[rs1] != r[rs2])<br>pc += signext({imm, 1'b0})                              | bne t2, t1, label<br>if r1 != r2 go to label         |
|                    | <b>blt</b> <b>rs1, rs2, offset</b>  | branch if less than                     | B    | <b>110 0011</b> | <b>100</b> | if (r[rs1] < r[rs2])<br>pc += signext({imm, 1'b0})                               | blt t2, t1, label<br>if r1 < r2 go to label          |
|                    | <b>bge</b> <b>rs1, rs2, offset</b>  | branch if greater than or equal to      | B    | <b>110 0011</b> | <b>101</b> | if (r[rs1] >= r[rs2])<br>pc += signext({imm, 1'b0})                              | bge t2, t1, label<br>if r1 >= r2 go to label         |
|                    | <b>bltu</b> <b>rs1, rs2, offset</b> | branch if less than unsigned            | B    | <b>110 0011</b> | <b>110</b> | if (r[rs1] < r[rs2])<br>pc += signext({imm, 1'b0})                               | bltu t2, t1, label<br>if r1 < r2 go to label         |
|                    | <b>bgeu</b> <b>rs1, rs2, offset</b> | branch if greater than or equal to uns. | B    | <b>110 0011</b> | <b>111</b> | if (r[rs1] >= r[rs2])<br>pc += signext({imm, 1'b0})                              | bgeu t2, t1, label<br>if r1 >= r2 go to label        |
| jump               | <b>jal</b> <b>rd, offset</b>        | jump (to address) and link              | J    | <b>110 1111</b> |            | r[rd] = pc + 4<br>pc += signext({offset, 1'b0})                                  | jal x1, label<br>save pc in x1, go to label          |
|                    | <b>jalr</b> <b>rd, offset(rs1)</b>  | jump (to) register and link             | I    | <b>110 0111</b> |            | r[rd] = pc + 4<br>target = r[rs1] + signext(offset)<br>pc = {target[31:1], 1'b0} | jalr x1, 16(s1)<br>save pc in x1, go to addr s1 + 16 |

### Formats of immediate produced by instruction types

|          |                  |             |             |             |             |
|----------|------------------|-------------|-------------|-------------|-------------|
| <b>I</b> | -- inst[31] --   |             | inst[30:25] | inst[24:21] | [20]        |
|          | 31               |             | 11 10       | 5 4         | 1 0         |
| <b>S</b> | -- inst[31] --   |             | inst[30:25] | inst[11:8]  | [7]         |
|          | 31               |             | 11 10       | 5 4         | 1 0         |
| <b>B</b> | -- inst[31] --   | [7]         | inst[30:25] | inst[11:8]  | 0           |
|          | 31               | 12 11 10    | 5 4         |             | 1 0         |
| <b>U</b> | [31] inst[30:20] | inst[19:12] |             | 0           |             |
|          | 31 30 20 19      |             | 12 11       |             | 0           |
| <b>J</b> | -- inst[31] --   | inst[19:12] | [20]        | inst[30:25] | inst[24:21] |
|          | 31 20 19         | 12 11 10    | 5 4         |             | 1 0         |

### Register types

| #  | name        | description      | #   | name         | description    | #   | name      | description    | #   | name       | description    |
|----|-------------|------------------|-----|--------------|----------------|-----|-----------|----------------|-----|------------|----------------|
| x0 | <b>zero</b> | constant value 0 | x8  | <b>s0/fp</b> | frame pointer  | x16 | <b>a6</b> | arguments      | x24 | <b>s8</b>  |                |
| x1 | <b>ra</b>   | return address   | x9  | <b>s1</b>    | (callee) saved | x17 | <b>a7</b> |                | x25 | <b>s9</b>  | (callee) saved |
| x2 | <b>sp</b>   | stack pointer    | x10 | <b>a0</b>    | arguments/     | x18 | <b>s2</b> |                | x26 | <b>s10</b> |                |
| x3 | <b>gp</b>   | global pointer   | x11 | <b>a1</b>    | return values  | x19 | <b>s3</b> |                | x27 | <b>s11</b> |                |
| x4 | <b>tp</b>   | thread pointer   | x12 | <b>a2</b>    |                | x20 | <b>s4</b> | (callee) saved | x28 | <b>t3</b>  |                |
| x5 | <b>t0</b>   | (caller saved)   | x13 | <b>a3</b>    | arguments      | x21 | <b>s5</b> |                | x29 | <b>t4</b>  | (caller saved) |
| x6 | <b>t1</b>   |                  | x14 | <b>a4</b>    |                | x22 | <b>s6</b> |                | x30 | <b>t5</b>  | temporaries    |
| x7 | <b>t2</b>   |                  | x15 | <b>a5</b>    |                | x23 | <b>s7</b> |                | x31 | <b>t6</b>  |                |
|    |             | caller saved     |     |              |                |     |           | callee saved   |     |            |                |