#### **Basic instructions**

```
0000000SSSSSSSSSSS000ddddd0110011
ADD
ADDI iiiiiiiiiiiiisssss000ddddd0010011
     0000000SSSSSSSSSSSS111dddddd0110011
ΔND
ANDI iiiiiiiiiiiiisssss111ddddd0010011
AUIPC iiiiiiiiiiiiiiiiiiiiiiddddd0010111
     iiiiiiiiSSSSsssss000iiiiii1100011
     iiiiiiiiSSSSsssss001iiiiii1100011
BNF
     iiiiiiiiiiiiiiiiiiiiiiiiiiiddddd1101111
IΔΓ
JALR iiiiiiiiiiiiisssss000ddddd1100111
LB
     iiiiiiiiiiisssss000ddddd0000011
LUI
     iiiiiiiiiiiiiiiiiiiiiiiiiiiddddd0110111
     iiiiiiiiiiisssss010ddddd0000011
LW
     0000000SSSSSSSSSSS110ddddd0110011
OR
ORI iiiiiiiiiiiiisssss110ddddd0010011
     SLLI 0000000iiiiisssss001ddddd0010011
SRLI 0000000iiiiisssss101ddddd0010011
     iiiiiiiiSSSSsssss010iiiii0100011
SW
     0000000SSSSSSSSSSS100ddddd0110011
XOR
```

#### +3

```
ANDN 0100000SSSSSSSSSSS111ddddd0110011
MINU 0000101SSSSSSSSSSS110ddddd0110011
XNOR 0100000SSSSSSSSSSSS00ddddd0110011
```

#### Interrupt and exception

```
CSRRC ccccccccsssss011ddddd1110011
CSRRS cccccccccsssss010ddddd1110011
CSRRW cccccccccsssss001ddddd1110011
EBREAK 0000000000100000000001110011
ECALL 000000000000000000001110011
MRET 001100000100000000001110011
SLTU 0000000SSSSSSSSSSS011dddddd0110011
```

### **Supplementary**

```
BLT iiiiiiiSSSSSsssss100iiiii1100011
```

#### Control/status registers(all 32bits)

| 名称       | 编号    | 描述                                     | 字段1           | 字段<br>1描<br>述                        | 字段2                     | 字段3                                     |
|----------|-------|----------------------------------------|---------------|--------------------------------------|-------------------------|-----------------------------------------|
| mtvec    | 0x305 | 保存发<br>生异常<br>时处理<br>器需要<br>跳转到<br>的地址 | BASE[31:2]    |                                      | MODE[1:0]               | 00则pc<-<br>BASE,01则pc<-<br>BASE+4*cause |
| mscratch | 0x340 | 暂时存<br>放一个<br>字大小<br>的数据               |               |                                      |                         |                                         |
| mepc     | 0x341 | 指向发<br>生异常<br>的指令                      |               |                                      |                         |                                         |
| mcause   | 0x342 | 指示发<br>生异常<br>的种类                      | Interrupt[31] | 0为<br>异<br>常,<br>1为<br>中断            | Exception<br>Code[30:0] | 见下面两表                                   |
| mstatus  | 0x300 | 保存全<br>局中断<br>使能,<br>以及许<br>多其他<br>的状态 | MPP[12:11]    | 当前<br>权模式。<br>00为U,01<br>为S,11<br>为M |                         |                                         |
| mie      | 0x304 | 指出处<br>理器目<br>前能处<br>理和必<br>须忽略<br>的中断 | MTIE[7]       |                                      |                         |                                         |
| mip      | 0x344 | 列出目<br>前正准<br>备处理<br>的中断               | MTIP[7]       | 只读                                   |                         |                                         |

| 名称    | 编号    | 描述                              | 字段1 | 字段<br>1描<br>述 | 字段2 | 字段3 |
|-------|-------|---------------------------------|-----|---------------|-----|-----|
| mtval | 0x343 | trap的<br>息: 中的地 法异的<br>中的地,指令的等 |     |               |     |     |

**Exception table** 

| Interrupt | Exception<br>Code | Description                       | 详细描述            |
|-----------|-------------------|-----------------------------------|-----------------|
| 1         | 0                 | Reserved                          |                 |
| 1         | 1                 | Supervisor software interrupt     |                 |
| 1         | 2                 | Reserved                          |                 |
| 1         | 3                 | Machine software interrupt        |                 |
| 1         | 4                 | Reserved                          |                 |
| 1         | 5                 | Supervisor timer interrupt        |                 |
| 1         | 6                 | Reserved                          |                 |
| 1         | 7                 | Machine timer interrupt           |                 |
| 1         | 8                 | Reserved                          |                 |
| 1         | 9                 | Supervisor external interrupt     |                 |
| 1         | 10                | Reserved                          |                 |
| 1         | 11                | Machine external interrupt        |                 |
| 1         | 12–15             | Reserved                          |                 |
| 1         | ≥16               | Designated for platform use       |                 |
| 0         | 0                 | Instruction address<br>misaligned | 真正跳转到的地址不是4字节对齐 |
| 0         | 1                 | Instruction access fault          | 读指令时出错          |
| 0         | 2                 | Illegal instruction               | 不合法的指令          |
| 0         | 3                 | Breakpoint                        | ebreak造成的断点     |
| 0         | 4                 | Load address misaligned           | 读内存时地址未对齐       |
| 0         | 5                 | Load access fault                 | 读内存时出错          |
| 0         | 6                 | Store/AMO address<br>misaligned   | 写内存时地址未对齐       |
| 0         | 7                 | Store/AMO access fault            | 写内存时出错          |
| 0         | 8                 | Environment call from U-<br>mode  | 用户模式下ecall      |
| 0         | 9                 | Environment call from S-<br>mode  | 监管者模式下ecall     |
| 0         | 10                | Reserved                          |                 |

| Interrupt | Exception<br>Code | Description                  | 详细描述       |
|-----------|-------------------|------------------------------|------------|
| 0         | 11                | Environment call from M-mode | 机器模式下ecall |
| 0         | 12                | Instruction page fault       | //TODO     |
| 0         | 13                | Load page fault              | //TODO     |
| 0         | 14                | Reserved                     |            |
| 0         | 15                | Store/AMO page fault         | //TODO     |
| 0         | 16-23             | Reserved                     |            |
| 0         | 24–31             | Designated for custom use    |            |
| 0         | 32-47             | Reserved                     |            |
| 0         | 48-63             | Designated for custom use    |            |
| 0         | ≥64               | Reserved                     |            |

## Priority for exceptions

| Priority                   | Exception Code | Description                       |
|----------------------------|----------------|-----------------------------------|
| Highest                    | 3              | Instruction address breakpoint    |
|                            | 12             | Instruction page fault            |
|                            | 1              | Instruction access fault          |
|                            | 2              | Illegal instruction               |
|                            | 0              | Instruction address misaligned    |
|                            | 8, 9, 11       | Environment call                  |
|                            | 3              | Environment break                 |
|                            | 3              | Load/Store/AMO address breakpoint |
| Optionally, these may have | 6              | Store/AMO address misaligned      |
| lowest priority instead.   | 4              | Load address misaligned           |
|                            | 15             | Store/AMO page fault              |
|                            | 13             | Load page fault                   |
|                            | 7              | Store/AMO access fault            |
|                            | 5              | Load access fault                 |

# **MMIO** registers

| 名称       | 地址        | 描述                |
|----------|-----------|-------------------|
| mtime    | 0x200bff8 | [63:0],表示当前时间     |
| mtimecmp | 0x2004000 | [63:0],表示下次时钟中断时间 |

# **Br\_comparator**

| 信号 | rdata1           | rdata2           | br_un         | br_eq                | br_lt                             |
|----|------------------|------------------|---------------|----------------------|-----------------------------------|
| 属性 | in<br>wire[31:0] | in<br>wire[31:0] | in wire       | out wire             | out wire                          |
| 描述 |                  |                  | 是否是无符号数<br>比较 | rdata1=rdata2<br>才为1 | rdata1 <rdata2<br>才为1</rdata2<br> |

## Decoder

sign\_ext = 20{inst[31]}

sign\_ext\_jal = 11{inst[31]}

unsign\_ext =  $27\{0\}$ 

| 信号     | inst             | csr_data         | br_eq              | br_lt                            | ext_op              | alu_op           | imm                                                           | b_select               | a_select              | reg_a            | reg_b            | reg_d            | pc_select                          | csr               | mem_wr      | mem_to_reg                                   | reg_wr      | csr_reg_wr     | exception                       | 备注                         |
|--------|------------------|------------------|--------------------|----------------------------------|---------------------|------------------|---------------------------------------------------------------|------------------------|-----------------------|------------------|------------------|------------------|------------------------------------|-------------------|-------------|----------------------------------------------|-------------|----------------|---------------------------------|----------------------------|
| 属性     | in<br>wire[31:0] | in<br>wire[31:0] | in<br>wire         | in<br>wire                       | out<br>wire[4:0]    | out<br>wire[3:0] | out wire(31:0)                                                | out wire               | out wire              | out<br>wire[4:0] | out<br>wire[4:0] | out<br>wire[4:0] | out wire                           | out<br>wire[11:0] | out wire    | out wire[1:0]                                | out<br>wire | out wire       | out<br>wire[3:0]                |                            |
| 描述     |                  |                  | a=b为<br>1.否则<br>为0 | a <b<br>为1,<br/>否则<br/>为0</b<br> | 执行阶段提作码             | alu提作<br>码       |                                                               | 选imm代<br>替reg_b<br>则为0 | 选pc代<br>替reg_a<br>则为1 |                  |                  |                  | pc<-pc+4<br>为0,<br>pc<-alu结<br>果为1 |                   | 读为0,<br>写为1 | 进内存为0.选<br>alu为1.选<br>(PC+4)为2,<br>选data_b为3 | 写为1         | 写为1,写<br>alu结果 | decode过<br>程中发生的<br>异常,振异<br>常号 |                            |
| add    |                  |                  |                    |                                  | OP_ADD              | ADD              | 1                                                             | 1                      | 0                     | inst[19:15]      | inst[24:20]      | inst[11:7]       | 0                                  |                   | 0           | 1                                            | 1           | 0              |                                 |                            |
| addi   |                  |                  |                    |                                  | OP_ADD              | ADD              | (sign_ext,inst(31:20])                                        | 0                      | 0                     | inst[19:15]      | 1                | inst[11:7]       | 0                                  |                   | 0           | 1                                            | 1           | 0              |                                 |                            |
| and    |                  |                  |                    |                                  | OP_AND              | AND              | 1                                                             | 1                      | 0                     | inst[19:15]      | inst[24:20]      | inst[11:7]       | 0                                  |                   | 0           | 1                                            | 1           | 0              |                                 |                            |
| andn   |                  |                  |                    |                                  | OP_AND              | ANDN             | 1                                                             | 1                      | 0                     | inst[19:15]      | inst[24:20]      | inst[11:7]       | 0                                  |                   | 0           | 1                                            | 1           | 0              |                                 |                            |
| andi   |                  |                  |                    |                                  | OP_AND              | AND              | {sign_ext,inst[31:20]}                                        | 0                      | 0                     | inst[19:15]      | 1                | inst[11:7]       | 0                                  |                   | 0           | 1                                            | 1           | 0              |                                 |                            |
| or     |                  |                  |                    |                                  | OP_OR               | OR               | 1                                                             | 1                      | 0                     | inst[19:15]      | inst[24:20]      | inst[11:7]       | 0                                  |                   | 0           | 1                                            | 1           | 0              |                                 |                            |
| ori    |                  |                  |                    |                                  | OP_OR               | OR               | {sign_ext,inst[31:20]}                                        | 0                      | 0                     | inst[19:15]      | 1                | inst[11:7]       | 0                                  |                   | 0           | 1                                            | 1           | 0              |                                 |                            |
| xor    |                  |                  |                    |                                  | OP_XOR              | XOR              | /                                                             | 1                      | 0                     | inst[19:15]      | inst[24:20]      | inst[11:7]       | 0                                  |                   | 0           | 1                                            | 1           | 0              |                                 |                            |
| ypor   |                  |                  |                    |                                  | OP_XOR              | XNOR             | /                                                             | 1                      | 0                     | inst[19:15]      | inst[24:20]      | inst[11:7]       | 0                                  |                   | 0           | 1                                            | 1           | 0              |                                 |                            |
| minu   |                  |                  |                    |                                  | OP_MIN              | MINU             | /                                                             | 1                      | 0                     | inst[19:15]      | inst[24:20]      | inst[11:7]       | 0                                  |                   | 0           | 1                                            | 1           | 0              |                                 |                            |
| sli    |                  |                  |                    |                                  | OP_SLL              | SLL              | {unsign_ext,inst(24:20)}                                      | 0                      | 0                     | inst[19:15]      | /                | inst[11:7]       | 0                                  |                   | 0           | 1                                            | 1           | 0              |                                 |                            |
| srli   |                  |                  |                    |                                  | OP_SRL              | SRL              | (unsign_ext,inst(24:20))                                      | 0                      | 0                     | inst[19:15]      | /                | inst[11:7]       | 0                                  |                   | 0           | 1                                            | 1           | 0              |                                 |                            |
| lui    |                  |                  |                    |                                  | OP_LUI              | ADD              | (inst[31:12],12'h000)                                         | 0                      | 0                     | 0                | 1                | inst[11:7]       | 0                                  |                   | 0           | 1                                            | 1           | 0              |                                 |                            |
| auipc  |                  |                  |                    |                                  | OP_AUIPC            | ADD              | (inst[31:12],12h000)                                          | 0                      | 1                     | 1                | 1                | inst[11:7]       | 0                                  |                   | 0           | 1                                            | 1           | 0              |                                 |                            |
| lb     |                  |                  |                    |                                  |                     | ADD              |                                                               | 0                      | 0                     |                  | /                | inst[11:7]       | 0                                  |                   | 0           | 0                                            | 1           | 0              |                                 |                            |
|        |                  |                  |                    |                                  | OP_LB               |                  | (sign_ext, inst(31:20))                                       | 0                      |                       | inst[19:15]      |                  |                  |                                    |                   | 0           |                                              |             | 0              |                                 |                            |
| lw     |                  |                  |                    |                                  | OP_LW               | ADD              | {sign_ext, inst{31:20}}                                       | 0                      | 0                     | inst[19:15]      | 1                | inst[11:7]       | 0                                  |                   | 0           | 0                                            | 1           | U              |                                 |                            |
| sb     |                  |                  |                    |                                  | OP_SB               | ADD              | {sign_ext, inst{31:25}, inst{11:7}}                           | 0                      | 0                     | inst[19:15]      | inst[24:20]      | inst[11:7]       | 0                                  |                   | 1           | ,                                            | 0           | 0              |                                 | 存的<br>值为<br>reg_d<br>的低8   |
| sw     |                  |                  |                    |                                  | OP_SW               | ADD              | {sign_ext, inst[31:25], inst[11:7]}                           | 0                      | 0                     | inst[19:15]      | inst[24:20]      | inst[11:7]       | 0                                  |                   | 1           | 1                                            | 0           | 0              |                                 | 存的<br>值为<br>reg_d          |
| beq    |                  |                  | 1                  |                                  | OP_BEQ              | ADD              | {sign_ext,inst[7],inst[30:25],inst[11:8],1'b0}                | 0                      | 1                     | 1                | 1                | 1                | 1                                  |                   | 0           | 1                                            | 0           | 0              |                                 |                            |
|        |                  |                  | 0                  |                                  | OP_BEQ              | ADD              | 1                                                             | 1                      | 1                     | 1                | 1                | 1                | 0                                  |                   | 0           | 1                                            | 0           | 0              |                                 |                            |
| bne    |                  |                  | 0                  |                                  | OP_BNE              | ADD              | /                                                             | 1                      | 1                     | 1                | 1                | 1                | 0                                  |                   | 0           | 1                                            | 0           | 0              |                                 |                            |
|        |                  |                  | 1                  |                                  | OP_BNE              | ADD              | {sign_ext,inst[7],inst[30:25],inst[11:8],1'b0}                | 0                      | 1                     | 1                | 1                | 1                | 1                                  |                   | 0           | 1                                            | 0           | 0              |                                 |                            |
| blt    |                  |                  |                    | 1                                | OP_BLT              | ADD              | {sign_ext,inst[7],inst[30:25],inst[11:8],1'b0}                | 0                      | 1                     | 1                | 1                | 1                | 1                                  |                   | 0           | 1                                            | 0           | 0              |                                 |                            |
|        |                  |                  |                    | 0                                | OP_BLT              | ADD              | 1                                                             | 1                      | 1                     | 1                | 1                | 1                | 0                                  |                   | 0           | 1                                            | 0           | 0              |                                 |                            |
| jal    |                  |                  |                    |                                  | OP_JAL              | ADD              | {sign_ext_jal,inst[31],inst[19:12],inst[20],inst[30:21],1'b0} | 0                      | 1                     | /                | 1                | inst[11:7]       | 1                                  |                   | 0           | 2                                            | 1           | 0              |                                 |                            |
| jalr   |                  |                  |                    |                                  | OP_JALR             | ADD              | {sign_ext,inst[31:20]}                                        | 0                      | 0                     | inst[19:15]      | ,                | inst[11:7]       | 1                                  |                   | 0           | 2                                            | 1           | 0              |                                 | ALU<br>结果<br>最低<br>位清<br>零 |
| csrrc  |                  |                  |                    |                                  | OP_CSRR             | NANDN            | csr_data                                                      | 0                      | 0                     | inst[19:15]      | 1                | inst[11:7]       | 0                                  | inst[31:20]       | 0           | 3                                            | 1           | 1              |                                 |                            |
| csrrs  |                  |                  |                    |                                  | OP_CSRR             | OR               | csr_data                                                      | 0                      | 0                     | inst[19:15]      | 1                | inst[11:7]       | 0                                  | inst[31:20]       | 0           | 3                                            | 1           | 1              |                                 |                            |
| csrrw  |                  |                  |                    |                                  | OP_CSRR             | ADD              | csr_data                                                      | 0                      | 0                     | inst[19:15]      | 1                | inst[11:7]       | 0                                  | inst[31:20]       | 0           | 3                                            | 1           | 1              |                                 |                            |
| ebreak |                  |                  |                    |                                  | OP_EBREAK           | ADD              | /                                                             | 1                      | /                     | /                | /                | /                | 0                                  |                   | 0           | 1                                            | 0           | 0              |                                 |                            |
| ecall  |                  |                  |                    |                                  | OP_ECALL            | ADD              | /                                                             | 1                      | 1                     | 1                | 1                | 1                | 0                                  |                   | 0           | /                                            | 0           | 0              |                                 |                            |
| mret   |                  |                  |                    |                                  | OP_ECALL<br>OP_MRET | ADD              | ,                                                             | /                      | /                     | 1                | /                | /                | 0                                  |                   | 0           | 1                                            | 0           | 0              |                                 |                            |
| et     |                  |                  |                    |                                  | OP_MIRET            | SLTU             | /                                                             | 1                      | 0                     | inst[19:15]      | inst[24:20]      | instf11:71       | 0                                  |                   | 0           | 1                                            | 1           | 0              |                                 |                            |