

Computer Organization & Design实验与课程设计

# Lab04-0

## 集成CPU核

### -IP核设计CPU/IP2CPU

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. 熟练掌握IP核的使用方法

# 实验环境

---

## □ 实验设备

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

## □ 材料

无

# 实验目标及任务

---

- **目标**: 熟悉SOC系统的原理，掌握IP核集成设计CPU的方法
- **任务**: 利用数据通路和控制器两个IP核集成设计CPU（根据原理图采用RTL代码方式）

- 
- 任务：利用数据通路和控制器两个IP核集成设计CPU

# Computer Organization

## □ Decomposability of computer systems



# Digital circuits vs CPU organization

## □ Digital circuit

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

Data input



## □ Computer organization

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

# CPU部件之1-数据通路： Data\_path

## □ Data\_path

- CPU主要部件之一
- 寄存器传输控制对象：通用数据通路

## □ 基本功能

- 具有通用计算功能的算术逻辑部件
- 具有通用目的寄存器
- 具有通用计数所需的尽可能的路径

## □ 本实验用IP 软核- Data\_path

- 核调用模块Data\_path.veo
- 核接口信号模块(空文档): Data\_path.v



# 数据通路空模块- Data\_path.v

---

```
module Data_path( input clk,           //时钟
                  input rst,            //复位
                  input[31:0]inst_field, //指令数据域[31:7]
                  input ALUSrc_B,
                  input [1:0]MemtoReg,
                  input [1:0] ImmSel,
                  input Jump,
                  input Branch,
                  input RegWrite,
                  input[31:0]Data_in,
                  input[2:0]ALU_Control,
                  output[31:0]ALU_out,
                  output[31:0]Data_out,
                  output[31:0]PC_out
                );
endmodule
```

# CPU部件之2-控制器： SCPU\_ctrl

## □ SCPU\_ctrl

- CPU主要部件之一
- 寄存器传输控制技术中的运算和通路控制器：

## □ 基本功能

- 指令译码
- 产生操作控制信号： ALU运算控制
- 产生指令所需的路径选择

## □ 本实验用IP 软核- SCPU\_ctrl

- 核调用模块SCPU\_ctrl.veo
- 核接口信号模块(空文档): SCPU\_ctrl.v



# 控制器接口文档- 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,
                  output reg[1:0]MemtoReg,
                  output reg Jump,
                  output reg Branch,
                  output reg RegWrite,
                  output reg MemRW,
                  output reg [2:0]ALU_Control,
                  output reg CPU_MIO
                );
endmodule
```

---

# RTL集成设计实现CPU

# 设计工程： OExp04-IP2CPU

## ◎ 分解CPU为二个IP核

- └ 用二个IP核构建CPU
- └ 顶层工程名称延用OExp04-IP2CPU
  - ◎ 顶层模块名： SCPU.v



---

# 添加二个核的封装文件到当前工程IP库目录：



# 逻辑原理图



# 用RTL代码描述CPU设计 SCPU.v

- 利用verilog描述，在SCPU.v顶层进行模块调用和连接

```
module SCPU(
    input wire clk,
    input wire rst,
    input wire MIO_ready,
    input wire[31:0] inst_in,
    input wire[31:0] Data_in,
    output wire CPU_MIO,
    output wire MemRW,
    output wire[31:0] PC_out,
    output wire[31:0] Data_out,
    output wire[31:0] Addr_out
);
    SCPU_ctrl1 U1(
        .OPcode      (inst_in[6:2]  ),
        .Fun3        (inst_in[14:12]),
        .Fun7        (inst_in[30]   ),
        .MIO_ready   (MIO_ready    ),
        .ImmSel      (ImmSel       ),
        .ALUSrc_B    (ALUSrc_B    ),
        .MemtoReg    (MemtoReg    ),
        .Jump         (Jump         ),
        .Branch       (Branch       ),
        .RegWrite    (RegWrite    ),
        .MemRW       (MemRW       ),
        .ALU_Control (ALU_Control ),
        .CPU_MIO     (CPU_MIO     )
);

```

# CPU集成设计后的层次关系

Exp04完成CPU设计后  
的模块调用关系

The screenshot shows a VHDL editor interface with two main panes. The left pane is titled 'Sources' and displays the module hierarchy. A red dashed box highlights the 'Design Sources (1)' section, which contains a single item: 'SCPU (SCPU.v) (4)'. This item is also highlighted with a red dashed box. Below it are four sub-items: 'U1 : SCPU\_ctrl (SCPU\_ctrl.v)', 'U1 : SCPU\_ctrl (SCPU\_ctrl.edf)', 'U2 : DataPath (DataPath.v)', and 'U2 : DataPath (DataPath.edf)'. The right pane shows the source code for 'SCPU.v'. A red dashed box surrounds the entire code area. The code defines a module 'SCPU\_ctrl1' with several port mappings:

```
40     wire      Branch;
41     wire      RegWrite;
42     wire [2:0] ALU_Control;
43
44     SCPU_ctrl1 U1(
45         .OPcode    (inst_in[6:2]  ),
46         .Fun3     (inst_in[14:12]),
47         .Fun7     (inst_in[30]   ),
48         .MIO_ready (MIO_ready  ),
49         .ImmSel   (ImmSel     ),
50         .ALUSrc_B (ALUSrc_B  ),
51         .MemtoReg (MemtoReg  ),
```

Below the code, a red box contains the text: '采用直接添加源文件的方式'.

---

 **END**