



## 体系结构实验报告

课程名称: 计算机体体系结构

实验项目: 支持 RISC-V RV32I 的流水线CPU

专业: 计算机科学技术

学生姓名: 李浩浩

学号: 3220105930

指导老师: 何水兵

实验日期: 2024年9月24日

# 一、实验目的、要求及任务

## (一) 实验目的

- Understand RISC-V RV32I instructions
- Master the design methods of pipelined CPU executing RV32I instructions
- Master the method of Pipeline Forwarding Detection and bypass unit design
- Master the methods of 1-cycle stall of Predict-not-taken branch design
- Master methods of program verification of Pipelined CPU executing RV32I instructions

## (二) 实验任务

- Design of Pipelined CPU executing RV32I instructions.
  - Design datapath
  - Design Bypass Unit
  - Design CPU Controller
- Verify the Pipelined CPU with program and observe the execution of program

# 二、实验原理

对于没有添加forward的流水线CPU，需要存到寄存器内的数据直到第5阶段才能准备好，如果下一条指令需要用到该指令的结果，则至少需要等待2个cycle（将下一条指令的第二阶段与该指令的第五阶段对齐）。但实际上，ALU的结果在指令的第三阶段就能得到，Load的结果在第四阶段就能得到，如果能够及时将结果前传，下一条指令的第二阶段就只需与该指令的第三或第四阶段对齐，最多等待1cycle。

## (一) 普通数据冲突



指当前指令需要存入寄存器的值在 ALU 阶段得出，该值在存入寄存器之前就有后来的指令将其作为操作数。由于后来指令用到该数值的最早时间在其第三阶段，而该阶段晚于当前指令的第三阶段，所以只需前传即可，不用停顿。

## (二) use after load



指当前指令为Load型指令，需要存入寄存器的值在该指令的第四阶段末才得到，而其后紧跟的指令需要在其第三阶段初就使用该值，这在时序上无法满足，所以即使在有前传的情况下也需要停顿一个周期。

## (三) branch



branch指令是否跳转的选择结果在ALU阶段（第三阶段）才会得到，然后需要用一个加法器计算下一条指令的地址，所以到第四阶段才能得到下一条指令确切的地址。在此之前，我们不知道该不该使用下一条指令。

- 如果什么都不做，需要等待 3 cycles 才能继续运行

- 总是假设不跳转，该策略不改变得到下一步指令确切地址的时间，所以如果预测错误的话还是相当于停顿三个周期，预测正确就是顺序执行，所以该策略只是在平均意义上减少停顿时间。
- 总是假设跳转，其余什么都不做，由于不改变确切得到下一步指令地址的时间，还要通过ALU之后的加法器得到跳转地址，所以无论预测对错都没有意义，不会改变停顿周期。
- 总是假设跳转，而且将跳转地址的计算提前到第二阶段（因为立即数最早能在第二阶段得到），此时如果预测正确，而我们是在第二阶段未得到跳转地址的，那么Instruction Memory最早能在branch的第三阶段取出正确的指令，所以需要停顿 1 cycle。如果预测错误（无需跳转），还是需要停顿 3 cycles（因为PC+4在第四阶段才能算出来）
- 总是假设跳转，且将跳转地址的计算和跳转条件的判断提前到第二阶段。因为要等待跳转地址的计算，所以下一步无论如何也要等到branch的第三阶段才能继续执行，但是我们在第三阶段已经具备了所有信息，完全可以直接执行正确的指令，无需预测。所以这种策略总是停顿 1 cycle。
- 总是假设不跳转，且将跳转地址的计算和跳转条件的判断提前到第二阶段。因为PC+4在branch的第一阶段就已经得到了，在branch判断是否跳转的时候PC+4的指令开始执行，所以预测正确的情况下无需停顿。如果在第二阶段发现预测错误，则正确指令在branch的第三阶段开始执行，相当于停顿 1 cycle。

| Predict Methods   | Status                | Original Datapath | Address Calculation Forward | Condition Comparison Forward |
|-------------------|-----------------------|-------------------|-----------------------------|------------------------------|
| Predict-taken     | Hit<br>(Need Branch)  | 3 stall           | 1 stall                     | 1 stall                      |
| Predict-taken     | Miss<br>(No Branch)   | 3 stall           | 3 stall                     | 1 stall                      |
| Predict-not-taken | Hit<br>(No Branch)    | go on             | go on                       | go on                        |
| Predict-not-taken | Miss<br>(Need Branch) | 3 stall           | 3 stall                     | 1 stall                      |

### 三、实验过程及数据记录



上面的图是按照本次实验源码画的，将 forward 和 hazard 合到一起了

## (一) cmp.v

```
'timescale 1ns / 1ps

module cmp_32( input [31:0] a,
                input [31:0] b,
                input [2:0] ctrl,
                output c
);
parameter cmp_EQ  = 3'b001;
parameter cmp_NE  = 3'b010;
parameter cmp_LT  = 3'b011;
parameter cmp_LTU = 3'b100;
parameter cmp_GE  = 3'b101;
parameter cmp_GEU = 3'b110;

wire res_EQ  = a == b;
wire res_NE  = ~res_EQ;
wire res_LT  = (a[31] & ~b[31]) || (~a[31] ^ b[31]) && a < b;
wire res_LTU = a < b;
wire res_GE  = ~res_LT;
wire res_GEU = ~res_LTU;

wire EQ  = ctrl == cmp_EQ ;
wire NE  = ctrl == cmp_NE ;
wire LT  = ctrl == cmp_LT ;
wire LTU = ctrl == cmp_LTU;
wire GE  = ctrl == cmp_GE ;
wire GEU = ctrl == cmp_GEU;

assign c = (EQ ? res_EQ : (NE ? res_NE : (LT ? res_LT : (LTU? res_LTU : (GE ? res_GE
: (GEU? res_GEU : 1'b0)))))); //to fill sth. in ()

endmodule
```

## (二) CtrlUnit.v

```
`timescale 1ns / 1ps

module CtrlUnit(
    input[31:0] inst,
    input cmp_res,
    output Branch, ALUSrc_A, ALUSrc_B, DatatoReg, RegWrite, mem_w,
    MIO, rs1use, rs2use,
    output [1:0] hazard_optype,
    output [2:0] ImmSel, cmp_ctrl,
    output [3:0] ALUControl,
    output JALR
);

wire[6:0] funct7 = inst[31:25];
wire[2:0] funct3 = inst[14:12];
wire[6:0] opcode = inst[6:0];

wire Rop = opcode == 7'b0110011;
wire Iop = opcode == 7'b0010011;
wire Bop = opcode == 7'b1100011;
wire Lop = opcode == 7'b0000011;
wire Sop = opcode == 7'b0100011;

wire funct7_0 = funct7 == 7'h0;
wire funct7_32 = funct7 == 7'h20;

wire funct3_0 = funct3 == 3'h0;
wire funct3_1 = funct3 == 3'h1;
wire funct3_2 = funct3 == 3'h2;
wire funct3_3 = funct3 == 3'h3;
wire funct3_4 = funct3 == 3'h4;
wire funct3_5 = funct3 == 3'h5;
wire funct3_6 = funct3 == 3'h6;
wire funct3_7 = funct3 == 3'h7;

wire ADD = Rop & funct3_0 & funct7_0;
wire SUB = Rop & funct3_0 & funct7_32;
wire SLL = Rop & funct3_1 & funct7_0;
wire SLT = Rop & funct3_2 & funct7_0;
wire SLTU = Rop & funct3_3 & funct7_0;
```

```

wire XOR  = Rop & funct3_4 & funct7_0;
wire SRL  = Rop & funct3_5 & funct7_0;
wire SRA  = Rop & funct3_5 & funct7_32;
wire OR   = Rop & funct3_6 & funct7_0;
wire AND  = Rop & funct3_7 & funct7_0;

wire ADDI = Iop & funct3_0;
wire SLTI = Iop & funct3_2;
wire SLTIU = Iop & funct3_3;
wire XORI = Iop & funct3_4;
wire ORI  = Iop & funct3_6;
wire ANDI = Iop & funct3_7;
wire SLLI = Iop & funct3_1 & funct7_0;
wire SRLI = Iop & funct3_5 & funct7_0;
wire SRAI = Iop & funct3_5 & funct7_32;

wire BEQ  = Bop & funct3_0;                                //to fill sth. in
wire BNE  = Bop & funct3_1;                                //to fill sth. in
wire BLT  = Bop & funct3_4;                                //to fill sth. in
wire BGE  = Bop & funct3_5;                                //to fill sth. in
wire BLTU = Bop & funct3_6;                               //to fill sth. in
wire BGEU = Bop & funct3_7;                               //to fill sth. in

wire LB   = Lop & funct3_0;                                //to fill sth. in
wire LH   = Lop & funct3_1;                                //to fill sth. in
wire LW   = Lop & funct3_2;                                //to fill sth. in
wire LBU  = Lop & funct3_4;                               //to fill sth. in
wire LHU  = Lop & funct3_5;                               //to fill sth. in

wire SB   = Sop & funct3_0;                                //to fill sth. in
wire SH   = Sop & funct3_1;                                //to fill sth. in
wire SW   = Sop & funct3_2;                                //to fill sth. in

wire LUI  = opcode == 7'b0110111;                          //to fill sth. in
wire AUIPC= opcode == 7'b0010111;                          //to fill sth. in

wire JAL  = opcode == 7'b1101111;                          //to fill sth. in
assign JALR = opcode == 7'b1100111;                         //to fill sth. in

wire R_valid = AND | OR | ADD | XOR | SLL | SRL | SRA | SUB | SLT | SLTU;
wire I_valid = ANDI | ORI | ADDI | XORI | SLLI | SRLI | SRAI | SLTI | SLTIU;
wire B_valid = BEQ | BNE | BLT | BGE | BLTU | BGEU;
wire L_valid = LW | LH | LB | LHU | LBU;

```

```

wire S_valid = SW | SH | SB;

assign Branch = (B_valid & cmp_res) | JAL | JALR; //to fill sth. in

parameter Imm_type_I = 3'b001;
parameter Imm_type_B = 3'b010;
parameter Imm_type_J = 3'b011;
parameter Imm_type_S = 3'b100;
parameter Imm_type_U = 3'b101;
assign ImmSel = {3{I_valid | JALR | L_valid}} & Imm_type_I |
               {3{B_valid}} & Imm_type_B |
               {3{JAL}} & Imm_type_J |
               {3{S_valid}} & Imm_type_S |
               {3{LUI | AUIPC}} & Imm_type_U ;

assign cmp_ctrl = {3{BEQ}} & 3'b001 | //to fill sth. in
                {3{BNE}} & 3'b010 |
                {3{BLT}} & 3'b011 |
                {3{BGE}} & 3'b101 |
                {3{BLTU}} & 3'b100 |
                {3{BGEU}} & 3'b110 ;

assign ALUSrc_A = JAL | JALR | AUIPC; //to fill sth. in // active
when pc is used as rs1

assign ALUSrc_B = ~(R_valid | B_valid | JAL | JALR); //to fill
sth. in // active when immediate is used as rs2

parameter ALU_ADD = 4'b0001;
parameter ALU_SUB = 4'b0010;
parameter ALU_AND = 4'b0011;
parameter ALU_OR = 4'b0100;
parameter ALU_XOR = 4'b0101;
parameter ALU_SLL = 4'b0110;
parameter ALU_SRL = 4'b0111;
parameter ALU_SLT = 4'b1000;
parameter ALU_SLTU = 4'b1001;
parameter ALU_SRA = 4'b1010;
parameter ALU_Ap4 = 4'b1011;
parameter ALU_Bout = 4'b1100;
assign ALUControl = {4{ADD | ADDI | L_valid | S_valid | AUIPC}} & ALU_ADD |

```

```

{4{SUB}} & ALU_SUB |
{4{AND | ANDI}} & ALU_AND |
{4{OR | ORI}} & ALU_OR |
{4{XOR | XORI}} & ALU_XOR |
{4{SLL | SLLI}} & ALU_SLL |
{4{SRL | SRRI}} & ALU_SRL |
{4{SLT | SLTI}} & ALU_SLT |
{4{SLTU | SLTIU}} & ALU_SLTU |
{4{SRA | SRAI}} & ALU_SRA |
{4{JAL | JALR}} & ALU_Ap4 |
{4{LUI}} & ALU_Bout ;

```

**assign** DatatoReg = L\_valid;

**assign** RegWrite = R\_valid | I\_valid | JAL | JALR | L\_valid | LUI | AUIPC;

**assign** mem\_w = S\_valid;

**assign** MIO = L\_valid | S\_valid;

**assign** rs1use = ~(LUI|AUIPC|JAL); //to fill sth. in

**assign** rs2use = Rop|Sop|Bop; //to fill sth. in

**localparam** hazard\_optype\_ALU = 2'b01; //current operation uses ALU

**localparam** hazard\_optype\_LOAD = 2'b10; //current operation loads data from memory

**localparam** hazard\_optype\_STORE = 2'b11; //current operation stores data to memory

**assign** hazard\_optype = {2{R\_valid | I\_valid | LUI | AUIPC | JAL | JALR}} & hazard\_optype\_ALU | {2{L\_valid}} & hazard\_optype\_LOAD | {2{S\_valid}} & hazard\_optype\_STORE; //to fill sth. in

**endmodule**

### (三) HazardDetectionUnit.v

```
`timescale 1ps/1ps

module HazardDetectionUnit(
    input clk,
    input Branch_ID, rs1use_ID, rs2use_ID,
    input[1:0] hazard_optype_ID,
    input[4:0] rd_EXE, rd_MEM, rs1_ID, rs2_ID, rs2_EXE,
    output PC_EN_IF, reg_FD_EN, reg_FD_stall, reg_FD_flush,
    reg_DE_EN, reg_DE_flush, reg_EM_EN, reg_EM_flush, reg_MW_EN,
    output forward_ctrl_ls,
    output[1:0] forward_ctrl_A, forward_ctrl_B
);
    //according to the diagram, design the Hazard Detection Unit

    //activate registers
    assign reg_FD_EN = 1'b1;
    assign reg_DE_EN = 1'b1;
    assign reg_EM_EN = 1'b1;
    assign reg_MW_EN = 1'b1;

    //hazard operation type transfer
    reg[1:0] hazard_optype_EXE, hazard_optype_MEM;
    always@(posedge clk)begin
        hazard_optype_MEM <= hazard_optype_EXE;
        hazard_optype_EXE <= hazard_optype_ID & {2{~reg_DE_flush}};      //there is no data
        hazard in EXE stage if DE flush is active
    end

    //forward and stall control logic
    localparam hazard_optype_ALU    = 2'b01;
    localparam hazard_optype_LOAD   = 2'b10;
    localparam hazard_optype_STORE  = 2'b11;

    wire rs1_stall = rs1use_ID && rs1_ID && (rs1_ID == rd_EXE) && (hazard_optype_EXE ==
    hazard_optype_LOAD); //rs2 of store instruction is only used in MEM stage, but rs1 is used in
    EXE stage
    wire rs2_stall = rs2use_ID && rs2_ID && (rs2_ID == rd_EXE) && (hazard_optype_EXE ==
    hazard_optype_LOAD) && (hazard_optype_ID != hazard_optype_STORE);

    wire rs1_forward_from_EXE = rs1use_ID && rs1_ID && (rs1_ID == rd_EXE) &&
    (hazard_optype_EXE == hazard_optype_ALU);
```

```

    wire rs2_forward_from_EXE = rs2use_ID && rs2_ID && (rs2_ID == rd_EXE) &&
(hazard_optype_EXE == hazard_optype_ALU);

    wire rs1_forward_from_MEM_ALU = (~rs1_forward_from_EXE) && rs1use_ID && rs1_ID && (rs1_ID
== rd_MEMORY) && (hazard_optype_MEMORY == hazard_optype_ALU); // if EXE stage is not hazardous, then
rs1 can be forwarded from MEM stage
    wire rs2_forward_from_MEM_ALU = (~rs2_forward_from_EXE) && rs2use_ID && rs2_ID && (rs2_ID
== rd_MEMORY) && (hazard_optype_MEMORY == hazard_optype_ALU);

    wire rs1_forward_from_MEM_LOAD = rs1use_ID && rs1_ID && (rs1_ID == rd_MEMORY) &&
(hazard_optype_MEMORY == hazard_optype_LOAD); // forward loaded data from MEM stage to ID stage
    wire rs2_forward_from_MEM_LOAD = rs2use_ID && rs2_ID && (rs2_ID == rd_MEMORY) &&
(hazard_optype_MEMORY == hazard_optype_LOAD);

    wire rs2_EXE_forward_from_MEMORY = rs2_EXE && (rs2_EXE == rd_MEMORY) && (hazard_optype_MEMORY ==
hazard_optype_LOAD) && (hazard_optype_EXE == hazard_optype_STORE);

    wire stall = rs1_stall | rs2_stall;

    assign PC_EN_IF = ~stall;
    assign reg_FD_stall = stall;
    assign reg_FD_flush = Branch_ID;
    assign reg_DE_flush = stall;

    assign forward_ctrl_A = {2{rs1_forward_from_EXE}} & 2'b01 |
{2{rs1_forward_from_MEM_ALU}} & 2'b10 |
{2{rs1_forward_from_MEM_LOAD}} & 2'b11 ;
    assign forward_ctrl_B = {2{rs2_forward_from_EXE}} & 2'b01 |
{2{rs2_forward_from_MEM_ALU}} & 2'b10 |
{2{rs2_forward_from_MEM_LOAD}} & 2'b11 ;
    assign forward_ctrl_ls = rs2_EXE_forward_from_MEMORY;

endmodule

```

## (四) RV32core.v

按照前面的结构图连线即可。

## 四、实验结果分析

## (一) 仿真







与ppt上的图片一模一样

## (二) 上板

Zhejiang University Computer Organization Experimental  
SOC Test Environment (With RISC-V)

|                   |                  |                   |                   |
|-------------------|------------------|-------------------|-------------------|
| x0:zero 00000000  | x01: ra 00000000 | x02: sp 00000000  | x03: gp 00000000  |
| x04: tp 00000000  | x05: t0 00000000 | x06: t1 00000000  | x07: t2 00000000  |
| x08:fps0 00000000 | x09: s1 00000000 | x10: a0 00000000  | x11: a1 00000000  |
| x12: a2 00000000  | x13: a3 00000000 | x14: a4 00000000  | x15: a5 00000000  |
| x16: a6 00000000  | x17: a7 00000000 | x18: s2 00000000  | x19: s3 00000000  |
| x20: s4 00000000  | x21: s5 00000000 | x22: s6 00000000  | x23: s7 00000000  |
| x24: s8 00000000  | x25: s9 00000000 | x26: s10 00000000 | x27: s11 00000000 |
| x28: t3 00000000  | x29: t4 00000000 | x30: t5 00000000  | x31: t6 00000000  |
| PC-- IF 00000000  | INST-IF 00000013 | rs1Data 00000000  | rs2Data 00000000  |
| PC-- ID 00000000  | INST-ID 00000000 | rs1Addr 00000000  | rs2Addr 00000000  |
| PC-- EXE 00000000 | INST-EX 00000000 | ----- AA55AA55    | PCJumpA 00000000  |
| PC-- MEM 00000000 | INST-M 00000000  | B/PCE-S 00000100  | D/C-Hzd 00000000  |
| PC-- WB 00000000  | INST-WB 00000000 | I/ABSel 00000000  | PCIFNxt 00000004  |
| ALU-Ain 00000010  | ALU-Out 00000000 | CPUAddr 00000000  | ALUCtrl 00000000  |
| ALU-Bin 00000010  | WB-Data 00000000 | CPU-DAI FFFFFFFBF | WR-MIO 00000000   |
| Imm32ID 00000000  | WB-Addr 00000000 | CPU-DAO 00000000  | RegW/DR 00000000  |
| CODE-00 00000000  | nop JStall:addi0 | CODE-03 00000000  | CODE-07 00000000  |
| CODE-04 00000000  | nop DStall:Iw 00 | CODE-0B 00000000  | CODE-0F 00000000  |
| CODE-08 00000000  | nop DStall:Iw 00 | CODE-13 00000000  | CODE-17 00000000  |
| CODE-0C 00000000  | nop DStall:Iw 00 | CODE-19 00000000  | CODE-1B 00000000  |
| CODE-10 00000000  | nop DStall:Iw 00 | CODE-1D 00000000  | CODE-1E 00000000  |
| CODE-14 00000000  | CODE-15 00000000 | CODE-21 00000000  | CODE-22 00000000  |
| CODE-18 00000000  | CODE-19 00000000 | CODE-25 00000000  | CODE-26 00000000  |
| CODE-1C 00000000  | CODE-1D 00000000 | CODE-27 00000000  | CODE-23 00000000  |
| CODE-20 00000000  | CODE-21 00000000 | CODE-27 00000000  | CODE-27 00000000  |
| CODE-24 00000000  | CODE-25 00000000 | CODE-27 00000000  | CODE-27 00000000  |

Zhejiang University Computer Organization Experimental  
SOC Test Environment (With RISC-V)

|                   |                    |                  |                  |
|-------------------|--------------------|------------------|------------------|
| x0:zero 00000000  | x01: ra 00000000   | x02: sp 00000000 | x03: gp 00000000 |
| x04: tp 00000010  | x05: t0 00000000   | x06: t1 00000000 | x07: t2 00000000 |
| x08:fps0 00000000 | x09: s1 00000000   | x10: a0 00000000 | x11: a1 00000000 |
| x12: a2 00000000  | x13: a3 00000000   | x14: a4 00000000 | x15: a5 00000000 |
| x16: a6 00000000  | x17: a7 00000000   | x18: s2 00000000 | x19: s3 00000000 |
| x20: s4 00000000  | x21: s5 00000000   | x22: s6 00000000 | x23: s7 00000000 |
| x24: s8 00000000  | x25: s9 00000000   | x26:s10 00000000 | x27:s11 00000000 |
| x28: t3 00000000  | x29: t4 00000000   | x30: t5 00000000 | x31: t6 00000000 |
| PC---IF 00000014  | INST-IF 00C02283   | rs1Data 00000000 | rs2Data 00000000 |
| PC---ID 00000010  | INST-ID FFF08093   | rs1Addr 00000001 | rs2Addr 0000001F |
| PC--EXE 0000000C  | INST-EX 004100B3   | ----- AA55AA55   | PCJumpA 0000000F |
| PC--MEM 0000000C  | INST--M 00000000   | B/PCE-S 00000100 | D/C-Hzd 00000000 |
| PC--WB 00000008   | INST-WB 00802203   | I/ABSel 00010001 | PCIFNxt 00000018 |
| ALU-Ain 00000008  | ALU-Out 00000008   | CPUAddr 00000000 | ALUCtrl 00000001 |
| ALU-Bin 00000010  | WB-Data 00000010   | CPU-Dai 00000010 | WR--MIO 00000000 |
| Imm32ID FFFFFFFF  | WB-Addr 00000004   | CPU-Dao 00000000 | RegW/DR 00010001 |
| CODE-00 00000000  | lw x05,x00,00CH    | CODE-03 00000000 | CODE-07 00000000 |
| CODE-04 00000000  | addi x01,x01,FFFFH | CODE-0B 00000000 | CODE-0F 00000000 |
| CODE-08 00000000  | add x01,x02,x04    | CODE-13 00000000 | CODE-17 00000000 |
| CODE-0C 00000000  | nop DStall:lw 00   | CODE-19 00000000 | CODE-1B 00000000 |
| CODE-10 00000000  | lw x04,x00,008H    | CODE-1D 00000000 | CODE-1E 00000000 |
| CODE-14 00000000  | CODE-15 00000000   | CODE-21 00000000 | CODE-22 00000000 |
| CODE-18 00000000  | CODE-19 00000000   | CODE-25 00000000 | CODE-26 00000000 |
| CODE-1C 00000000  | CODE-1D 00000000   | CODE-27 00000000 | CODE-23 00000000 |
| CODE-20 00000000  | CODE-21 00000000   | CODE-29 00000000 | CODE-27 00000000 |
| CODE-24 00000000  | CODE-25 00000000   | CODE-2A 00000000 | CODE-2B 00000000 |

POWER VOL- VOL+ MENU CH- CH+ MODE

Zhejiang University Computer Organization Experimental  
SOC Test Environment (With RISC-V)

|                  |                  |                    |                  |
|------------------|------------------|--------------------|------------------|
| x0:zero 00000000 | x01: ra 00000001 | x02: sp 00000008   | x03: gp 00000000 |
| x84: tp 00000010 | x05: t0 00000014 | x06: t1 FFFF0000   | x07: t2 0FFF0000 |
| x8:fps0 00000000 | x09: s1 00000000 | x10: a0 00000000   | x11: a1 00000000 |
| x12: a2 00000000 | x13: a3 00000000 | x14: a4 00000000   | x15: a5 00000000 |
| x16: a6 00000000 | x17: a7 00000000 | x18: s2 00000000   | x19: s3 00000000 |
| x20: s4 00000000 | x21: s5 00000000 | x22: s6 00000000   | x23: s7 00000000 |
| x24: s8 00000000 | x25: s9 00000000 | x26:s10 00000000   | x27:s11 00000000 |
| x28: t3 00000000 | x29: t4 00000000 | x30: t5 00000000   | x31: t6 00000000 |
| PC--IF 0000008C  | INST-IF 00421863 | rs1Data 00000000   | rs2Data 00000000 |
| PC--ID 00000080  | INST-ID 00000013 | rs1Addr 00000000   | rs2Addr 00000000 |
| PC--EXE 00000080 | INST-EX 00420663 | ----- AA55AA55     | PCJumpA 00000000 |
| PC--MDM 0000007C | INST-M 00520863  | B/PCE-S 00000100   | D/C-HzD 00000000 |
| PC--WB 00000078  | INST-WB FFF3B093 | I/ABSel 00010001   | PCIFNxt 00000090 |
| ALU-Ain 00000010 | ALU-Out 00000000 | CPUAddr 00000000   | ALUCtrl 00000001 |
| ALU-Bin 00000010 | WB-Data 00000001 | CPU-DAi FFFFFFFBF  | WR--MID 00000000 |
| Imm32ID 00000000 | WB-Addr 00000001 | CPU-DAO 00000014   | RegW/DR 00010000 |
| CODE-00 00000000 | bne x04,x04,0010 |                    | CODE-03 00000000 |
| CODE-04 00000000 | nop JStall:addi0 |                    | CODE-07 00000000 |
| CODE-08 00000000 |                  | beq x04,x04,000C   | CODE-0B 00000000 |
| CODE-0C 00000000 |                  | beq x04,x05,0010   | CODE-0F 00000000 |
| CODE-10 00000000 |                  | sltiu x01,x07,FFFF | CODE-13 00000000 |
| CODE-14 00000000 | CODE-15 00000000 | CODE-16 00000000   | CODE-17 00000000 |
| CODE-18 00000000 | CODE-19 00000000 | CODE-1A 00000000   | CODE-1B 00000000 |
| CODE-1C 00000000 | CODE-1D 00000000 | CODE-1E 00000000   | CODE-1F 00000000 |
| CODE-20 00000000 | CODE-21 00000000 | CODE-22 00000000   | CODE-23 00000000 |
| CODE-24 00000000 | CODE-25 00000000 | CODE-26 00000000   | CODE-27 00000000 |

POWER VOL VOL+ MENU CH CH+ MODE

Zhejiang University Computer Organization Experimental  
SOC Test Environment (With RISC-V)

|                    |                  |                  |                  |
|--------------------|------------------|------------------|------------------|
| x0:zero 00000000   | x01: ra 00000001 | x02: sp 00000008 | x03: gp 00000000 |
| x04: tp 00000010   | x05: t0 00000014 | x06: t1 FFFF0000 | x07: t2 0FFF0000 |
| x08:fps0 00000000  | x09: s1 00000000 | x10: a0 00000000 | x11: a1 00000000 |
| x12: a2 00000000   | x13: a3 00000000 | x14: a4 00000000 | x15: a5 00000000 |
| x16: a6 00000000   | x17: a7 00000000 | x18: s2 00000000 | x19: s3 00000000 |
| x20: s4 00000000   | x21: s5 00000000 | x22: s6 00000000 | x23: s7 00000000 |
| x24: s8 00000000   | x25: s9 00000000 | x26:s10 00000000 | x27:s11 00000000 |
| x28: t3 00000000   | x29: t4 00000000 | x30: t5 00000000 | x31: t6 00000000 |
| PC---IF 000000A0   | INST-IF 00524663 | rs1Data 00000014 | rs2Data 00000010 |
| PC---ID 00000089C  | INST-ID 0042C863 | rs1Addr 00000005 | rs2Addr 00000004 |
| PC---EX 000000090  | INST-EX 00000013 | ----- AA55AA55   | PCJumpA 000000AC |
| PC---MEM 000000090 | INST--M 00521663 | B/PCE-S 00000100 | D/C-Hzd 00000000 |
| PC---WB 00000008C  | INST-WB 00421863 | I/ABSel 00020000 | PCIFNxt 000000A1 |
| ALU-Ain 00000000   | ALU-Out 00000000 | CPUAddr 00000000 | ALUCtrl 00000000 |
| ALU-Bin 00000000   | WB-Data 00000000 | CPU-Dai FFFF80BF | WR--MIO 00000000 |
| Imm32ID 00000010   | WB-Addr 00000010 | CPU-Dao 00000014 | RegW/DR 00000000 |
| CODE-00 00000000   | blt x04,x05,0000 |                  | CODE-03 00000000 |
| CODE-04 00000000   | blt x05,x04,0010 |                  | CODE-07 00000000 |
| CODE-08 00000000   | nop JStall:addi0 |                  | CODE-0B 00000000 |
| CODE-0C 00000000   | bne x04,x05,000C |                  | CODE-0F 00000000 |
| CODE-10 00000000   | bne x04,x04,0010 |                  | CODE-13 00000000 |
| CODE-14 00000000   | CODE-15 00000000 | CODE-16 00000000 | CODE-17 00000000 |
| CODE-18 00000000   | CODE-19 00000000 | CODE-1A 00000000 | CODE-1B 00000000 |
| CODE-1C 00000000   | CODE-1D 00000000 | CODE-1E 00000000 | CODE-1F 00000000 |
| CODE-20 00000000   | CODE-21 00000000 | CODE-22 00000000 | CODE-23 00000000 |
| CODE-24 00000000   | CODE-25 00000000 | CODE-26 00000000 | CODE-27 00000000 |

POWER VOL- VOL+ MENU CH- CH+ MODE

Zhejiang University Computer Organization Experimental  
SOC Test Environment (With RISC-V)

|                   |                  |                   |                   |
|-------------------|------------------|-------------------|-------------------|
| x0:zero 00000000  | x01: ra 00000000 | x02: sp 00000000  | x03: gp 00000000  |
| x04: tp 00000000  | x05: t0 00000000 | x06: t1 00000000  | x07: t2 00000000  |
| x08:fps0 00000000 | x09: s1 00000000 | x10: a0 00000000  | x11: a1 00000000  |
| x12: a2 00000000  | x13: a3 00000000 | x14: a4 00000000  | x15: a5 00000000  |
| x16: a6 00000000  | x17: a7 00000000 | x18: s2 00000000  | x19: s3 00000000  |
| x20: s4 00000000  | x21: s5 00000000 | x22: s6 00000000  | x23: s7 00000000  |
| x24: s8 00000000  | x25: s9 00000000 | x26:s10 00000000  | x27:s11 00000000  |
| x28: t3 00000000  | x29: t4 00000000 | x30: t5 00000000  | x31: t6 00000000  |
| PC---IF 00000000  | INST-IF 00000013 | rs1Data 00000000  | rs2Data 00000000  |
| PC---ID 00000000  | INST-ID 00000000 | rs1Addr 00000000  | rs2Addr 00000000  |
| PC--EXE 00000000  | INST-EX 00000000 | ----- AA55AA55    | PCJumpA 00000000  |
| PC--MEM 00000000  | INST--M 00000000 | B/PCE-S 00000100  | D/C-Hzd 00000000  |
| PC--WB 00000000   | INST-WB 00000000 | I/ABSel 00000000  | PCIFNtxt 00000004 |
| ALU-Ain 00000012  | ALU-Out 00000000 | CPUAddr 00000000  | ALUCtrl 00000000  |
| ALU-Bin 00000012  | WB-Data 00000000 | CPU-DAi FFFFFFFBF | WR--MIO 00000000  |
| Imm32ID 00000000  | WB-Addr 00000000 | CPU-DAO 00000000  | RegW/DR 00000000  |
| RAM:000 00000000  | RAM:001 00000000 | RAM:002 00000000  | RAM:003 00000000  |
| RAM:004 00000000  | RAM:005 00000000 | RAM:006 00000000  | RAM:007 00000000  |
| RAM:008 00000000  | RAM:009 00000000 | RAM:00A 00000000  | RAM:00B 00000000  |
| RAM:00C 00000000  | RAM:00D 00000000 | RAM:00E 00000000  | RAM:00F 00000000  |
| RAM:010 00000000  | RAM:011 00000000 | RAM:012 00000000  | RAM:013 00000000  |
| RAM:014 00000000  | RAM:015 00000000 | RAM:016 00000000  | RAM:017 00000000  |
| RAM:018 00000000  | RAM:019 00000000 | RAM:01A 00000000  | RAM:01B 00000000  |
| RAM:01C 00000000  | RAM:01D 00000000 | RAM:01E 00000000  | RAM:01F 00000000  |
| RAM:020 00000000  | RAM:021 00000000 | RAM:022 00000000  | RAM:023 00000000  |
| RAM:024 00000000  | RAM:025 00000000 | RAM:026 00000000  | RAM:027 00000000  |

POWER VOL- VOL+ MENU CH- CH+ MODE