

# Assignment 1

Faculteit Industriële  
Ingenieurswetenschappen  
EA-ICT

Kris Myny

RISC-V®  
ARCHITECTURE

RISC-

COMPUTER  
ARCHITECTURES



# Assignment 1

- You have to write assembler code for three different programs.
- Use sufficient # to explain the program.
- Upload a small report (*Word or Latex*) showing your code and output for the assignment.
- By when? Sunday **September 28, 2025**
  
- Which programs?
  1. Calculate  $k = ((a - b) + (c - d) + e)$  **#basic arithmetic**
  2.  $A[6] = (A[5] + A[4]) \gg 2$  **#array with shift**
  3. While ( $\text{save}[i] == k$ )  $i += 1;$  **#simple while loop**

# Your assembly programs

- ❑ Sufficient commenting
- ❑ Typical structure of a program:

```
.data  
# this is your data
```

```
k: .word 0x0000
```

```
a: ...
```

```
.text
```

*You can choose the  
value of the data  
yourself!*

Name of function:

Your assembly code

## .data – store all data in memory

- Single words:

K: .word 0x0011 (hexadecimal)

G: .word 0b01110011 (binary)

H: .word 5 (decimal)

- Array:

A: .word 5, 11, 15, 0, 10 (he will make an array in the memory)

0A 00 00 00  
00 00 00 00  
0F 00 00 00  
0B 00 00 00  
**A[ ]** 05 00 00 00

la x22, A # load base address of a in X22

- Use la (load address) to load a base address in a register)

- Byte see next slide

## .data

### □ Characters:

lab: .byte 'h', 'e', 'l', 'l', ..., 0 (0 is marker for end)

G: .word 0b01110011 (binary)

H: .word 5 (decimal)

### □ Array

A: .word 5, 11, 15, 0, 10 (he will make an array in the memory)

Following .data give the same result in the memory:

- lab1: .string "abc"
- lab: .byte 'a', 'b', 'c', 0

# Print an enter in the console

## □ .data

```
.data  
enter_ascii: .byte 0x0A
```

## □ .text

```
lb t1, enter_ascii  
mv a1, t1  
li a0, 11  
ecall
```

## □ Print a space: (ascii table!)

- ASCII code 32  
.byte 32

# Some ecalls (environmental calls) for the simulator

To use an environmental call, load the ID into register `a0`, and load any arguments into `a1` - `a7`. Any return values will be stored in argument registers.

The following environmental calls are currently supported.

| ID<br>( <code>a0</code> ) | Name            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1                         | print_int       | prints integer in <code>a1</code>                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 4                         | print_string    | prints the null-terminated string whose address is in <code>a1</code>                                                                                                                                                                                                                                                                                                                                                                                             |
| 9                         | sbrk            | allocates <code>a1</code> bytes on the heap, returns pointer to start in <code>a0</code>                                                                                                                                                                                                                                                                                                                                                                          |
| 10                        | exit            | ends the program                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 11                        | print_character | prints ASCII character in <code>a1</code>                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 13                        | openFile        | Opens the file in the VFS where a pointer to the path is in <code>a1</code> and the permission bits are in <code>a2</code> . Returns to a0 an integer representing the file descriptor.                                                                                                                                                                                                                                                                           |
| 14                        | readFile        | Takes in: <code>a1</code> = FileDescriptor, <code>a2</code> = Where to store the data (an array), <code>a3</code> = the amount you want to read from the file. Returns <code>a0</code> = Number of items which were read and put to the given array. If it is less than <code>a3</code> it is either an error or EOF. You will have to use another ecall to determine what was the cause.                                                                         |
| 15                        | writeFile       | Takes in: <code>a1</code> = FileDescriptor, <code>a2</code> = Buffer to read data from, <code>a3</code> = amount of the buffer you want to read, <code>a4</code> = Size of each item. Returns <code>a0</code> = Number of items written. If it is less than <code>a3</code> it is either an error or EOF. You will have to use another ecall to determine what was the cause. Also, you need to flush or close the file for the changes to be written to the VFS. |
| 16                        | closeFile       | Takes in: <code>a1</code> = FileDescriptor. Returns 0 on success and EOF (-1) otherwise. Will flush the data as well.                                                                                                                                                                                                                                                                                                                                             |
| 17                        | exit2           | ends the program with return code in <code>a1</code>                                                                                                                                                                                                                                                                                                                                                                                                              |
| 18                        | fflush          | Takes in: <code>a1</code> = FileDescriptor. Will return 0 on success otherwise EOF on an error.                                                                                                                                                                                                                                                                                                                                                                   |
| 19                        | feof            | Takes in: <code>a1</code> = FileDescriptor. Returns a nonzero value when the end of file is reached otherwise, it returns 0.                                                                                                                                                                                                                                                                                                                                      |
| 20                        | ferror          | Takes in: <code>a1</code> = FileDescriptor. Returns Nnnzero value if the file stream has errors occurred, 0 otherwise.                                                                                                                                                                                                                                                                                                                                            |
| 34                        | printHex        | prints hex in <code>a1</code>                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x3CC                     | vlib            | Please check out the <a href="#">vlib page</a> to see what functions you can use!                                                                                                                                                                                                                                                                                                                                                                                 |

The environmental calls are intended to be somewhat backwards compatible with SPIM's syscalls.

As an example, the following code prints the integer `42` to the console:

```
addi a0 x0 1      # print_int ecall
addi a1 x0 42      # integer 42
ecall
```

## □ Print in console in hexadecimal

```
mv a1, REGISTER WHERE YOU STORED YOUR FINAL DATA
li a0, 34
ecall
```

## □ Stop the simulator

```
li a0, 10
ecall
```

# Some instructions (RV32I)



- X0 → 0x00000000 (zero)
- PC is a separate register

# RV32I instructions diagram

## *Integer Computation*

add {immediate}

subtract

{and  
or  
exclusive or} } {immediate}

{shift left logical  
shift right arithmetic  
shift right logical} } {immediate}

load upper immediate

add upper immediate to pc

set less than {immediate} } {unsigned}

## *Control transfer*

branch {equal  
not equal}

branch {greater than or equal  
less than} } {unsigned}

jump and link {register}

## *Loads and Stores*

load } {byte  
halfword  
word}

store } {byte  
halfword} {unsigned

## *Miscellaneous instructions*

fence loads & stores

fence.instruction & data

environment {break  
call}

control status register {read & clear bit  
read & set bit  
read & write} } {immediate}

# Instructions formats and encoding

| Instruction Formats | 31         | 30        | 29 | 28 | 27 | 26  | 25   | 24         | 23 | 22 | 21     | 20 | 19 | 18     | 17 | 16     | 15       | 14 | 13   | 12     | 11 | 10     | 9      | 8      | 7 | 6 | 5      | 4 | 3 | 2      | 1 | 0 |  |  |  |  |
|---------------------|------------|-----------|----|----|----|-----|------|------------|----|----|--------|----|----|--------|----|--------|----------|----|------|--------|----|--------|--------|--------|---|---|--------|---|---|--------|---|---|--|--|--|--|
| Register/register   | funct7     |           |    |    |    | rs2 |      |            |    |    | rs1    |    |    |        |    | funct3 |          |    | rd   |        |    | opcode |        |        |   |   |        |   |   |        |   |   |  |  |  |  |
| Immediate           | imm[11:0]  |           |    |    |    | rs1 |      |            |    |    | funct3 |    |    | rd     |    |        | opcode   |    |      |        |    |        |        | opcode |   |   |        |   |   |        |   |   |  |  |  |  |
| Upper Immediate     | imm[31:12] |           |    |    |    | rs1 |      |            |    |    | funct3 |    |    | rd     |    |        | opcode   |    |      |        |    |        |        | opcode |   |   |        |   |   |        |   |   |  |  |  |  |
| Store               | imm[11:5]  |           |    |    |    | rs2 |      |            |    |    | rs1    |    |    | funct3 |    |        | imm[4:0] |    |      | opcode |    |        |        |        |   |   | opcode |   |   |        |   |   |  |  |  |  |
| Branch              | [12]       | imm[10:5] |    |    |    | rs2 |      |            |    |    | rs1    |    |    | funct3 |    |        | imm[4:1] |    | [11] | opcode |    |        |        |        |   |   | opcode |   |   |        |   |   |  |  |  |  |
| Jump                | [20]       | imm[10:1] |    |    |    |     | [11] | imm[19:12] |    |    |        |    | rd |        |    | opcode |          |    |      |        |    |        | opcode |        |   |   |        |   |   | opcode |   |   |  |  |  |  |

• opcode (7 bit): partially specifies which of the 6 types of *instruction formats*

• funct7 + funct3 (10 bit): combined with opcode, these two fields describe what operation to perform

• rs1 (5 bit): specifies register containing first operand

• rs2 (5 bit): specifies second register operand

• rd (5 bit):: Destination register specifies register which will receive result of computation

- R: register-register operations (add, sub, xor)
- I: immediates and loads (addi, lw, srli)
- S: stores (sw, sb)
- B: conditional branches (beq, bge)
- I: long immediates (lui, auipc)
- J: unconditional jumps (jal)

# RV32I instructions

- Basic set to be supported by all further extensions (such as RV32IM, RV64G, ...)
- 47 unique instructions
- Eight ecall/ebreak/csrxx instructions can be implemented with a single SYSTEM hardware instruction that always traps (implemented in software); Implement fence and fence.i as nops → 38 instructions
- RV32I only 1/8 of the encoding space → space for ISA extensions

# Registers

| 31           | 0 |                                 |
|--------------|---|---------------------------------|
| x0 / zero    |   | Hardwired zero                  |
| x1 / ra      |   | Return address                  |
| x2 / sp      |   | Stack pointer                   |
| x3 / gp      |   | Global pointer                  |
| x4 / tp      |   | Thread pointer                  |
| x5 / t0      |   | Temporary                       |
| x6 / t1      |   | Temporary                       |
| x7 / t2      |   | Temporary                       |
| x8 / s0 / fp |   | Saved register, frame pointer   |
| x9 / s1      |   | Saved register                  |
| x10 / a0     |   | Function argument, return value |
| x11 / a1     |   | Function argument, return value |
| x12 / a2     |   | Function argument               |
| x13 / a3     |   | Function argument               |
| x14 / a4     |   | Function argument               |
| x15 / a5     |   | Function argument               |
| x16 / a6     |   | Function argument               |
| x17 / a7     |   | Function argument               |
| x18 / s2     |   | Saved register                  |
| x19 / s3     |   | Saved register                  |
| x20 / s4     |   | Saved register                  |
| x21 / s5     |   | Saved register                  |
| x22 / s6     |   | Saved register                  |
| x23 / s7     |   | Saved register                  |
| x24 / s8     |   | Saved register                  |
| x25 / s9     |   | Saved register                  |
| x26 / s10    |   | Saved register                  |
| x27 / s11    |   | Saved register                  |
| x28 / t3     |   | Temporary                       |
| x29 / t4     |   | Temporary                       |
| x30 / t5     |   | Temporary                       |
| x31 / t6     |   | Temporary                       |
| 32           |   |                                 |

| 31 | 0 |  |
|----|---|--|
| pc |   |  |
| 32 |   |  |

## □ All registers x1...X32

- Allow same operations
- Functionally interchangeable

## □ ABI (application binary interface)

- Register names: zero, ra, sp, ...

# RV32I instructions - arithmetic

| Mnemonic             | Instruction                      | Type | Description                         |
|----------------------|----------------------------------|------|-------------------------------------|
| ADD rd, rs1, rs2     | Add                              | R    | $rd \leftarrow rs1 + rs2$           |
| SUB rd, rs1, rs2     | Subtract                         | R    | $rd \leftarrow rs1 - rs2$           |
| ADDI rd, rs1, imm12  | Add immediate                    | I    | $rd \leftarrow rs1 + imm12$         |
| SLT rd, rs1, rs2     | Set less than                    | R    | $rd \leftarrow rs1 < rs2 ? 1 : 0$   |
| SLTI rd, rs1, imm12  | Set less than immediate          | I    | $rd \leftarrow rs1 < imm12 ? 1 : 0$ |
| SLTU rd, rs1, rs2    | Set less than unsigned           | R    | $rd \leftarrow rs1 < rs2 ? 1 : 0$   |
| SLTIU rd, rs1, imm12 | Set less than immediate unsigned | I    | $rd \leftarrow rs1 < imm12 ? 1 : 0$ |
| LUI rd, imm20        | Load upper immediate             | U    | $rd \leftarrow imm20 \ll 12$        |
| AUIP rd, imm20       | Add upper immediate to PC        | U    | $rd \leftarrow PC + imm20 \ll 12$   |

# RV32I instructions - logical

| Mnemonic            | Instruction                      | Type | Description                    |
|---------------------|----------------------------------|------|--------------------------------|
| AND rd, rs1, rs2    | AND                              | R    | $rd \leftarrow rs1 \And rs2$   |
| OR rd, rs1, rs2     | OR                               | R    | $rd \leftarrow rs1 \Or rs2$    |
| XOR rd, rs1, rs2    | XOR                              | R    | $rd \leftarrow rs1 \Xor rs2$   |
| ANDI rd, rs1, imm12 | AND immediate                    | I    | $rd \leftarrow rs1 \And imm12$ |
| ORI rd, rs1, imm12  | OR immediate                     | I    | $rd \leftarrow rs1 \Or imm12$  |
| XORI rd, rs1, imm12 | XOR immediate                    | I    | $rd \leftarrow rs1 \Xor imm12$ |
| SLL rd, rs1, rs2    | Shift left logical               | R    | $rd \leftarrow rs1 \ll rs2$    |
| SRL rd, rs1, rs2    | Shift right logical              | R    | $rd \leftarrow rs1 \gg rs2$    |
| SRA rd, rs1, rs2    | Shift right arithmetic           | R    | $rd \leftarrow rs1 \gg rs2$    |
| SLLI rd, rs1, shamt | Shift left logical immediate     | I    | $rd \leftarrow rs1 \ll shamt$  |
| SRLI rd, rs1, shamt | Shift right logical imm.         | I    | $rd \leftarrow rs1 \gg shamt$  |
| SRAI rd, rs1, shamt | Shift right arithmetic immediate | I    | $rd \leftarrow rs1 \gg shamt$  |

# RV32I instructions – load/store

| Mnemonic           | Instruction            | Type | Description                                            |
|--------------------|------------------------|------|--------------------------------------------------------|
| LD rd, imm12(rs1)  | Load doubleword        | I    | $rd \leftarrow \text{mem}[rs1 + \text{imm12}]$         |
| LW rd, imm12(rs1)  | Load word              | I    | $rd \leftarrow \text{mem}[rs1 + \text{imm12}]$         |
| LH rd, imm12(rs1)  | Load halfword          | I    | $rd \leftarrow \text{mem}[rs1 + \text{imm12}]$         |
| LB rd, imm12(rs1)  | Load byte              | I    | $rd \leftarrow \text{mem}[rs1 + \text{imm12}]$         |
| LWU rd, imm12(rs1) | Load word unsigned     | I    | $rd \leftarrow \text{mem}[rs1 + \text{imm12}]$         |
| LHU rd, imm12(rs1) | Load halfword unsigned | I    | $rd \leftarrow \text{mem}[rs1 + \text{imm12}]$         |
| LBU rd, imm12(rs1) | Load byte unsigned     | I    | $rd \leftarrow \text{mem}[rs1 + \text{imm12}]$         |
| SD rs2, imm12(rs1) | Store doubleword       | S    | $rs2 \rightarrow \text{mem}[rs1 + \text{imm12}]$       |
| SW rs2, imm12(rs1) | Store word             | S    | $rs2(31:0) \rightarrow \text{mem}[rs1 + \text{imm12}]$ |
| SH rs2, imm12(rs1) | Store halfword         | S    | $rs2(15:0) \rightarrow \text{mem}[rs1 + \text{imm12}]$ |
| SB rs2, imm12(rs1) | Store byte             | S    | $rs2(7:0) \rightarrow \text{mem}[rs1 + \text{imm12}]$  |

# RV32I instructions – branching

| Mnemonic             | Instruction                           | Type | Description                                           |
|----------------------|---------------------------------------|------|-------------------------------------------------------|
| BEQ rs1, rs2, imm12  | Branch equal                          | SB   | if $rs1 == rs2$<br>$PC \leftarrow PC + imm12$         |
| BNE rs1, rs2, imm12  | Branch not equal                      | SB   | if $rs1 != rs2$<br>$PC \leftarrow PC + imm12$         |
| BGE rs1, rs2, imm12  | Branch greater than or equal          | SB   | if $rs1 \geq rs2$<br>$PC \leftarrow PC + imm12$       |
| BGEU rs1, rs2, imm12 | Branch greater than or equal unsigned | SB   | if $rs1 \geq rs2$<br>$PC \leftarrow PC + imm12$       |
| BLT rs1, rs2, imm12  | Branch less than                      | SB   | if $rs1 < rs2$<br>$PC \leftarrow PC + imm12$          |
| BLTU rs1, rs2, imm12 | Branch less than unsigned             | SB   | if $rs1 < rs2$<br>$PC \leftarrow PC + imm12 \ll 1$    |
| JAL rd, imm20        | Jump and link                         | UJ   | $rd \leftarrow PC + 4$<br>$PC \leftarrow PC + imm20$  |
| JALR rd, imm12(rs1)  | Jump and link register                | I    | $rd \leftarrow PC + 4$<br>$PC \leftarrow rs1 + imm12$ |

# RV32I instructions – pseudo-instructions

| Mnemonic              | Instruction                       | Base instruction(s)                            |
|-----------------------|-----------------------------------|------------------------------------------------|
| LI rd, imm12          | Load immediate (near)             | ADDI rd, zero, imm12                           |
| LI rd, imm            | Load immediate (far)              | LUI rd, imm[31:12]<br>ADDI rd, rd, imm[11:0]   |
| LA rd, sym            | Load address (far)                | AUIPC rd, sym[31:12]<br>ADDI rd, rd, sym[11:0] |
| MV rd, rs             | Copy register                     | ADDI rd, rs, 0                                 |
| NOT rd, rs            | One's complement                  | XORI rd, rs, -1                                |
| NEG rd, rs            | Two's complement                  | SUB rd, zero, rs                               |
| BGT rs1, rs2, offset  | Branch if rs1 > rs2               | BLT rs2, rs1, offset                           |
| BLE rs1, rs2, offset  | Branch if rs1 ≤ rs2               | BGE rs2, rs1, offset                           |
| BGTU rs1, rs2, offset | Branch if rs1 > rs2<br>(unsigned) | BLTU rs2, rs1, offset                          |
| BLEU rs1, rs2, offset | Branch if rs1 ≤ rs2<br>(unsigned) | BGEU rs2, rs1, offset                          |

|                  |                        |                                                      |
|------------------|------------------------|------------------------------------------------------|
| BEQZ rs1, offset | Branch if rs1 = 0      | BEQ rs1, zero, offset                                |
| BNEZ rs1, offset | Branch if rs1 ≠ 0      | BNE rs1, zero, offset                                |
| BGEZ rs1, offset | Branch if rs1 ≥ 0      | BGE rs1, zero, offset                                |
| BLEZ rs1, offset | Branch if rs1 ≤ 0      | BGE zero, rs1, offset                                |
| BGTZ rs1, offset | Branch if rs1 > 0      | BLT zero, rs1, offset                                |
| J offset         | Unconditional jump     | JAL zero, offset                                     |
| CALL offset12    | Call subroutine (near) | JALR ra, ra, offset12                                |
| CALL offset      | Call subroutine (far)  | AUIPC ra, offset[31:12]<br>JALR ra, ra, offset[11:0] |
| RET              | Return from subroutine | JALR zero, 0(ra)                                     |
| NOP              | No operation           | ADDI zero, zero, 0                                   |

# RISC-V reference card (I)

## Free & Open RISC-V Reference Card ①

| Base Integer Instructions: RV32I, RV64I, and RV128I |                        |     |                   |                        | RV Privileged Instructions                                     |                               |                     |
|-----------------------------------------------------|------------------------|-----|-------------------|------------------------|----------------------------------------------------------------|-------------------------------|---------------------|
| Category                                            | Name                   | Fmt | RV32I Base        | +RV{64,128}            | Category                                                       | Name                          | RV mnemonic         |
| <b>Loads</b>                                        | Load Byte              | I   | LB rd,rs1,imm     |                        | <b>CSR Access</b>                                              | Atomic R/W                    | CSRRW rd,csr,rs1    |
|                                                     | Load Halfword          | I   | LH rd,rs1,imm     |                        |                                                                | Atomic Read & Set Bit         | CSRRS rd,csr,rs1    |
|                                                     | Load Word              | I   | LW rd,rs1,imm     | L{D Q} rd,rs1,imm      |                                                                | Atomic Read & Clear Bit       | CSRRC rd,csr,rs1    |
|                                                     | Load Byte Unsigned     | I   | LBU rd,rs1,imm    |                        |                                                                | Atomic R/W Imm                | CSRRWI rd,csr,imm   |
|                                                     | Load Half Unsigned     | I   | LHU rd,rs1,imm    | L{W D}U rd,rs1,imm     |                                                                | Atomic Read & Set Bit Imm     | CSRRSI rd,csr,imm   |
| <b>Stores</b>                                       | Store Byte             | S   | SB rs1,rs2,imm    |                        | <b>Change Level</b>                                            | Env. Call                     | CSRRCI rd,csr,imm   |
|                                                     | Store Halfword         | S   | SH rs1,rs2,imm    |                        |                                                                | Environment Breakpoint        | EBREAK              |
|                                                     | Store Word             | S   | SW rs1,rs2,imm    | S{D Q} rs1,rs2,imm     |                                                                | Environment Return            | ERET                |
| <b>Shifts</b>                                       | Shift Left             | R   | SLL rd,rs1,rs2    | SLL{W D} rd,rs1,rs2    | <b>Trap Redirect</b>                                           | to Supervisor                 | MRTS                |
|                                                     | Shift Left Immediate   | I   | SLLI rd,rs1,shamt | SLLI{W D} rd,rs1,shamt |                                                                | Redirect Trap to Hypervisor   | MRTH                |
|                                                     | Shift Right            | R   | SRL rd,rs1,rs2    | SRL{W D} rd,rs1,rs2    |                                                                | Hypervisor Trap to Supervisor | HRTS                |
|                                                     | Shift Right Immediate  | I   | SRLI rd,rs1,shamt | SRLI{W D} rd,rs1,shamt |                                                                |                               |                     |
|                                                     | Shift Right Arithmetic | R   | SRA rd,rs1,rs2    | SRA{W D} rd,rs1,rs2    | <b>Interrupt</b>                                               | Wait for Interrupt            | WFI                 |
|                                                     | Shift Right Arith Imm  | I   | SRAI rd,rs1,shamt | SRAI{W D} rd,rs1,shamt | <b>MMU</b>                                                     | Supervisor FENCE              | SFENCE.VM rs1       |
| <b>Arithmetic</b>                                   | ADD                    | R   | ADD rd,rs1,rs2    | ADD{W D} rd,rs1,rs2    |                                                                |                               |                     |
|                                                     | ADD Immediate          | I   | ADDI rd,rs1,imm   | ADDI{W D} rd,rs1,imm   |                                                                |                               |                     |
|                                                     | SUBtract               | R   | SUB rd,rs1,rs2    | SUB{W D} rd,rs1,rs2    |                                                                |                               |                     |
|                                                     | Load Upper Imm         | U   | LUI rd,imm        |                        | <b>Optional Compressed (16-bit) Instruction Extension: RVC</b> |                               |                     |
|                                                     | Add Upper Imm to PC    | U   | AUIPC rd,imm      |                        |                                                                |                               |                     |
|                                                     |                        |     |                   |                        | <b>Category</b>                                                | <b>Name</b>                   | <b>Fmt</b>          |
| <b>Logical</b>                                      | XOR                    | R   | XOR rd,rs1,rs2    | <b>Loads</b>           | C.LW                                                           | rd',rs1',imm                  | LW rd',rs1',imm*4   |
|                                                     | XOR Immediate          | I   | XORI rd,rs1,imm   | Load Word SP           | CI                                                             | rd,imm                        | LW rd,sp,imm*4      |
|                                                     | OR                     | R   | OR rd,rs1,rs2     | Load Double            | CL                                                             | rd',rs1',imm                  | LD rd',rs1',imm*8   |
|                                                     | OR Immediate           | I   | ORI rd,rs1,imm    | Load Double SP         | CI                                                             | rd,imm                        | LD rd,sp,imm*8      |
|                                                     | AND                    | R   | AND rd,rs1,rs2    | Load Quad              | CL                                                             | rd',rs1',imm                  | LQ rd',rs1',imm*16  |
|                                                     | AND Immediate          | I   | ANDI rd,rs1,imm   | Load Quad SP           | CI                                                             | rd,imm                        | LQ rd,sp,imm*16     |
|                                                     |                        |     |                   |                        |                                                                |                               |                     |
| <b>Compare</b>                                      | Set <                  | R   | SLT rd,rs1,rs2    | <b>Stores</b>          | C.SW                                                           | rs1',rs2',imm                 | SW rs1',rs2',imm*4  |
|                                                     | Set < Immediate        | I   | SLTI rd,rs1,imm   | Store Word SP          | CSS                                                            | rs2,imm                       | SW rs2,sp,imm*4     |
|                                                     | Set < Unsigned         | R   | SLTU rd,rs1,rs2   | Store Double           | CS                                                             | rs1',rs2',imm                 | SD rs1',rs2',imm*8  |
|                                                     | Set < Imm Unsigned     | I   | SLTIU rd,rs1,imm  | Store Double SP        | CSS                                                            | rs2,imm                       | SD rs2,sp,imm*8     |
| <b>Branches</b>                                     | Branch =               | SB  | BEQ rs1,rs2,imm   | Store Quad             | CS                                                             | rs1',rs2',imm                 | SQ rs1',rs2',imm*16 |
|                                                     | Branch ≠               | SB  | BNE rs1,rs2,imm   | Store Quad SP          | CSS                                                            | rs2,imm                       | SQ rs2,sp,imm*16    |
|                                                     | Branch <               | SB  | BLT rs1,rs2,imm   | <b>Arithmetic</b>      | CR                                                             | rd,rs1                        | ADD rd,rd,rs1       |

# RISC-V reference card (II)

|                        |                       |           |                      |  |                        |                        |                         |                     |
|------------------------|-----------------------|-----------|----------------------|--|------------------------|------------------------|-------------------------|---------------------|
| <b>Branches</b>        | Branch =              | <b>SB</b> | BEQ      rs1,rs2,imm |  | Store Quad             | <b>CS</b>              | C.SQ      rs1',rs2',imm | SQ rs1',rs2',imm*16 |
|                        | Branch ≠              | <b>SB</b> | BNE      rs1,rs2,imm |  | Store Quad SP          | <b>CSS</b>             | C.SQSP      rs2,imm     | SQ rs2,sp,imm*16    |
|                        | Branch <              | <b>SB</b> | BLT      rs1,rs2,imm |  |                        |                        |                         |                     |
|                        | Branch ≥              | <b>SB</b> | BGE      rs1,rs2,imm |  | <b>Arithmetic</b>      | <b>ADD</b>             | C.ADD      rd,rs1       | ADD rd,rd,rs1       |
| Branch < Unsigned      |                       | <b>SB</b> | BLTU     rs1,rs2,imm |  |                        | <b>ADD Word</b>        | C.ADDW     rd,rs1       | ADDW rd,rd,imm      |
| Branch ≥ Unsigned      |                       | <b>SB</b> | BGEU     rs1,rs2,imm |  |                        | <b>ADD Immediate</b>   | C.IADDI     rd,imm      | ADDI rd,rd,imm      |
|                        |                       |           |                      |  |                        | <b>ADD Word Imm</b>    | C.IADDIW    rd,imm      | ADDIW rd,rd,imm     |
|                        |                       |           |                      |  |                        | <b>ADD SP Imm * 16</b> | C.IADDI16SP x0,imm      | ADDI sp,sp,imm*16   |
|                        |                       |           |                      |  |                        | <b>ADD SP Imm * 4</b>  | C.IADDI4SPN rd',imm     | ADDI rd',sp,imm*4   |
| <b>Jump &amp; Link</b> | J&L                   | <b>UJ</b> | JAL      rd,imm      |  |                        | <b>Load Immediate</b>  | C.ICLI      rd,imm      | ADDI rd,x0,imm      |
|                        | Jump & Link Register  | <b>UJ</b> | JALR     rd,rs1,imm  |  |                        | <b>Load Upper Imm</b>  | C.ICLUI     rd,imm      | LUI rd,imm          |
| <b>Synch</b>           | Synch thread          | <b>I</b>  | FENCE                |  |                        | <b>MoVe</b>            | C.RMV      rd,rs1       | ADD rd,rs1,x0       |
|                        | Synch Instr & Data    | <b>I</b>  | FENCE.I              |  |                        | <b>SUB</b>             | C.RSUB     rd,rs1       | SUB rd,rd,rs1       |
| <b>System</b>          | System CALL           | <b>I</b>  | SCALL                |  | <b>Shifts</b>          | <b>Shift Left Imm</b>  | C.ISLLI     rd,imm      | SLLI rd,rd,imm      |
|                        | System BREAK          | <b>I</b>  | SBREAK               |  | <b>Branches</b>        | Branch=0               | C.BEQZ     rs1',imm     | BEQ rs1',x0,imm     |
| <b>Counters</b>        | ReaD CYCLE            | <b>I</b>  | RDCYCLE    rd        |  |                        | Branch≠0               | C.BNEZ     rs1',imm     | BNE rs1',x0,imm     |
|                        | ReaD CYCLE upper Half | <b>I</b>  | RDCYCLES   rd        |  | <b>Jump</b>            | Jump                   | C.J      imm            | JAL x0,imm          |
|                        | ReaD TIME             | <b>I</b>  | RDTIME     rd        |  |                        | Jump Register          | C.JR      rd,rs1        | JALR x0,rs1,0       |
|                        | Read TIME upper Half  | <b>I</b>  | RDTIMEH    rd        |  | <b>Jump &amp; Link</b> | J&L                    | C.JAL      imm          | JAL ra,imm          |
|                        | ReaD INSTR RETired    | <b>I</b>  | RDINSTRRET rd        |  |                        | Jump & Link Register   | C.JALR     rs1          | JALR ra,rs1,0       |
|                        | ReaD INSTR upper Half | <b>I</b>  | RDINSTRETH rd        |  | <b>System</b>          | Env. BREAK             | C.IEBREAK               | EBREAK              |

32-bit Instruction Formats

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

|            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>CR</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>CI</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>CSS</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>CIW</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>CL</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>CS</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>CB</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>CJ</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

|        |             |        |        |    |
|--------|-------------|--------|--------|----|
| funct4 | rd/rs1      | rs2    | op     |    |
| funct3 | imm         | rd/rs1 | op     |    |
| funct3 | imm         | rs2    | op     |    |
| funct3 | imm         | rd'    | op     |    |
| funct3 | imm         | rs1'   | rd'    | op |
| funct3 | imm         | imm    | rs2'   | op |
| funct3 | offset      | rs1'   | offset | op |
| funct3 | jump target |        |        | op |

RISC-V Integer Base (RV32I/64I/128I), privileged, and optional compressed extension (RVC). Registers x1-x31 and the pc are 32 bits wide in RV32I, 64 in RV64I, and 128 in RV128I (x0=0). RV64I/128I add 10 instructions for the wider formats. The RVI base of <50 classic integer RISC instructions is required. Every 16-bit RVC instruction matches an existing 32-bit RVI instruction. See risc.org.

# RISC-V reference card (III)

|                            |       |   |                 |                |                                  |          |        |                                  |
|----------------------------|-------|---|-----------------|----------------|----------------------------------|----------|--------|----------------------------------|
| <b>Load</b>                | Load  | I | FL{W,D,Q}       | rd,rs1,imm     | <b>RISC-V Calling Convention</b> |          |        |                                  |
| <b>Store</b>               | Store | S | FS{W,D,Q}       | rs1,rs2,imm    | Register                         | ABI Name | Saver  | Description                      |
| <b>Arithmetic</b>          |       | R | FADD.{S D Q}    | rd,rs1,rs2     | x0                               | zero     | ---    | Hard-wired zero                  |
| ADD                        |       | R | FSUB.{S D Q}    | rd,rs1,rs2     | x1                               | ra       | Caller | Return address                   |
| SUBtract                   |       | R | FMUL.{S D Q}    | rd,rs1,rs2     | x2                               | sp       | Callee | Stack pointer                    |
| MULTiply                   |       | R | FDIV.{S D Q}    | rd,rs1,rs2     | x3                               | gp       | ---    | Global pointer                   |
| DIVide                     |       | R | FSQRT.{S D Q}   | rd,rs1         | x4                               | tp       | ---    | Thread pointer                   |
| SQuare Root                |       | R | FMADD.{S D Q}   | rd,rs1,rs2,rs3 | x5-7                             | t0-2     | Caller | Temporaries                      |
| <b>Mul-Add</b>             |       | R | FMSUB.{S D Q}   | rd,rs1,rs2,rs3 | x8                               | s0/fp    | Callee | Saved register/frame pointer     |
| Multiply-SUBtract          |       | R | FNMSUB.{S D Q}  | rd,rs1,rs2,rs3 | x9                               | s1       | Callee | Saved register                   |
| Negative Multiply-SUBtract |       | R | FNMADD.{S D Q}  | rd,rs1,rs2,rs3 | x10-11                           | a0-1     | Caller | Function arguments/return values |
| Negative Multiply-ADD      |       | R | FMIN.{S D Q}    | rd,rs1,rs2     | x12-17                           | a2-7     | Caller | Function arguments               |
| <b>Sign Inject</b>         |       | R | FSGNJ.{S D Q}   | rd,rs1,rs2     | x18-27                           | s2-11    | Callee | Saved registers                  |
| SiGN source                |       | R | FSGNJS.{S D Q}  | rd,rs1,rs2     | x28-31                           | t3-t6    | Caller | Temporaries                      |
| Negative SiGN source       |       | R | FSGNJSX.{S D Q} | rd,rs1,rs2     | f0-7                             | ft0-7    | Caller | FP temporaries                   |
| Xor SiGN source            |       | R | FMAX.{S D Q}    | rd,rs1,rs2     | f8-9                             | fs0-1    | Callee | FP saved registers               |
| <b>Min/Max</b>             |       | R | FEQ.{S D Q}     | rd,rs1,rs2     | f10-11                           | fa0-1    | Caller | FP arguments/return values       |
| MINimum                    |       | R | FLT.{S D Q}     | rd,rs1,rs2     | f12-17                           | fa2-7    | Caller | FP arguments                     |
| MAXimum                    |       | R | FLE.{S D Q}     | rd,rs1,rs2     | f18-27                           | fs2-11   | Callee | FP saved registers               |
| <b>Compare</b>             |       | R | FCLASS.{S D Q}  | rd,rs1         | f28-31                           | ft8-11   | Caller | FP temporaries                   |
| Compare Float =            |       | R | FRCSR           | rd             |                                  |          |        |                                  |
| Compare Float <            |       | R | FRRM            | rd             |                                  |          |        |                                  |
| Compare Float ≤            |       | R | FRFLAGS         | rd             |                                  |          |        |                                  |
| <b>Categorization</b>      |       | R | FSCSR           | rd,rs1         |                                  |          |        |                                  |
| Classify Type              |       | R | FSRM            | rd,rs1         |                                  |          |        |                                  |
| <b>Configuration</b>       |       | R | FSFLAGS         | rd,rs1         |                                  |          |        |                                  |
| Read Status                |       | R | FSRMI           | rd,imm         |                                  |          |        |                                  |
| Read Rounding Mode         |       | R | FSFLAGSI        | rd,imm         |                                  |          |        |                                  |
| Read Flags                 |       |   |                 |                |                                  |          |        |                                  |
| Swap Status Reg            |       |   |                 |                |                                  |          |        |                                  |
| Swap Rounding Mode         |       |   |                 |                |                                  |          |        |                                  |
| Swap Flags                 |       |   |                 |                |                                  |          |        |                                  |
| Swap Rounding Mode Imm     |       |   |                 |                |                                  |          |        |                                  |
| Swap Flags Imm             |       |   |                 |                |                                  |          |        |                                  |

RISC-V calling convention and five optional extensions: 10 multiply-divide instructions (RV32M); 11 optional atomic instructions (RV32A); and 25 floating-point instructions each for single-, double-, and quadruple-precision (RV32F, RV32D, RV32Q). The latter add registers f0-f31, whose width matches the widest precision, and a floating-point control and status register fcsr. Each larger address adds some instructions: 4 for RVM, 11 for RVA, and 6 each for RVF/D/Q. Using regex notation, { } means set, so L{D|Q} is both LD and LQ. See risc.org. (8/21/15 revision)

# RISC-V reference card (IV)

## Free & Open RISC-V Reference Card ([riscv.org](http://riscv.org)) ②

| <b>Optional Multiply-Divide Instruction Extension: RVM</b>                       |                           |            |                                        |                              |
|----------------------------------------------------------------------------------|---------------------------|------------|----------------------------------------|------------------------------|
| <b>Category</b>                                                                  | <b>Name</b>               | <b>Fmt</b> | <b>RV32M (Multiply-Divide)</b>         | <b>+RV{64,128}</b>           |
| <b>Multiply</b>                                                                  | MULtify                   | R          | MUL rd,rs1,rs2                         | MUL{W D} rd,rs1,rs2          |
|                                                                                  | MULtify upper Half        | R          | MULH rd,rs1,rs2                        |                              |
|                                                                                  | MULTiply Half Sign/Uns    | R          | MULHSU rd,rs1,rs2                      |                              |
|                                                                                  | MULtiply upper Half Uns   | R          | MULHU rd,rs1,rs2                       |                              |
| <b>Divide</b>                                                                    | DIVide                    | R          | DIV rd,rs1,rs2                         | DIV{W D} rd,rs1,rs2          |
|                                                                                  | DIVide Unsigned           | R          | DIVU rd,rs1,rs2                        |                              |
| <b>Remainder</b>                                                                 | REMAinder                 | R          | REM rd,rs1,rs2                         | REM{W D} rd,rs1,rs2          |
|                                                                                  | REMAinder Unsigned        | R          | REMU rd,rs1,rs2                        | REMU{W D} rd,rs1,rs2         |
| <b>Optional Atomic Instruction Extension: RVA</b>                                |                           |            |                                        |                              |
| <b>Category</b>                                                                  | <b>Name</b>               | <b>Fmt</b> | <b>RV32A (Atomic)</b>                  | <b>+RV{64,128}</b>           |
| <b>Load</b>                                                                      | Load Reserved             | R          | LR.W rd,rs1                            | LR.{D Q} rd,rs1              |
| <b>Store</b>                                                                     | Store Conditional         | R          | SC.W rd,rs1,rs2                        | SC.{D Q} rd,rs1,rs2          |
| <b>Swap</b>                                                                      | SWAP                      | R          | AMOSWAP.W rd,rs1,rs2                   | AMOSWAP.{D Q} rd,rs1,rs2     |
| <b>Add</b>                                                                       | ADD                       | R          | AMOADD.W rd,rs1,rs2                    | AMOADD.{D Q} rd,rs1,rs2      |
| <b>Logical</b>                                                                   | XOR                       | R          | AMOXOR.W rd,rs1,rs2                    | AMOXOR.{D Q} rd,rs1,rs2      |
|                                                                                  | AND                       | R          | AMOAND.W rd,rs1,rs2                    | AMOAND.{D Q} rd,rs1,rs2      |
|                                                                                  | OR                        | R          | AMOOR.W rd,rs1,rs2                     | AMOOR.{D Q} rd,rs1,rs2       |
| <b>Min/Max</b>                                                                   | MINimum                   | R          | AMOMIN.W rd,rs1,rs2                    | AMOMIN.{D Q} rd,rs1,rs2      |
|                                                                                  | MAXimum                   | R          | AMOMAX.W rd,rs1,rs2                    | AMOMAX.{D Q} rd,rs1,rs2      |
|                                                                                  | MINimum Unsigned          | R          | AMOMINU.W rd,rs1,rs2                   | AMOMINU.{D Q} rd,rs1,rs2     |
|                                                                                  | MAXimum Unsigned          | R          | AMOMAXU.W rd,rs1,rs2                   | AMOMAXU.{D Q} rd,rs1,rs2     |
| <b>Three Optional Floating-Point Instruction Extensions: RVF, RVD, &amp; RVQ</b> |                           |            |                                        |                              |
| <b>Category</b>                                                                  | <b>Name</b>               | <b>Fmt</b> | <b>RV32{F D Q} (HP/SP,DP,QP Fl Pt)</b> | <b>+RV{64,128}</b>           |
| <b>Move</b>                                                                      | Move from Integer         | R          | FMV.{H S}.X rd,rs1                     | FMV.{D Q}.X rd,rs1           |
|                                                                                  | Move to Integer           | R          | FMV.X.{H S} rd,rs1                     | FMV.X.{D Q} rd,rs1           |
| <b>Convert</b>                                                                   | Convert from Int          | R          | FCVT.{H S D Q}.W rd,rs1                | FCVT.{H S D Q}.{L T} rd,rs1  |
|                                                                                  | Convert from Int Unsigned | R          | FCVT.{H S D Q}.WU rd,rs1               | FCVT.{H S D Q}.{L T}U rd,rs1 |
|                                                                                  | Convert to Int            | R          | FCVT.W.{H S D Q} rd,rs1                | FCVT.{L T}.{H S D Q} rd,rs1  |
|                                                                                  | Convert to Int Unsigned   | R          | FCVT.WU.{H S D Q} rd,rs1               | FCVT.{L T}U.{H S D Q} rd,rs1 |

# Assembler pseudo-instructions

| Pseudoinstruction            | Base Instruction(s)                                                            | Meaning                           |
|------------------------------|--------------------------------------------------------------------------------|-----------------------------------|
| <code>nop</code>             | <code>addi x0, x0, 0</code>                                                    | No operation                      |
| <code>neg rd, rs</code>      | <code>sub rd, x0, rs</code>                                                    | Two's complement                  |
| <code>negw rd, rs</code>     | <code>subw rd, x0, rs</code>                                                   | Two's complement word             |
| <code>snez rd, rs</code>     | <code>sltu rd, x0, rs</code>                                                   | Set if $\neq$ zero                |
| <code>sltz rd, rs</code>     | <code>slt rd, rs, x0</code>                                                    | Set if $<$ zero                   |
| <code>sgtz rd, rs</code>     | <code>slt rd, x0, rs</code>                                                    | Set if $>$ zero                   |
| <code>beqz rs, offset</code> | <code>beq rs, x0, offset</code>                                                | Branch if = zero                  |
| <code>bnez rs, offset</code> | <code>bne rs, x0, offset</code>                                                | Branch if $\neq$ zero             |
| <code>blez rs, offset</code> | <code>bge x0, rs, offset</code>                                                | Branch if $\leq$ zero             |
| <code>bgez rs, offset</code> | <code>bge rs, x0, offset</code>                                                | Branch if $\geq$ zero             |
| <code>bltz rs, offset</code> | <code>blt rs, x0, offset</code>                                                | Branch if < zero                  |
| <code>bgtz rs, offset</code> | <code>blt x0, rs, offset</code>                                                | Branch if > zero                  |
| <code>j offset</code>        | <code>jal x0, offset</code>                                                    | Jump                              |
| <code>jr rs</code>           | <code>jalr x0, rs, 0</code>                                                    | Jump register                     |
| <code>ret</code>             | <code>jalr x0, x1, 0</code>                                                    | Return from subroutine            |
| <code>tail offset</code>     | <code>auipc x6, offset[31:12]</code><br><code>jalr x0, x6, offset[11:0]</code> | Tail call far-away subroutine     |
| <code>rdinstret[h] rd</code> | <code>csrrs rd, instret[h], x0</code>                                          | Read instructions-retired counter |
| <code>rdcycle[h] rd</code>   | <code>csrrs rd, cycle[h], x0</code>                                            | Read cycle counter                |
| <code>rdtime[h] rd</code>    | <code>csrrs rd, time[h], x0</code>                                             | Read real-time clock              |
| <code>csrr rd, csr</code>    | <code>csrrs rd, csr, x0</code>                                                 | Read CSR                          |
| <code>csrw csr, rs</code>    | <code>csrrw x0, csr, rs</code>                                                 | Write CSR                         |
| <code>csrs csr, rs</code>    | <code>csrrs x0, csr, rs</code>                                                 | Set bits in CSR                   |
| <code>csrc csr, rs</code>    | <code>csrrc x0, csr, rs</code>                                                 | Clear bits in CSR                 |
| <code>csrwi csr, imm</code>  | <code>csrrwi x0, csr, imm</code>                                               | Write CSR, immediate              |
| <code>csrsi csr, imm</code>  | <code>csrrsi x0, csr, imm</code>                                               | Set bits in CSR, immediate        |
| <code>csrci csr, imm</code>  | <code>csrrci x0, csr, imm</code>                                               | Clear bits in CSR, immediate      |
| <code>frcsr rd</code>        | <code>csrrs rd, fcsr, x0</code>                                                | Read FP control/status register   |
| <code>fscsr rs</code>        | <code>csrrw x0, fcsr, rs</code>                                                | Write FP control/status register  |
| <code>frrm rd</code>         | <code>csrrs rd, frm, x0</code>                                                 | Read FP rounding mode             |
| <code>fsrm rs</code>         | <code>csrrw x0, frm, rs</code>                                                 | Write FP rounding mode            |
| <code>frflags rd</code>      | <code>csrrs rd, fflags, x0</code>                                              | Read FP exception flags           |
| <code>fsflags rs</code>      | <code>csrrw x0, fflags, rs</code>                                              | Write FP exception flags          |

| Pseudoinstruction                      | Base Instruction(s)                                                                                                                         | Meaning                         |
|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| <code>lla rd, symbol</code>            | <code>auipc rd, symbol[31:12]</code><br><code>addi rd, rd, symbol[11:0]</code>                                                              | Load local address              |
| <code>la rd, symbol</code>             | <i>PIC:</i> <code>auipc rd, GOT[symbol][31:12]</code><br><code>1{w d} rd, rd, GOT[symbol][11:0]</code>                                      | Load address                    |
| <code>1{b h w d} rd, symbol</code>     | <i>Non-PIC:</i> Same as <code>lla rd, symbol</code><br><code>auipc rd, symbol[31:12]</code><br><code>1{b h w d} rd, symbol[11:0](rd)</code> | Load global                     |
| <code>s{b h w d} rd, symbol, rt</code> | <code>auipc rt, symbol[31:12]</code><br><code>s{b h w d} rd, symbol[11:0](rt)</code>                                                        | Store global                    |
| <code>f1{w d} rd, symbol, rt</code>    | <code>auipc rt, symbol[31:12]</code><br><code>f1{w d} rd, symbol[11:0](rt)</code>                                                           | Floating-point load global      |
| <code>fs{w d} rd, symbol, rt</code>    | <code>auipc rt, symbol[31:12]</code><br><code>fs{w d} rd, symbol[11:0](rt)</code>                                                           | Floating-point store global     |
| <code>li rd, immediate</code>          | <i>Myriad sequences</i><br><code>addi rd, rs, 0</code>                                                                                      | Load immediate                  |
| <code>mv rd, rs</code>                 | <code>xori rd, rs, -1</code>                                                                                                                | Copy register                   |
| <code>not rd, rs</code>                | <code>addiw rd, rs, 0</code>                                                                                                                | One's complement                |
| <code>sext.w rd, rs</code>             | <code>sltiu rd, rs, 1</code>                                                                                                                | Sign extend word                |
| <code>seqz rd, rs</code>               |                                                                                                                                             | Set if = zero                   |
| <code>fmv.s rd, rs</code>              | <code>fsgnj.s rd, rs, rs</code>                                                                                                             | Copy single-precision register  |
| <code>fabs.s rd, rs</code>             | <code>fsgnjx.s rd, rs, rs</code>                                                                                                            | Single-precision absolute value |
| <code>fneg.s rd, rs</code>             | <code>fsgnjn.s rd, rs, rs</code>                                                                                                            | Single-precision negate         |
| <code>fmv.d rd, rs</code>              | <code>fsgnj.d rd, rs, rs</code>                                                                                                             | Copy double-precision register  |
| <code>fabs.d rd, rs</code>             | <code>fsgnjx.d rd, rs, rs</code>                                                                                                            | Double-precision absolute value |
| <code>fneg.d rd, rs</code>             | <code>fsgnjn.d rd, rs, rs</code>                                                                                                            | Double-precision negate         |
| <code>bgt rs, rt, offset</code>        | <code>blt rt, rs, offset</code>                                                                                                             | Branch if >                     |
| <code>ble rs, rt, offset</code>        | <code>bge rt, rs, offset</code>                                                                                                             | Branch if $\leq$                |
| <code>bgtu rs, rt, offset</code>       | <code>bltu rt, rs, offset</code>                                                                                                            | Branch if >, unsigned           |
| <code>bleu rs, rt, offset</code>       | <code>bgeu rt, rs, offset</code>                                                                                                            | Branch if $\leq$ , unsigned     |
| <code>jal offset</code>                | <code>jal x1, offset</code>                                                                                                                 | Jump and link                   |
| <code>jalr rs</code>                   | <code>jalr x1, rs, 0</code>                                                                                                                 | Jump and link register          |
| <code>call offset</code>               | <code>auipc x1, offset[31:12]</code><br><code>jalr x1, x1, offset[11:0]</code>                                                              | Call far-away subroutine        |
| <code>fence</code>                     | <code>fence iorw, iorw</code>                                                                                                               | Fence on all memory and I/O     |
| <code>fscsr rd, rs</code>              | <code>csrrw rd, fcsr, rs</code>                                                                                                             | Swap FP control/status register |
| <code>fsrm rd, rs</code>               | <code>csrrw rd, frm, rs</code>                                                                                                              | Swap FP rounding mode           |
| <code>fsflags rd, rs</code>            | <code>csrrw rd, fflags, rs</code>                                                                                                           | Swap FP exception flags         |

# Assembler directives

| Directive          | Description                                                                                                     |
|--------------------|-----------------------------------------------------------------------------------------------------------------|
| .text              | Subsequent items are stored in the text section (machine code).                                                 |
| .data              | Subsequent items are stored in the data section (global variables).                                             |
| .bss               | Subsequent items are stored in the bss section (global variables initialized to 0).                             |
| .section .foo      | Subsequent items are stored in the section named .foo.                                                          |
| .align n           | Align the next datum on a $2^n$ -byte boundary. For example, .align 2 aligns the next value on a word boundary. |
| .balign n          | Align the next datum on a $n$ -byte boundary. For example, .balign 4 aligns the next value on a word boundary.  |
| .globl sym         | Declare that label sym is global and may be referenced from other files.                                        |
| .string "str"      | Store the string str in memory and null-terminate it.                                                           |
| .byte b1,..., bn   | Store the n 8-bit quantities in successive bytes of memory.                                                     |
| .half w1,...,wn    | Store the n 16-bit quantities in successive memory halfwords.                                                   |
| .word w1,...,wn    | Store the n 32-bit quantities in successive memory words.                                                       |
| .dword w1,...,wn   | Store the n 64-bit quantities in successive memory doublewords.                                                 |
| .float f1,..., fn  | Store the n single-precision floating-point numbers in successive memory words.                                 |
| .double d1,..., dn | Store the n double-precision floating-point numbers in successive memory doublewords.                           |
| .option rvc        | Compress subsequent instructions (see Chapter 7).                                                               |
| .option norvc      | Don't compress subsequent instructions.                                                                         |
| .option relax      | Allow linker relaxations for subsequent instructions.                                                           |
| .option norelax    | Don't allow linker relaxations for subsequent instructions.                                                     |
| .option pic        | Subsequent instructions are position-independent code.                                                          |
| .option nopic      | Subsequent instructions are position-dependent code.                                                            |
| .option push       | Push the current setting of all .options to a stack, so that a subsequent .option pop will restore their value. |
| .option pop        | Pop the option stack, restoring all .options to their setting at the time of the last .option push.             |