

## RISC-V RV32IM ISA Reference Sheet v1.4

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

| instruction               | fmt | opcode | fun3 | fun7 | semantics                                         | encoding                                |
|---------------------------|-----|--------|------|------|---------------------------------------------------|-----------------------------------------|
| lui <b>rd,imm20</b>       | U   | 0x37   |      |      | <b>rd = imm20 &lt;&lt; 12</b>                     | iiii iiii iiii iiii iiii dddd d011 0111 |
| auipc <b>rd,imm20</b>     | U   | 0x17   |      |      | <b>rd = pc + (imm20 &lt;&lt; 12)</b>              | iiii iiii iiii iiii iiii dddd d001 0111 |
| addi <b>rd,rs1,imm12</b>  | I   | 0x13   | 000  |      | <b>rd = rs1 + se(imm12)</b>                       | iiii iiii iiii ssss s000 dddd d001 0011 |
| slti <b>rd,rs1,imm12</b>  | I   | 0x13   | 010  |      | <b>rd = rs1 &lt;signed se(imm12) ? 1 : 0</b>      | iiii iiii iiii ssss s010 dddd d001 0011 |
| sltiu <b>rd,rs1,imm12</b> | I   | 0x13   | 011  |      | <b>rd = rs1 &lt;unsigned se(imm12) ? 1 : 0</b>    | iiii iiii iiii ssss s011 dddd d001 0011 |
| xori <b>rd,rs1,imm12</b>  | I   | 0x13   | 100  |      | <b>rd = rs1 ^ se(imm12)</b>                       | iiii iiii iiii ssss s100 dddd d001 0011 |
| ori <b>rd,rs1,imm12</b>   | I   | 0x13   | 110  |      | <b>rd = rs1   se(imm12)</b>                       | iiii iiii iiii ssss s110 dddd d001 0011 |
| andi <b>rd,rs1,imm12</b>  | I   | 0x13   | 111  |      | <b>rd = rs1 &amp; se(imm12)</b>                   | iiii iiii iiii ssss s111 dddd d001 0011 |
| slli <b>rd,rs1,imm12</b>  | I   | 0x13   | 001  | 0x0  | <b>rd = rs1 &lt;&lt; imm12[4:0]</b>               | 0000 000i iiii ssss s001 dddd d001 0011 |
| srl <b>rd,rs1,imm12</b>   | I   | 0x13   | 101  | 0x0  | <b>rd = rs1 &gt;&gt; imm12[4:0]</b>               | 0000 000i iiii ssss s101 dddd d001 0011 |
| srai <b>rd,rs1,imm12</b>  | I   | 0x13   | 101  | 0x20 | <b>rd = rs1 &gt;&gt;&gt; imm12[4:0]</b>           | 0100 000i iiii ssss s101 dddd d001 0011 |
| add <b>rd,rs1,rs2</b>     | R   | 0x33   | 000  | 0x0  | <b>rd = rs1 + rs2</b>                             | 0000 000t tttt ssss s000 dddd d011 0011 |
| sub <b>rd,rs1,rs2</b>     | R   | 0x33   | 000  | 0x20 | <b>rd = rs1 - rs2</b>                             | 0100 000t tttt ssss s000 dddd d011 0011 |
| sll <b>rd,rs1,rs2</b>     | R   | 0x33   | 001  | 0x0  | <b>rd = rs1 &lt;&lt; rs2[4:0]</b>                 | 0000 000t tttt ssss s001 dddd d011 0011 |
| slt <b>rd,rs1,rs2</b>     | R   | 0x33   | 010  | 0x0  | <b>rd = rs1 &lt;signed rs2 ? 1 : 0</b>            | 0000 000t tttt ssss s010 dddd d011 0011 |
| sltu <b>rd,rs1,rs2</b>    | R   | 0x33   | 011  | 0x0  | <b>rd = rs1 &lt;unsigned rs2 ? 1 : 0</b>          | 0000 000t tttt ssss s011 dddd d011 0011 |
| xor <b>rd,rs1,rs2</b>     | R   | 0x33   | 100  | 0x0  | <b>rd = rs1 ^ rs2</b>                             | 0000 000t tttt ssss s100 dddd d011 0011 |
| srl <b>rd,rs1,rs2</b>     | R   | 0x33   | 101  | 0x0  | <b>rd = rs1 &gt;&gt; rs2[4:0]</b>                 | 0000 000t tttt ssss s101 dddd d011 0011 |
| sra <b>rd,rs1,rs2</b>     | R   | 0x33   | 101  | 0x20 | <b>rd = rs1 &gt;&gt;&gt; rs2[4:0]</b>             | 0100 000t tttt ssss s101 dddd d011 0011 |
| or <b>rd,rs1,rs2</b>      | R   | 0x33   | 110  | 0x0  | <b>rd = rs1   rs2</b>                             | 0000 000t tttt ssss s110 dddd d011 0011 |
| and <b>rd,rs1,rs2</b>     | R   | 0x33   | 111  | 0x0  | <b>rd = rs1 &amp; rs2</b>                         | 0000 000t tttt ssss s111 dddd d011 0011 |
| lb <b>rd,imm12(rs1)</b>   | I   | 0x03   | 000  |      | <b>rd = se(mem[rs1+se(imm12)][7:0])</b>           | iiii iiii iiii ssss s000 dddd d000 0011 |
| lh <b>rd,imm12(rs1)</b>   | I   | 0x03   | 001  |      | <b>rd = se(mem[rs1+se(imm12)][15:0])</b>          | iiii iiii iiii ssss s001 dddd d000 0011 |
| lw <b>rd,imm12(rs1)</b>   | I   | 0x03   | 010  |      | <b>rd = mem[rs1+se(imm12)][31:0]</b>              | iiii iiii iiii ssss s010 dddd d000 0011 |
| lbu <b>rd,imm12(rs1)</b>  | I   | 0x03   | 100  |      | <b>rd = ze(mem[rs1+se(imm12)][7:0])</b>           | iiii iiii iiii ssss s100 dddd d000 0011 |
| lhu <b>rd,imm12(rs1)</b>  | I   | 0x03   | 101  |      | <b>rd = ze(mem[rs1+se(imm12)][15:0])</b>          | iiii iiii iiii ssss s101 dddd d000 0011 |
| sb <b>rs2,imm12(rs1)</b>  | S   | 0x23   | 000  |      | <b>mem[rs1+se(imm12)][7:0] = rs2[7:0]</b>         | iiii iiit tttt ssss s000 iii i010 0011  |
| sh <b>rs2,imm12(rs1)</b>  | S   | 0x23   | 001  |      | <b>mem[rs1+se(imm12)][15:0] = rs2[15:0]</b>       | iiii iiit tttt ssss s001 iii i010 0011  |
| sw <b>rs2,imm12(rs1)</b>  | S   | 0x23   | 010  |      | <b>mem[rs1+se(imm12)][31:0] = rs2</b>             | iiii iiit tttt ssss s010 iii i010 0011  |
| jal <b>rd,targ20</b>      | J   | 0x6f   |      |      | <b>rd = pc+4; pc += se(targ20&lt;&lt;1)</b>       | iiii iiii iiii iiii dddd d110 1111      |
| jalr <b>rd,imm12(rs1)</b> | I   | 0x67   | 000  |      | <b>rd = pc+4; pc = (rs1+se(imm12)) &amp; ~0x1</b> | iiii iiii iiii ssss s000 dddd d110 0111 |

|                                  |   |                   |     |      |                                                                |                                                       |
|----------------------------------|---|-------------------|-----|------|----------------------------------------------------------------|-------------------------------------------------------|
| <code>beq rs1,rs2,targ12</code>  | B | <code>0x63</code> | 000 |      | <code>if (rs1 == rs2) pc += se(targ12&lt;&lt;1)</code>         | <code>ffff iiit tttt ssss s000 iiiii i110 0011</code> |
| <code>bne rs1,rs2,targ12</code>  | B | <code>0x63</code> | 001 |      | <code>if (rs1 != rs2) pc += se(targ12&lt;&lt;1)</code>         | <code>ffff iiit tttt ssss s001 iiiii i110 0011</code> |
| <code>blt rs1,rs2,targ12</code>  | B | <code>0x63</code> | 100 |      | <code>if (rs1 &lt;signed rs2) pc += se(targ12&lt;&lt;1)</code> | <code>ffff iiit tttt ssss s100 iiiii i110 0011</code> |
| <code>bge rs1,rs2,targ12</code>  | B | <code>0x63</code> | 101 |      | <code>if (rs1 ≥signed rs2) pc += se(targ12&lt;&lt;1)</code>    | <code>ffff iiit tttt ssss s101 iiiii i110 0011</code> |
| <code>bltu rs1,rs2,targ12</code> | B | <code>0x63</code> | 110 |      | <code>if (rs1 &lt;unsign rs2) pc += se(targ12&lt;&lt;1)</code> | <code>ffff iiit tttt ssss s110 iiiii i110 0011</code> |
| <code>bgeu rs1,rs2,targ12</code> | B | <code>0x63</code> | 111 |      | <code>if (rs1 ≥unsign rs2) pc += se(targ12&lt;&lt;1)</code>    | <code>ffff iiit tttt ssss s111 iiiii i110 0011</code> |
| <code>mul rd,rs1,rs2</code>      | R | <code>0x33</code> | 000 | 0x01 | <code>rd = (rs1 * rs2)[31:0]</code>                            | <code>0000 001t tttt ssss s000 dddd d011 0011</code>  |
| <code>mulh rd,rs1,rs2</code>     | R | <code>0x33</code> | 001 | 0x01 | <code>rd = (signed(rs1) * signed(rs2))[63:32]</code>           | <code>0000 001t tttt ssss s001 dddd d011 0011</code>  |
| <code>mulhsu rd,rs1,rs2</code>   | R | <code>0x33</code> | 010 | 0x01 | <code>rd = (signed(rs1) * unsign(rs2))[63:32]</code>           | <code>0000 001t tttt ssss s010 dddd d011 0011</code>  |
| <code>mulhu rd,rs1,rs2</code>    | R | <code>0x33</code> | 011 | 0x01 | <code>rd = (unsign(rs1) * unsign(rs2))[63:32]</code>           | <code>0000 001t tttt ssss s011 dddd d011 0011</code>  |
| <code>div rd,rs1,rs2</code>      | R | <code>0x33</code> | 100 | 0x01 | <code>rd = rs1 /signed rs2</code>                              | <code>0000 001t tttt ssss s100 dddd d011 0011</code>  |
| <code>divu rd,rs1,rs2</code>     | R | <code>0x33</code> | 101 | 0x01 | <code>rd = rs1 /unsign rs2</code>                              | <code>0000 001t tttt ssss s101 dddd d011 0011</code>  |
| <code>rem rd,rs1,rs2</code>      | R | <code>0x33</code> | 110 | 0x01 | <code>rd = rs1 %signed rs2</code>                              | <code>0000 001t tttt ssss s110 dddd d011 0011</code>  |
| <code>remu rd,rs1,rs2</code>     | R | <code>0x33</code> | 111 | 0x01 | <code>rd = rs1 %unsign rs2</code>                              | <code>0000 001t tttt ssss s111 dddd d011 0011</code>  |