

Computer Organization & Design 实验与课程设计

# Lab04-2

# CPU设计—控制器

Ma De (马德)

[made@zju.edu.cn](mailto:made@zju.edu.cn)

2025

College of Computer Science, Zhejiang University

# Course Outline

---

- 一、实验目的
- 二、实验环境
- 三、实验目标及任务

# 实验目的

---

1. 运用寄存器传输控制技术
2. 掌握CPU的核心：指令执行过程与控制流关系
3. 设计控制器
4. 学习测试方案的设计
5. 学习测试程序的设计

# 实验环境

---

## □ 实验设备

1. 计算机（Intel Core i5以上， 4GB内存以上）系统
2. NEXYS A7开发板
3. VIVADO 2017.4及以上开发工具

## □ 材料

无

# 实验目标及任务

---

- **目标**: 熟悉RISC-V RV32I的指令特点，了解控制器的原理，设计并测试控制器
- **任务一**: 用硬件描述语言设计实现控制器
  - 根据Exp04-1数据通路及指令编码完成控制信号真值表
  - 此实验在Exp04-1的基础上完成，替换Exp04-1的控制器核
- **任务二**: 设计控制器测试方案并完成测试
  - OP译码测试：R-格式、访存指令、分支指令，转移指令
  - 运算控制测试：Function译码测试

---

# RISC-V RV32I控制器的原理介绍

# CPU organization

## □ Digital circuit

- General circuits that controls logical event with logical gates -  
**-Hardware**



## □ Computer organization

- Special circuits that processes logical action with instructions  
**-Software**

# Control unit



- 控制单元
- 控制单元作为处理器的一部分，用以告诉数据通路需要做什么。包含了取指单元（PC及地址计算单元）、译码单元、控制单元（时序信号形成及微操作控制信号形成电路）、中断等

# 控制对象：数据通路结构



# Control unit---add



# Control unit---sw



# Control unit---lw



# Control unit---beq



# Control unit---jal



jal rd, immediate

$rd = pc + 4$

$pc \leftarrow pc + immediate$



# 控制信号定义

## □ 通路与操作控制

| 信号          | 源数目     | 功能定义        | 赋值0时动作            | 赋值1时动作                      | 赋值2时动作 |
|-------------|---------|-------------|-------------------|-----------------------------|--------|
| ALUSrc_B    | 2       | ALU端口B输入选择  | 选择源操作数寄存器2数据      | 选择32位立即数（符号扩展后）             | -      |
| MemToReg    | 3       | 寄存器写入数据选择   | 选择ALU输出           | 选择存储器数据                     | 选择PC+4 |
| Branch      | 2       | Beq指令目标地址选择 | 选择PC+4地址          | 选择转移目的地址<br>PC+imm (zero=1) | -      |
| Jump        | 3       | J指令目标地址选择   | 由Branch决定输出       | 选择跳转目标地址<br>PC+imm (JAL)    | -      |
| RegWrite    | -       | 寄存器写控制      | 禁止寄存器写            | 使能寄存器写                      | -      |
| MemRW       | -       | 存储器读写控制     | 存储器读使能，<br>存储器写禁止 | 存储器写使能，<br>存储器读禁止           | -      |
| ALU_Control | 000-111 | 3位ALU操作控制   | 参考表ALU_Control    |                             |        |
| ImmSel      | 000-111 | 3位立即数组合控制   | 参考表ImmSel         |                             |        |

# 主控制器信号真值表

| Inst[31:0]          | Banch | Jump | ImmSel | ALUSrc_B | ALU_Control | MemRW | RegWrite | MemtoReg |
|---------------------|-------|------|--------|----------|-------------|-------|----------|----------|
| <b>add</b>          | 0     | 0    | *      | Reg      | Add         | Read  | 1        | ALU      |
| <b>sub</b>          | 0     | 0    | *      | Reg      | Sub         | Read  | 1        | ALU      |
| <i>(R-R<br/>Op)</i> | 0     | 0    | *      | Reg      | (Op)        | Read  | 1        | ALU      |
| <b>addi</b>         | 0     | 0    | I      | Imm      | Add         | Read  | 1        | ALU      |
| <b>lw</b>           | 0     | 0    | I      | Imm      | Add         | Read  | 1        | Mem      |
| <b>sw</b>           | 0     | 0    | S      | Imm      | Add         | Write | 0        | *        |
| <b>beq</b>          | 0     | 0    | B      | Reg      | Sub         | Read  | 0        | *        |
| <b>beq</b>          | 1     | 0    | B      | Reg      | sub         | Read  | 0        | *        |
| <b>jal</b>          | 0     | 1    | J      | Imm      | *           | Read  | 1        | PC+4     |
| <b>lui</b>          | 0     | 0    | U      | Imm      | Add         | Read  | 1        | ALU      |

# ImmSel

## I-Format



## S-Format



## B-Format



# ImmSel



## U-Format



## J-Format



# ImmSel

| Instruction type | Instruction opcode[6:0] | Instruction operation                  | (sign-extend)immediate                                   | Imm Sel |
|------------------|-------------------------|----------------------------------------|----------------------------------------------------------|---------|
| I-type           | 0000011                 | Lw;lbu;lh;<br>lb;lhu                   | (sign-extend) instr[31:20]                               | 00      |
|                  | 0010011                 | Addi;slti;slti<br>u;xori;ori;a<br>ndi; |                                                          |         |
|                  | 1100111                 | jalr                                   |                                                          |         |
| S-type           | 0100011                 | Sw;sb;sh                               | (sign-extend)<br>instr[31:25],[11:7]                     | 01      |
| B-type           | 1100011                 | Beq;bne;blt<br>;bge;bltu;b<br>geu      | (sign-extend)<br>instr[31],[7],[30:25],[11:8],<br>1'b0   | 10      |
| J-type           | 1101111                 | jal                                    | (sign-extend)<br>instr[31],[19:12],[20],[30:21],1<br>'b0 | 11      |
| 2025/10/30       |                         |                                        | Chapter 6                                                | 19      |

# RV32I---encode

|                       |     |     |     |             |
|-----------------------|-----|-----|-----|-------------|
| imm[31:12]            |     |     | rd  | 0110111     |
| imm[31:12]            |     |     | rd  | 0010111     |
| imm[20:10:1 11:19:12] |     |     | rd  | 1101111     |
| imm[11:0]             | rs1 | 000 | rd  | 1100111     |
| imm[12:10:5]          | rs2 | rs1 | 000 | imm[4:1 11] |
| imm[12:10:5]          | rs2 | rs1 | 001 | imm[4:1 11] |
| imm[12:10:5]          | rs2 | rs1 | 100 | imm[4:1 11] |
| imm[12:10:5]          | rs2 | rs1 | 101 | imm[4:1 11] |
| imm[12:10:5]          | rs2 | rs1 | 110 | imm[4:1 11] |
| imm[12:10:5]          | rs2 | rs1 | 111 | imm[4:1 11] |
| imm[11:0]             | rs1 | 000 | rd  | 0000011     |
| imm[11:0]             | rs1 | 001 | rd  | 0000011     |
| imm[11:0]             | rs1 | 010 | rd  | 0000011     |
| imm[11:0]             | rs1 | 100 | rd  | 0000011     |
| imm[11:0]             | rs1 | 101 | rd  | 0000011     |
| imm[11:5]             | rs2 | rs1 | 000 | imm[4:0]    |
| imm[11:5]             | rs2 | rs1 | 001 | imm[4:0]    |
| imm[11:5]             | rs2 | rs1 | 010 | imm[4:0]    |
| imm[11:0]             | rs1 | 000 | rd  | 0010011     |
| imm[11:0]             | rs1 | 010 | rd  | 0010011     |
| imm[11:0]             | rs1 | 011 | rd  | 0010011     |
| imm[11:0]             | rs1 | 100 | rd  | 0010011     |
| imm[11:0]             | rs1 | 110 | rd  | 0010011     |
| imm[11:0]             | rs1 | 111 | rd  | 0010011     |

LUI  
AUIPC  
JAL

JALR

BEQ

BNE

BLT

BGE

BLTU

BGEU

LB

LH

LW

LBU

LHU

SB

SH

SW

ADDI

SLTI

SLTIU

XORI

ORI

ANDI

inst[30]

inst[14:12]

inst[6:2]

|         |       |     |     |    |         |      |
|---------|-------|-----|-----|----|---------|------|
| 0000000 | shamt | rs1 | 001 | rd | 0010011 | SLLI |
| 0000000 | shamt | rs1 | 101 | rd | 0010011 | SRLI |
| 0100000 | shamt | rs1 | 101 | rd | 0010011 | SRAI |
| 0000000 | rs2   | rs1 | 000 | rd | 0110011 | ADD  |
| 0100000 | rs2   | rs1 | 000 | rd | 0110011 | SUB  |
| 0000000 | rs2   | rs1 | 001 | rd | 0110011 | SLL  |
| 0000000 | rs2   | rs1 | 010 | rd | 0110011 | SLT  |
| 0000000 | rs2   | rs1 | 011 | rd | 0110011 | SLTU |
| 0000000 | rs2   | rs1 | 100 | rd | 0110011 | XOR  |
| 0000000 | rs2   | rs1 | 101 | rd | 0110011 | SRL  |
| 0100000 | rs2   | rs1 | 101 | rd | 0110011 | SRA  |
| 0000000 | rs2   | rs1 | 110 | rd | 0110011 | OR   |
| 0000000 | rs2   | rs1 | 111 | rd | 0110011 | AND  |

|      |      |      |              |       |       |         |           |
|------|------|------|--------------|-------|-------|---------|-----------|
| 0000 | pred | succ | 00000        | 000   | 00000 | 0001111 | I fence   |
| 0000 | 0000 | 0000 | 00000        | 001   | 00000 | 0001111 | I fence.i |
|      |      |      | 000000000000 | 00000 | 000   | 00000   | I fence.i |
|      |      |      | 000000000001 | 00000 | 000   | 00000   | I fence.i |
|      | csr  |      | rs1          | 001   | rd    | 1110011 | I fence.i |
|      | csr  |      | rs1          | 010   | rd    | 1110011 | I fence.i |
|      | csr  |      | rs1          | 011   | rd    | 1110011 | I fence.i |
|      | csr  |      | zimm         | 101   | rd    | 1110011 | I fence.i |
|      | csr  |      | zimm         | 110   | rd    | 1110011 | I fence.i |
|      | csr  |      | zimm         | 111   | rd    | 1110011 | I fence.i |

Instruction type encoded using only 9 bits  
inst[30], inst[14:12], inst[6:2]

特殊指令本实验暂不做考虑

# RV32I---decode

| Instruction<br>opcode | op      | Instruction<br>operation | Funct 3 | Funct7  | ALUop | Desired<br>ALU action | ALUControl |
|-----------------------|---------|--------------------------|---------|---------|-------|-----------------------|------------|
| R-type                | 0110011 | add                      | 000     | 0000000 | 10    | add                   | 010        |
|                       |         | sub                      | 000     | 0100000 |       | sub                   | 110        |
|                       |         | sll                      | 001     | 0000000 |       | sll                   | -          |
|                       |         | slt                      | 010     | 0000000 |       | slt                   | 111        |
|                       |         | sltu                     | 011     | 0000000 |       | sltu                  | -          |
|                       |         | xor                      | 100     | 0000000 |       | xor                   | 011        |
|                       |         | srl                      | 101     | 0000000 |       | srl                   | 101        |
|                       |         | sra                      | 101     | 0100000 |       | sra                   | -          |
|                       |         | or                       | 110     | 0000000 |       | or                    | 001        |
|                       |         | and                      | 111     | 0000000 |       | and                   | 000        |

# RV32I---decode

| Instruction<br>opcode | op      | Instruction<br>operation | Funct 3 | Funct7 | ALUop | Desired<br>ALU action | ALUControl |
|-----------------------|---------|--------------------------|---------|--------|-------|-----------------------|------------|
| S-Type                | 0100011 | sb                       | 000     | -      | 00    | add                   | 010        |
|                       |         | sh                       | 001     | -      |       | add                   | 010        |
|                       |         | sw                       | 010     | -      |       | add                   | 010        |
| Instruction<br>opcode | op      | Instruction<br>operation | Funct 3 | Funct7 | ALUop | Desired<br>ALU action | ALUControl |
| B-Type                | 1100011 | Beq                      | 000     | -      | 01    | sub                   | 110        |
|                       |         | Bne                      | 001     | -      |       | sub                   | 110        |
|                       |         |                          |         |        |       |                       |            |
|                       |         |                          |         |        |       |                       |            |
|                       |         |                          |         |        |       |                       |            |
|                       |         |                          |         |        |       |                       |            |
|                       |         |                          |         |        |       |                       |            |

# RV32I---decode

---

| Instruction<br>opcode | op      | Instruction<br>operation | Funct 3 | Funct7 | ALUop | Desired<br>ALU action | ALUControl |
|-----------------------|---------|--------------------------|---------|--------|-------|-----------------------|------------|
| U-Type                | 0110111 | lui                      | -       | -      | -     | --                    | -          |
|                       | 0010111 | auipc                    | -       | -      |       | -                     | -          |
| Instruction<br>opcode | op      | Instruction<br>operation | Funct 3 | Funct7 | ALUop | Desired<br>ALU action | ALUControl |
| J-Type                | 1101111 | jal                      | -       | -      | -     | -                     | -          |

# RV32I---decode

| Instruction<br>opcode | op      | Instruction<br>operation | Funct 3 | Funct7 | ALUop | Desired<br>ALU action | ALUControl |
|-----------------------|---------|--------------------------|---------|--------|-------|-----------------------|------------|
| I-Type                | 0000011 | Lb                       | -       | -      | 00    | add                   | 010        |
|                       |         | Lh                       | -       | -      |       | add                   | 010        |
|                       |         | Lw                       | 010     | -      |       | add                   | 010        |
|                       |         | Lbu                      | -       | -      |       | add                   | 010        |
|                       |         | lh                       | -       | -      |       | add                   | 010        |
|                       |         |                          |         |        |       |                       |            |

# RV32I---decode

| Instruction<br>opcode | op      | Instruction<br>operation | Funct 3 | Funct7  | ALUop | Desired<br>ALU action | ALUControl |
|-----------------------|---------|--------------------------|---------|---------|-------|-----------------------|------------|
| I-Type                | 0010011 | addi                     | 000     | -       | 11    | add                   | 010        |
|                       |         | slti                     | 010     | -       |       | slt                   | 111        |
|                       |         | sltiu                    | 011     | -       |       | sltu                  | -          |
|                       |         | xori                     | 100     | -       |       | xor                   | 011        |
|                       |         | ori                      | 110     | -       |       | or                    | 001        |
|                       |         | andi                     | 111     | -       |       | and                   | 000        |
|                       |         | slli                     | 001     | 0000000 |       | sll                   | -          |
|                       |         | srl                      | 101     | 0000000 |       | srl                   | 101        |
|                       |         | srai                     | 101     | 0100000 |       | sra                   | -          |

# ALU操作译码----多级译码



# CPU部件之控制器接口： SCPU\_ctrl

## □ SCPU\_ctrl

- CPU主要部件之一
- 寄存器传输控制者：编码转换成命令

## □ 基本功能

- 微控制控制
- 数据传输通道控制
- 时序控制：单周期时序在那里？

## □ 接口要求- SCPU\_ctrl

- 控制器接口信号如右图



# 控制器接口信号标准- SCPU\_ctrl.v

```
module SCPU_ctrl( input[4:0]OPcode,    //Opcode-----inst[6:2]
                  input[2:0]Fun3,      //Function-----inst[14:12]
                  input   Fun7,       //Function-----inst[30]
                  input MIO_ready,   //CPU Wait
                  output reg [1:0]ImmSel, //立即数选择控制
                  output reg ALUSrc_B, //源操作数2选择
                  output reg MemtoReg, //写回数据选择控制
                  output reg Jump,    //jal
                  output reg Branch,  //beq
                  output reg RegWrite, //寄存器写使能
                  output reg MemRW,   //存储器读写使能
                  output reg [2:0]ALU_Control, //alu控制
                  output reg CPU_MIO //not use
                );
endmodule
```

---

## ■ 任务一：用硬件描述语言设计实现控制器

- 根据Exp04-1数据通路及指令编码完成控制信号真值表
- 此实验在Exp04-1的基础上完成，替换Exp04-1的控制器核

---

# CPU之控制器设计

## -控制04-1设计的数据通路

# 设计工程：OExp04-SCPU\_ctrl

---

## ○ 设计CPU之控制器

- ⌚ 根据理论课分析讨论设计数据通路的的控制器
- ⌚ 采用HDL描述
- ⌚ 仿真测试控制器模块

## ○ 集成替换验证通过的数据通路模块

- ⌚ 替换 (Exp04-1)中的SCPU\_ctrl核
- ⌚ 顶层模块延用Exp04

## ○ 测试控制器模块

- ⌚ 设计测试程序(RISCV汇编)测试：
- ⌚ OP译码测试：
  - ⌚ R-格式、访存指令、分支指令，转移指令
- ⌚ 运算控制测试：Function译码测试

# 设计要点

---

## □ 设计主控制器模块

- 写出控制器的函数表达式
- 结构描述实现电路

## □ 设计ALU操作译码

- 写出ALU操作译码函数表达式
- 结构描述实现电路
- 使用DEMO作功能初步调试

## □ 仿真二个控制器电路模块

- 可以单独或合并仿真，但最后要合并为一个控制模块

# 主控制器HDL描述结构

## □ 指令译码器参考描述

```
'define CPU_ctrl_signals {ALUSrc_B,MemtoReg,RegWR,MemWrite,Branch,Jump,ALUop}
  always @* begin
    case(OPcode)
      5'b01100: begin CPU_ctrl_signals = ?; end      //ALU
      5'b00000: begin CPU_ctrl_signals = ?; end      //load
      5'b01000: begin CPU_ctrl_signals = ?; end      //store
      5'b11000: begin CPU_ctrl_signals = ?; end      //beq
      5'b11011: begin CPU_ctrl_signals = ?; end      //jump
      5'b00100: begin CPU_ctrl_signals = ?; end      //ALU(addi;;;;)
      .....
    default:   begin CPU_ctrl_signals = ?; end
  endcase
end
```

某些指令仅需部分控制信号，  
无关信号可赋定值，避免组合  
逻辑赋值不完整而生成latch

# ALU操作译码器HDL描述结构

## □ ALU控制器参考描述

```
assign Fun = {Fun3,Fun7};  
always @* begin  
    case(ALUop)  
        2'b00: ALU_Control = ? ; //add计算地址  
        2'b01: ALU_Control = ? ; //sub比较条件  
        2'b10:  
            case(Fun)  
                4'b0000: ALU_Control = 3'b010 ; //add  
                4'b0001: ALU_Control = ? ; //sub  
                4'b1110: ALU_Control = ? ; //and  
                4'b1100: ALU_Control = ? ; //or  
                4'b0100: ALU_Control = ? ; //slt  
                4'b1010: ALU_Control = ? ; //srl  
                4'b1000: ALU_Control = ? ; //xor  
                .....  
            default: ALU_Control=3'bx;  
        endcase  
        2'b11:  
            case(Fun3)  
                .....  
        endcase
```

# 控制器仿真激励代码参考

```
initial begin
    // Initialize Inputs
    OPcode = 0;
    Fun = 0;
    MIO_ready = 0;
    #40;
    // Wait 40 ns for global reset to finish。以上是测试模板代码。
    // Add stimulus here
    //检查输出信号和关键信号输出是否满足真值表
    OPcode = 5'b01100; //ALU指令, 检查ALUop=2'b10; RegWrite=1
    Fun3 = 3'b000; Fun7 = 1'b0;//add, 检查ALU_Control=3'b010
    #20;
    Fun3 = 3'b000; Fun7 = 1'b1;//sub, 检查ALU_Control=3'b110
    #20;
    Fun3 = 3'b111; Fun7 = 1'b0;//and, 检查ALU_Control=3'b000
    #20;
    Fun3 = 3'b110; Fun7 = 1'b0;//or, 检查ALU_Control=3'b001
    #20;
    Fun3 = 3'b010; Fun7 = 1'b0 ;//slt, 检查ALU_Control=3'b111
    #20;
```

# 控制器仿真激励代码参考

```
#20;
Fun3 = 3'b101; Fun7 = 1'b0    //srl, 检查ALU_Control=3'b101
#20;
Fun3 = 3'b100; Fun7 = 1'b0    //xor, 检查ALU_Control=3'b011
#20;
Fun3 = 3'b111; Fun7 = 1'b1;  //间隔
#1;
OPcode = 5'b00000;           //load指令, 检查ALUop=2'b00,
#20;                         // ALUSrc_B=1, MemtoReg=1, RegWrite=1
OPcode = 5'b01000;
#20;                         //store指令, 检查ALUop=2'b00, MemRW=1, ALUSrc_B=1
OPcode = 5'b11000;//beq指令, 检查ALUop=2'b01, Branch=1
#20;
OPcode = 5'b11011;           //jump指令, 检查Jump=1
OPcode = 5'b00100;           //l指令, 检查ALUop=2'b11; RegWrite=1
#20;
Fun3 = 3'b000;               //addi, 检查ALU_Control=3'b010
.....
#20;
OPcode = 5'h1f;              //间隔
Fun3 = 3'b000; Fun7 = 1'b0;//间隔
end
```

# 控制器模块时序仿真参考



# 控制器集成替换、CPU集成替换

## □ 控制器集成替换

- 仿真正确后替换Exp04-1的控制器IP核

## □ CPU集成替换

- 仿真正确后替换SOC系统中的CPU

## □ 集成和替换方法与lab04-1相同

控制器和数据  
通路模块采  
用.v的形式直  
接调用

A hierarchical list of components under U1 and U2. U1 contains SCPU (2 instances) and SCPU\_ctrl (1 instance). U2 contains DataPath (11 instances) and various logic blocks like ALU\_U, AND2, ImmGen\_U, MUX0, MUX1, MUX2, MUX3, PC, Regs\_U, and add32\_0, add32\_1. The SCPU\_ctrl component is highlighted with a red dashed border.

- U1 : SCPU (SCPU.v) (2)
  - U1 : SCPU\_ctrl (SCPU\_ctrl.v)
- U2 : DataPath (DataPath.v) (11)
  - ALU\_U : ALU (Alu.v)
  - AND2 : AND (AND.v)
  - ImmGen\_U : ImmGen (ImmGen.v)
  - MUX0 : MUX2T1\_32 (MUX2T1\_32.v)
  - MUX1 : MUX2T1\_32 (MUX2T1\_32.v)
  - MUX2 : MUX2T1\_32 (MUX2T1\_32.v)
  - MUX3 : MUX4T1\_32 (MUX4T1\_32.v)
  - PC : REG32 (REG32.v)
  - Regs\_U : Regs (Regs.v)
  - add32\_0 : add\_32 (add\_32.v)
  - add32\_1 : add\_32 (add\_32.v)

# CPU集成后功能仿真

## □ CPU设计并集成后，应进行功能仿真

- 利用CPU（本实验设计）、RAM、ROM可以搭建如下图的仿真平台，初始化RAM的数据，初始化ROM的指令（可自行选择设计），可以完成CPU各种类型指令的执行，查看CPU数据的输入和输出，以及底层的包括寄存器在内的个模块的状态。（参考原理图进行verilog描述）

所有CPU组件应均为包含源文件形式，不能包含EDF文件



# CPU集成后功能仿真

- 仿真平台搭建完成，编写Testbench开始仿真
  - 由于外部端口只有clk,rst，需要在Scope窗口添加观察信号



# CPU集成后功能仿真

- 在Scope窗口下点击子模块，右键Add to wave window添加信号到波形窗口



# CPU集成后功能仿真

- 观察PC地址下对应的指令内容，分析指令的执行情况判断CPU功能正确与否
- 待观察信号可自由添加



- 
- 任务二：设计控制器测试方案并完成测试
    - OP译码测试：R-格式、访存指令、分支指令，转移指令
    - 运算控制测试：Function译码测试

# 物理验证

---

## □ 使用**DEMO**程序目测控制器功能

- DEMO接口功能

- SW[8]=0, SW[2]=0(全速运行)
- SW[8]=0, SW[2]=1(自动单步)
- SW[8]=1, SW[2]=x(手动单步)
- SW[10], 从0到1 (手动单步)

## □ 用汇编语言设计测试程序

- 测试ALU指令(R-格式译码、Function译码)
- 测试LW指令(I-格式译码)
- 测试SW指令(S-格式译码)
- 测试分支指令(B-格式译码)
- 测试转移指令(J-格式译码)

# 物理验证

## □ 使用DEMO程序目测数据通路功能

### ■ DEMO接口功能

- SW[8]=1(手动单步运行) 液晶屏显示CPU信息

```
RV32I Single Cycle CPU

pc: 00000000 inst: 00100093

x0: 00000000 ra: 00000000 sp: 00000000 gp: 00000000
t0: 00000000 t1: 00000000 t2: 00000000 s0: 00000000
a0: 00000000 a1: 00000000 a2: 00000000 a3: 00000000
a5: 00000000 a6: 00000000 a7: 00000000 s2: 00000000
s4: 00000000 s5: 00000000 s6: 00000000 s7: 00000000
s9: 00000000 s10: 00000000 s11: 00000000 t3: 00000000
t5: 00000000 t6: 00000000

rs1: 00 rs1_val: 00000000
rs2: 00 rs2_val: 00000000
rd: 00 reg_i_data: 00000000 reg_wen: 0

is_imm: 0 is_auipc: 0 is_lui: 0 imm: 00000000
a_val: 00000000 b_val: 00000000 alu_ctrl: 0 cmp_ctrl: 0
alu_res: 00000001 cmp_res: 0

is_branch: 0 is_jal: 0 is_jalr: 0
do_branch: 0 pc_branch: 00000000

mem_wen: 0 mem_ren: 0
dmem_o_data: f0000000 dmem_i_data: 00000000 dmem_addr: 0
dmem_wen: 0

csr_wen: 0 csr_ind: 000 csr_ctrl: 0 csr_r_data: 00000000
mstatus: 00000000 mcause: 00000000 mepc: 00000000 mtval: 0
mtvec: 00000000 mie: 00000000 mip: 00000000
```

# 物理验证-DEMO接口功能



# 测试程序参考：ALU指令

## □ 设计ALU指令测试程序替换DEMO程序

- ALU、Regs测试参考设计，测试结果通过CPU输出信号单步观察
- SW[7:5]=100, Addr\_out = ALU输出
- SW[7:5]=101, Data\_out= 寄存器B输出

```
#baseAddr 0000
loop:    addi x1,x0,1;      //x1=00000001
          slt  x2,x0,x1;    //x2=00000001
          add  x3,x2,x2;    //x3=00000002
          add  x4,x3,x3;    //x4=00000004
          add  x5,x4,x2;    //x5=00000005
          add  x6,x5,x5;    //x6=0000000A
          sub  x7,x6,x5;    //x7=00000005
          and  x8,x7,x5;    //x9=0000000A
          sub  x10,x8,x6;   //x10=00000000
          or   x11,x5,x6;   //x11=0000000F
          or   x12,x11,x7;  //x12=0000000A
          slt  x13,x7,x7;  //x13=00000000
          .....
          beq  x0,x0, loop;
```

# 测试程序参考： LW/SW

## □ 设计LW/SW程序替换DEMO程序

- 参考04-1通道测试设计。测试结果通过CPU输出信号单步观察
- 存储器地址通过Addr\_out通道4观察：13+x0

```
#baseAddr 0000
start:                                //通道结果由后一条指令读操作数观察
    lw  x5, 0x34(x0);                //取测试常数55555555。存储器读通道
start_A:
    add x1, x5, x0;                //r1: 寄存器写通道。R5:寄存器读通道A输出
    xor x2, x0, x1;                //r1: 寄存器读通道B输出。R2:ALU输出通道
    lw  x5, 0x48(x0);              //取测试常数AAAAAAA。立即数通道:00000048
    beq x2, x5 test_sw;           //循环测试
    jal  x0, start;                //循环测试。
test_sw: .....                         //增加写SW测试，如34和48单元交换
    beq x0,x0,start;               //循环测试。立即数通道： 00000014
```

## □ 测试的完备性

- 上述测试正确仅表明地址计算、存储单元和总线传输部分正确
- 要测试其完全正确，必须遍历所有可能的情况

# 动态LW/SW测试 (reserve)

## □ 利用七段显示设备可以设计动态测试程序

- 7段码显示器的地址是E0000000/FFFFFE0
- LED显示地址是F0000000/FFFFFF00
- SW指令输出测试结果: sw
- 请设计存储器模块测试程序
  - 测试结果在7段显示器上指示

## □ RAM初始化数据同Exp0

F0000000, 000002AB, 80000000, 0000003F, 00000001, FFF70000,  
0000FFFF, 80000000, 00000000, 11111111, 22222222, 33333333,  
44444444, 55555555, 66666666, 77777777, 88888888, 99999999,  
aaaaaaaa, bbbbbbbb, cccccccc, dddddddd, eeeeeeee, FFFFFFFF,  
**557EF7E0, D7BDFBD9, D7DBFDB9, DFCFFCFB, DFCFBFFF, F7F3DFFF,**  
**FFFFDF3D, FFFF9DB9, FFFFBCFB, DFCFFCFB, DFCFBFFF, D7DB9FFF,**  
**D7DBFDB9, D7BDFBD9, FFFF07E0, 007E0FFF, 03bdf020, 03def820,**  
**08002300;**

# 设计测试记录表格

---

## □ ALU指令测试结果记录

- 自行设计记录表格

## □ LW/SW指令测试结果记录

- 自行设计记录表格

## □ 动态存储模块测试记录

- 自行设计记录表格

# 思考题

---

- 单周期控制器时序体现在那里？
- 设计bne指令需要增加控制信号吗？
- 扩展下列指令， 控制器将作如何修改：

R-Type: sra, sll, sltu;

I-Type: srai, slli, sltiu

B-Type: bne;

U-Type: lui;

- 此时用二级译码有优势吗？
- 动态存储模块测试七段显示会出现什么问题？

---

 **END**