



XD-LAB-ARCH-005

# Lab5: Pipelined CPU supporting 31 MIPS Instructions

Joseph Xu

2019-1-23

## 修改记录

| 版本号. | 作者        | 描述 | 修改日期       |
|------|-----------|----|------------|
| 1.0  | Joseph Xu | 初稿 | 2019-01-23 |
|      |           |    |            |
|      |           |    |            |
|      |           |    |            |
|      |           |    |            |

## 审核记录

| 姓名 | 职务 | 签字 | 日期 |
|----|----|----|----|
|    |    |    |    |
|    |    |    |    |
|    |    |    |    |
|    |    |    |    |
|    |    |    |    |

|                                                                                     |                                                     |                 |           |         |
|-------------------------------------------------------------------------------------|-----------------------------------------------------|-----------------|-----------|---------|
|  | 标题                                                  | 文档编号            | 版本        | 页       |
|                                                                                     | Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0       | 1 of 46 |
| 作者                                                                                  | Joseph Xu                                           | 修改日期            | 2019/1/23 | 公开      |

## 目录

|                            |    |
|----------------------------|----|
| 修改记录 .....                 | 0  |
| 审核记录 .....                 | 1  |
| 1. 实验准备 .....              | 6  |
| 1. 1 实验目的 .....            | 6  |
| 1. 2 实验内容 .....            | 6  |
| 1. 3 实验资料 .....            | 7  |
| 2. 实验步骤 .....              | 9  |
| 2. 1 新建工程 .....            | 9  |
| 2. 1 修改文件 .....            | 11 |
| 2. 2 功能仿真 .....            | 25 |
| 2. 3 生成 bitstream 文件 ..... | 40 |
| 2. 4 下载验证 .....            | 42 |

| 标题                                                                 | 文档编号              | 版本  | 页       |
|--------------------------------------------------------------------|-------------------|-----|---------|
| XINGDENG<br>Lab5: Pipelined CPU supporting 31<br>MIPS Instructions | XD-LAB-ARCH-005   | 1.0 | 2 of 46 |
| 作者<br>Joseph Xu                                                    | 修改日期<br>2019/1/23 | 公开  |         |

## 图目录

|                                 |    |
|---------------------------------|----|
| 图 1-1 扩充后的 31 条 MIPS 指令格式 ..... | 6  |
| 图 1-2 实验资料网站 .....              | 7  |
| 图 1-3 实验文档和工程源文件 .....          | 7  |
| 图 2-1 运行 Vivado .....           | 9  |
| 图 2-2 打开工程 .....                | 9  |
| 图 2-3 打开 Lab04 工程 .....         | 10 |
| 图 2-4 工程另存为 .....               | 10 |
| 图 2-5 工程另存为 lab05 .....         | 11 |
| 图 2-6 需要修改的 lab05 工程 .....      | 11 |
| 图 2-7 点击 Expand All 快捷按钮 .....  | 12 |
| 图 2-8 mips_top 展开后的文件层次 .....   | 12 |
| 图 2-9 移除 controller.v 文件 .....  | 13 |
| 图 2-10 确认移除文件 .....             | 13 |
| 图 2-11 移除 CONTROLLER 后的视图 ..... | 13 |
| 图 2-12 移除所有旧文件后的源码层次 .....      | 14 |
| 图 2-13 添加新文件 .....              | 14 |
| 图 2-14 增加 design sources .....  | 15 |
| 图 2-15 Add Files .....          | 15 |
| 图 2-16 切换目录 .....               | 16 |
| 图 2-17 选择文件 .....               | 16 |
| 图 2-18 lab06 添加的文件 .....        | 17 |
| 图 2-19 继续添加 hex 文件 .....        | 17 |
| 图 2-20 Next .....               | 18 |
| 图 2-21 添加文件 .....               | 18 |
| 图 2-22 指定全部类型文件可见 .....         | 19 |
| 图 2-23 切换目录 .....               | 19 |
| 图 2-24 选择 hex 文件 .....          | 20 |
| 图 2-25 增加到工程 .....              | 20 |
| 图 2-26 设置文件类型 .....             | 21 |
| 图 2-27 设置类型为 Data Files .....   | 21 |
| 图 2-28 设置文件类型 .....             | 22 |

| XINGDENG | 标题                                                  | 文档编号            | 版本  | 页       |
|----------|-----------------------------------------------------|-----------------|-----|---------|
|          | Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 3 of 46 |
| 作者       | 修改日期                                                |                 |     |         |
|          | Joseph Xu                                           | 2019/1/23       |     | 公开      |

|                                                |    |
|------------------------------------------------|----|
| 图 2-29 设置类型为 Data Files .....                  | 22 |
| 图 2-30 Refresh Hierarchy .....                 | 23 |
| 图 2-31 Data Files .....                        | 23 |
| 图 2-32 添加所有文件后的文件列表.....                       | 24 |
| 图 2-33 设置仿真顶层.....                             | 25 |
| 图 2-34 开始仿真.....                               | 25 |
| 图 2-35 仿真视图.....                               | 26 |
| 图 2-36 仿真所需要观察的所有信号.....                       | 27 |
| 图 2-37 菜单中选择“Open Waveform Configuration”..... | 28 |
| 图 2-38 切换目录.....                               | 28 |
| 图 2-39 选择 wcfg 文件.....                         | 29 |
| 图 2-40 加载波形配置文件后的波形列表视图 .....                  | 29 |
| 图 2-41 Restart Simulation.....                 | 30 |
| 图 2-42 Run for... .....                        | 30 |
| 图 2-43 仿真结果 1.....                             | 31 |
| 图 2-45 仿真结果 2.....                             | 32 |
| 图 2-46 仿真结果 3.....                             | 33 |
| 图 2-47 仿真结果 4.....                             | 34 |
| 图 2-48 仿真结果 5.....                             | 35 |
| 图 2-49 仿真结果 6.....                             | 36 |
| 图 2-50 仿真结果 7.....                             | 37 |
| 图 2-51 仿真结果 8.....                             | 38 |
| 图 2-52 关闭仿真视图.....                             | 39 |
| 图 2-53 生成 bitstream.....                       | 40 |
| 图 2-54 自动运行中间步骤.....                           | 40 |
| 图 2-55 生成 bitstream 成功 .....                   | 41 |
| 图 2-56 连接 SWORD4.0.....                        | 42 |
| 图 2-57 主要控制 IO .....                           | 43 |
| 图 2-58 进入 Hardware Manager .....               | 43 |
| 图 2-59 自动连接到 SWORD4.0 .....                    | 44 |
| 图 2-60 Program Device .....                    | 44 |
| 图 2-61 下载 bit 文件 .....                         | 45 |

| XINGDENG | 标题                                                  | 文档编号            | 版本  | 页       |
|----------|-----------------------------------------------------|-----------------|-----|---------|
|          | Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 4 of 46 |
|          | 作者                                                  | 修改日期            |     |         |
|          | Joseph Xu                                           | 2019/1/23       |     | 公开      |

---

图 2-62 运行效果.....45

|                                                                                     |                                                     |                 |           |         |
|-------------------------------------------------------------------------------------|-----------------------------------------------------|-----------------|-----------|---------|
|  | 标题                                                  | 文档编号            | 版本        | 页       |
|                                                                                     | Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0       | 5 of 46 |
| 作者                                                                                  | Joseph Xu                                           | 修改日期            | 2019/1/23 | 公开      |

## 1. 实验准备

### 1.1 实验目的

在实验 4 的基础上，将 CPU 支持的指令数量从 16 条扩充为 31 条，使处理器功能更加丰富。其中增加的指令如下图所示（图中红色指令为扩充指令）：

| No. | Bit #  | 31..26 | 25..21  | 20..16 | 15..11    | 10..6 | 5..0   |  |  |  |
|-----|--------|--------|---------|--------|-----------|-------|--------|--|--|--|
|     | R-type | op     | rs      | rt     | rd        | sa    | func   |  |  |  |
| 1   | add    | 000000 | rs      | rt     | rd        | 00000 | 100000 |  |  |  |
| 2   | addu   |        | rs      | rt     | rd        | 00000 | 100001 |  |  |  |
| 3   | sub    |        | rs      | rt     | rd        | 00000 | 100010 |  |  |  |
| 4   | subu   |        | rs      | rt     | rd        | 00000 | 100011 |  |  |  |
| 5   | and    |        | rs      | rt     | rd        | 00000 | 100100 |  |  |  |
| 6   | or     |        | rs      | rt     | rd        | 00000 | 100101 |  |  |  |
| 7   | xor    |        | rs      | rt     | rd        | 00000 | 100110 |  |  |  |
| 8   | nor    |        | rs      | rt     | rd        | 00000 | 100111 |  |  |  |
| 9   | slt    |        | rs      | rt     | rd        | 00000 | 101010 |  |  |  |
| 10  | sltu   |        | rs      | rt     | rd        | 00000 | 101011 |  |  |  |
| 11  | sll    |        | 00000   | rt     | rd        | sa    | 000000 |  |  |  |
| 12  | srl    |        | 00000   | rt     | rd        | sa    | 000010 |  |  |  |
| 13  | sra    |        | 00000   | rt     | rd        | sa    | 000011 |  |  |  |
| 14  | sllv   |        | rs      | rt     | rd        | 00000 | 000100 |  |  |  |
| 15  | srlv   |        | rs      | rt     | rd        | 00000 | 000110 |  |  |  |
| 16  | srav   |        | rs      | rt     | rd        | 00000 | 000111 |  |  |  |
| 17  | jr     |        | rs      | 00000  | 00000     | 00000 | 001000 |  |  |  |
|     | I-type | op     | rs      | rt     | immediate |       |        |  |  |  |
| 18  | addi   | 001000 | rs      | rt     | imm       |       |        |  |  |  |
| 19  | addiu  | 001001 | rs      | rt     | imm       |       |        |  |  |  |
| 20  | andi   | 001100 | rs      | rt     | imm       |       |        |  |  |  |
| 21  | ori    | 001101 | rs      | rt     | imm       |       |        |  |  |  |
| 22  | xori   | 001110 | rs      | rt     | imm       |       |        |  |  |  |
| 23  | lui    | 001111 | 00000   | rt     | imm       |       |        |  |  |  |
| 24  | lw     | 100011 | rs      | rt     | imm       |       |        |  |  |  |
| 25  | sw     | 101011 | rs      | rt     | imm       |       |        |  |  |  |
| 26  | beq    | 000100 | rs      | rt     | imm       |       |        |  |  |  |
| 27  | bne    | 000101 | rs      | rt     | imm       |       |        |  |  |  |
| 28  | slti   | 001010 | rs      | rt     | imm       |       |        |  |  |  |
| 29  | sltiu  | 001011 | rs      | rt     | imm       |       |        |  |  |  |
|     | J-type | op     | address |        |           |       |        |  |  |  |
| 30  | j      | 000010 | address |        |           |       |        |  |  |  |
| 31  | jal    | 000011 | address |        |           |       |        |  |  |  |

图 1-1 扩充后的 31 条 MIPS 指令格式

### 1.2 实验内容

本实验内容包括：

|                 |                                                     |                 |           |         |
|-----------------|-----------------------------------------------------|-----------------|-----------|---------|
| <b>XINGDENG</b> | 标题                                                  | XD-LAB-ARCH-005 | 1.0       | 6 of 46 |
|                 | Lab5: Pipelined CPU supporting 31 MIPS Instructions |                 |           |         |
| 作者              | Joseph Xu                                           | 修改日期            | 2019/1/23 | 公开      |

- 修改设计 CPU 的数据通路 Datapath 和控制单元 Controller；
- 对设计的 CPU 进行行为仿真，检查功能正确性；
- 上板验证并观察 CPU 的执行过程。

### 1.3 实验资料

实验资料可以从网站 <https://gitee.com/SWORDfpga/ComputerArchitecture> 获得。



图 1-2 实验资料网站

为方便使用，建议建立 c:\archlabs 目录，放置实验资料和实验工程。



图 1-3 实验文档和工程源文件

| 标题                                                  | 文档编号            | 版本  | 页       |
|-----------------------------------------------------|-----------------|-----|---------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 7 of 46 |
| 作者                                                  | 修改日期            |     |         |
| Joseph Xu                                           | 2019/1/23       |     | 公开      |

|                                                                                     |                                                     |                 |           |         |
|-------------------------------------------------------------------------------------|-----------------------------------------------------|-----------------|-----------|---------|
|  | 标题                                                  | 文档编号            | 版本        | 页       |
|                                                                                     | Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0       | 8 of 46 |
| 作者                                                                                  | Joseph Xu                                           | 修改日期            | 2019/1/23 | 公开      |

## 2. 实验步骤

### 2.1 新建工程

首先启动 Vivado 2014.4 开发工具，如图 2-1 所示：



图 2-1 运行 Vivado

点击 Open Project，如图 2-2 所示：



图 2-2 打开工程

| 标题                                                  | 文档编号            | 版本  | 页       |
|-----------------------------------------------------|-----------------|-----|---------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 9 of 46 |
| 作者                                                  | 修改日期            |     |         |
| Joseph Xu                                           | 2019/1/23       |     | 公开      |

选择之前已经完成的 Lab04 工程，点击 OK 打开工程，如图 2-3 所示：



图 2-3 打开 Lab04 工程

本实验以 Lab04 工程为基础，在 File 菜单点击 **Save Project As** 将工程另存为，如图 2-4 所示：



图 2-4 工程另存为

输入新工程名 lab05，选中 **Create project subdirectory**，点击 OK 继续，如图 2-5 所示：

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 10 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       |     | 公开       |



图 2-5 工程另存为 lab05

如图 2-6 所示，工程被另存为 lab05，本实验将以此工程为基础进行修改。



图 2-6 需要修改的 lab05 工程

## 2.1 修改文件

在 Project Manager 窗口下，首先点击 mips\_top，然后点击如图 2-7 所示的 Expand

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 11 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       |     | 公开       |

All 快捷按钮展开 mips\_top 下的所有文件：



图 2-7 点击 Expand All 快捷按钮

展开后的层次如图 2-8 所示：



图 2-8 mips\_top 展开后的文件层次

由于本实验在 lab04 的基础上需要修改和新增一些文件，所以我们进行如下一些移除旧文件，添加更新文件的操作：

首先移除 controller.v 文件：右键点击 **CONTROLLER**，点击 **Remove File from Project** 继续，如图 2-9 所示：

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 12 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       |     | 公开       |



图 2-9 移除 controller.v 文件

选中 **Also delete the project local file/directory form disk**，点击 **OK** 继续，如图 2-10 所示：



图 2-10 确认移除文件

移除后的视图如图 2-11 所示：



图 2-11 移除 CONTROLLER 后的视图

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 13 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       | 公开  |          |

接着按照上面的移除文件方式，将下列文件依次移除：

- 1) inst\_mem.hex
- 2) data\_mem.hex
- 3) alu.v
- 4) datapath.v
- 5) mips\_core.v
- 6) mips\_define.vh

移除后的文件列表应如图 2-12 所示，请仔细比对该图，确保所有旧文件都已经移除 !!



图 2-12 移除所有旧文件后的源码层次

接着在 Sources 窗口内点击 Add Sources 快捷按钮，添加新文件，如图 2-13 所示。



图 2-13 添加新文件

选中 Add or create design sources，点击 Next，如图 2-14 所示。

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 14 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       |     | 公开       |



图 2-14 增加 design sources

点击 Add Files , 如图 2-15 所示 :



图 2-15 Add Files

进入 C:\archlabs\ComputerArchitecture\lab\_source\lab05\sources\cpu 目录 , 如图 2-16 所示 :

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 15 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       |     | 公开       |



图 2-16 切换目录

选中所有文件，点击回车确认添加，如图 2-17 所示。



图 2-17 选择文件

如图 2-18 所示，列表中会显示要添加到工程中的文件，本次操作添加了 5 个文件，请确认添加文件的数量正确。选中 Scan and add RTL include files into project 和 Copy sources into project，点击 Finish。

本次操作新加入了以下文件：

增加的 alu.v、controller.v 和 datapath.v 修改了新增指令后的控制机制和数据通路；  
mips\_core.v 作为连接 controller 和 datapath 的模块也做了对应修改；

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 16 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       |     | 公开       |

mips\_define.vh 里增加了对新增指令的定义。



图 2-18 lab06 添加的文件

接着我们添加 hex 文件，同样点击如图 2-19 所示的 Add Sources 快捷按钮：



图 2-19 继续添加 hex 文件

选中 Add or create design sources，点击 Next，如图 2-20 所示：

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 17 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       | 公开  |          |



图 2-20 Next

用 Add Files 添加文件。



图 2-21 添加文件

指定文件类型为 All Files , 如图 2-22 所示：

| 标题                                                  | 文档编号              | 版本  | 页        |
|-----------------------------------------------------|-------------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005   | 1.0 | 18 of 46 |
| 作者<br>Joseph Xu                                     | 修改日期<br>2019/1/23 |     | 公开       |
| <b>XINGDENG</b>                                     |                   |     |          |



图 2-22 指定全部类型文件可见

切换到 C:\archlabs\ComputerArchitecture\lab\_source\lab05\data 目录，如图 2-23 所示：



图 2-23 切换目录

选择 data\_mem.hex 和 inst\_mem.hex 文件，如图 2-24 所示：

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 19 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       |     | 公开       |



图 2-24 选择 hex 文件

选中 Scan and add RTL include files into project 和 Copy sources into project , 点击 Finish 把文件加入到工程 , 如图 2-25 所示 :



图 2-25 增加到工程

点击 “+” 展开 Unknown , 在 data\_mem.hex 上点击右键 , 点击 Set File Type , 如图 2-26 所示 :

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 20 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       |     | 公开       |



图 2-26 设置文件类型

选择 Data Files , 点击 OK , 如图 2-27 所示 :



图 2-27 设置类型为 Data Files

如图 2-28 所示 , 同样设置 inst\_mem.hex 的类型。

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 21 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       | 公开  |          |



图 2-28 设置文件类型

设置为 Data Files , 如图 2-29 所示 :



图 2-29 设置类型为 Data Files

在 data\_mem.hex 上点击右键 , 点击 Refresh Hierarchy 更新视图 , 如图 2-30 所示 :

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 22 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       | 公开  |          |



图 2-30 Refresh Hierarchy

如图 2-31 所示，现在 data\_mem.hex 和 inst\_mem.hex 都在 Data Files 下了，这两个文件包含指令存储器和数据存储器的初始化信息。



图 2-31 Data Files

添加的文件列表应如图 2-32 所示，请仔细比对该图，确保所有新文件都已经添加！！

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 23 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       |     | 公开       |



图 2-32 添加所有文件后的文件列表

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 24 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       |     | 公开       |

## 2.2 功能仿真

如图 2-33 所示，在 Vivado 的 Sources 窗口的 Simulation Source 子项依次展开，然后将 sim\_mips 设置为仿真顶层：



图 2-33 设置仿真顶层

接着点击 Run Simulation 下的 Run Behavioral Simulation，如图 2-34 所示：



图 2-34 开始仿真

| 标题                                                  | 文档编号            | 版本           |
|-----------------------------------------------------|-----------------|--------------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 25 of 46 |
| 作者                                                  | 修改日期            |              |
| Joseph Xu                                           | 2019/1/23       | 公开           |

仿真编译成功后，进入仿真视图，如图 2-35 所示：



图 2-35 仿真视图

按照之前实验的仿真操作，将如下信号添加到波形列表中：

1. sim\_mips/clk
2. sim\_mips/uut/MIPS\_CORE/if\_rst
3. sim\_mips/uut/MIPS\_CORE/if\_en
4. sim\_mips/uut/MIPS\_CORE/if\_valid
5. sim\_mips/uut/MIPS\_CORE/inst\_addr
6. sim\_mips/uut/MIPS\_CORE/inst\_data
7. sim\_mips/uut/MIPS\_CORE/id\_rst
8. sim\_mips/uut/MIPS\_CORE/id\_en
9. sim\_mips/uut/MIPS\_CORE/id\_valid
10. sim\_mips/uut/MIPS\_CORE/DATAPATH/inst\_addr\_id
11. sim\_mips/uut/MIPS\_CORE/DATAPATH/inst\_data\_id
12. sim\_mips/uut/MIPS\_CORE/DATAPATH/fwd\_a\_ctrl
13. sim\_mips/uut/MIPS\_CORE/DATAPATH/fwd\_b\_ctrl
14. sim\_mips/uut/MIPS\_CORE/CONTROLLER/reg\_stall
15. sim\_mips/uut/MIPS\_CORE/CONTROLLER/exe\_rst
16. sim\_mips/uut/MIPS\_CORE/CONTROLLER/exe\_en
17. sim\_mips/uut/MIPS\_CORE/CONTROLLER/exe\_valid
18. sim\_mips/uut/MIPS\_CORE/DATAPATH/inst\_addr\_exe
19. sim\_mips/uut/MIPS\_CORE/DATAPATH/inst\_data\_exe
20. sim\_mips/uut/MIPS\_CORE/DATAPATH/mem\_rst
21. sim\_mips/uut/MIPS\_CORE/DATAPATH/mem\_en
22. sim\_mips/uut/MIPS\_CORE/DATAPATH/mem\_valid
23. sim\_mips/uut/MIPS\_CORE/DATAPATH/inst\_addr\_mem
24. sim\_mips/uut/MIPS\_CORE/DATAPATH/inst\_data\_mem
25. sim\_mips/uut/MIPS\_CORE/DATAPATH/fwd\_m\_mem
26. sim\_mips/uut/MIPS\_CORE/DATAPATH/mem\_ren

| 标题                   | 文档编号                                                | 版本              | 页            |
|----------------------|-----------------------------------------------------|-----------------|--------------|
| XINGDENG<br>XINGDENG | Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 26 of 46 |
| 作者<br>Joseph Xu      | 修改日期<br>2019/1/23                                   |                 | 公开           |

27. sim\_mips/uut/MIPS\_CORE/DATAPATH/mem\_wen
28. sim\_mips/uut/MIPS\_CORE/DATAPATH/mem\_addr
29. sim\_mips/uut/MIPS\_CORE/DATAPATH/mem\_din
30. sim\_mips/uut/MIPS\_CORE/DATAPATH/mem\_dout
31. sim\_mips/uut/MIPS\_CORE/DATAPATH/wb\_valid
32. sim\_mips/uut/MIPS\_CORE/DATAPATH/wb\_wen\_wb
33. sim\_mips/uut/MIPS\_CORE/DATAPATH/regw\_addr\_wb
34. sim\_mips/uut/MIPS\_CORE/DATAPATH/regw\_data\_wb
35. sim\_mips/uut/MIPS\_CORE/DATAPATH/REGFILE/regfile

添加后将所有 4 位以上宽度的信号都设置成 16 进制显示。添加并设置后的波形列表如图 2-36 所示：



图 2-36 仿真所需要观察的所有信号

另外为了方便操作，可以直接加载预先提供的波形列表配置文件，具体操作如下：  
在仿真视图下，选择 File→Open Waveform Configuration，如图 2-37 所示：

| 标题                                                  | 文档编号              | 版本  | 页        |
|-----------------------------------------------------|-------------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005   | 1.0 | 27 of 46 |
| XINGDENG                                            |                   |     |          |
| 作者<br>Joseph Xu                                     | 修改日期<br>2019/1/23 | 公开  |          |



图 2-37 菜单中选择“Open Waveform Configuration”

切换到 C:\archlabs\ComputerArchitecture\lab\_source\lab05\simulation 目录，如图 2-38 所示：



图 2-38 切换目录

选择 lab5\_sim.wcfg 文件，然后点击 OK。如图 2-39 所示：

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 28 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       |     | 公开       |



图 2-39 选择 wcfg 文件

添加后的信号如图 2-40 所示：



图 2-40 加载波形配置文件后的波形列表视图

增加信号后需要使用 Run 菜单下的 Restart，重新开始仿真，如图 2-41 所示：

| XINGDENG  | 标题                                                  | 文档编号            | 版本  | 页        |
|-----------|-----------------------------------------------------|-----------------|-----|----------|
|           | Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 29 of 46 |
| 作者        | 修改日期                                                |                 |     |          |
| Joseph Xu | 2019/1/23                                           |                 |     | 公开       |



图 2-41 Restart Simulation

使用 **Run for...** 仿真指定时间长的波形，如图 2-42 所示：



图 2-42 Run for...

通过键盘 Shift+ “-” 和 Shift+ “+” 可以对波形图进行缩放。

将仿真出的波形和下面 8 张图对比，可以知道设计的电路是否正常工作。

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 30 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       | 公开  |          |



图 2-43 仿真结果 1



图 2-44 仿真结果 2

| XINGDENG | 标题                                                  | 文档编号            | 版本  | 页        |
|----------|-----------------------------------------------------|-----------------|-----|----------|
|          | Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 32 of 46 |
| 作者       | 修改日期                                                |                 |     |          |
|          | Joseph Xu                                           | 2019/1/23       | 公开  |          |



图 2-45 仿真结果 3

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 33 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       |     | 公开       |



图 2-46 仿真结果 4

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 34 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       | 公开  |          |



图 2-47 仿真结果 5

| XINGDENG | 标题                                                  | 文档编号            | 版本  | 页        |
|----------|-----------------------------------------------------|-----------------|-----|----------|
|          | Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 35 of 46 |
| 作者       | 修改日期                                                |                 |     |          |
|          | Joseph Xu                                           | 2019/1/23       | 公开  |          |



图 2-48 仿真结果 6

| XINGDENG | 标题                                                  | 文档编号            | 版本  | 页        |
|----------|-----------------------------------------------------|-----------------|-----|----------|
|          | Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 36 of 46 |
| 作者       | 修改日期                                                |                 |     |          |
|          | Joseph Xu                                           | 2019/1/23       | 公开  |          |



图 2-49 仿真结果 7

| 标题              | 文档编号              | 版本   页       |
|-----------------|-------------------|--------------|
|                 |                   |              |
| XINGDENG        | XD-LAB-ARCH-005   | 1.0 37 of 46 |
| 作者<br>Joseph Xu | 修改日期<br>2019/1/23 | 公开           |



图 2-50 仿真结果 8

仿真结束后，在菜单中选择 File→Close Simulation，关闭仿真视图。如图 2-51 所示：

| XINGDENG | 标题                                                  | 文档编号            | 版本  | 页        |
|----------|-----------------------------------------------------|-----------------|-----|----------|
|          | Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 38 of 46 |
| 作者       | Joseph Xu                                           | 修改日期            |     |          |
|          | 2019/1/23                                           |                 | 公开  |          |



图 2-51 关闭仿真视图

| 标题                                                  | 文档编号              | 版本  | 页        |
|-----------------------------------------------------|-------------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005   | 1.0 | 39 of 46 |
| 作者<br>Joseph Xu                                     | 修改日期<br>2019/1/23 | 公开  |          |

## 2.3 生成 bitstream 文件

回到 Vivado 主界面后，确认 mips\_top.v 被设置为顶层文件后。点击 Generate Bitstream 生成 FPGA 配置文件。如图 2-52 所示：



图 2-52 生成 bitstream

在询问对话框中选择 Yes，自动运行 synthesis 和 implementation，如图 2-53 所示：



图 2-53 自动运行中间步骤

如图 2-54 所示，当显示 Bitstream Generation Completed 时表示文件成功生成，点击 Cancel 结束。

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 40 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       |     | 公开       |



图 2-54 生成 bitstream 成功

| 标题                                                  | 文档编号              | 版本  | 页        |
|-----------------------------------------------------|-------------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005   | 1.0 | 41 of 46 |
| 作者<br>Joseph Xu                                     | 修改日期<br>2019/1/23 | 公开  |          |

## 2.4 下载验证

仿真完成后，下载 bit 文件到 SWORD4.0 开发平台查看真实效果。按图连接 SWORD4.0 的 12V 电源和 JTAG，然后打开开关。



图 2-55 连接 SWORD4.0

SWORD4.0 的控制开关主要有拨码开关、键盘矩阵、复位按钮等。

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 42 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       | 公开  |          |



图 2-56 主要控制 I/O

在 Vivado 中点击 Open Hardware Manager。



图 2-57 进入 Hardware Manager

点击 Open target，然后点击 Auto Connect。

| 标题       | 文档编号      | 版本        | 页  |
|----------|-----------|-----------|----|
|          |           |           |    |
| XINGDENG | Joseph Xu | 2019/1/23 | 公开 |



图 2-58 自动连接到 SWORD4.0

右键点击找到的 `xc7k325t_0`，选择 `Program Device`。



图 2-59 Program Device

点击 `Program` 下载 bit 文件。

| 标题                                                  | 文档编号            | 版本  | 页        |
|-----------------------------------------------------|-----------------|-----|----------|
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0 | 44 of 46 |
| 作者                                                  | 修改日期            |     |          |
| Joseph Xu                                           | 2019/1/23       |     | 公开       |



图 2-60 下载 bit 文件

下载完成后 SWORD4.0 上的反应，液晶屏上会显示调试信息。



图 2-61 运行效果

通过将拨码开关 DSW0 拨向上，可以开启单步模式。之后每按一下键盘矩阵左下角的 BTNX4YO，CPU 就执行一条指令。按复位键 FPGA RST 按钮回到初始状态。

| 标题                                                  | 文档编号              | 版本  | 页        |
|-----------------------------------------------------|-------------------|-----|----------|
|                                                     |                   |     |          |
| Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005   | 1.0 | 45 of 46 |
| 作者<br>Joseph Xu                                     | 修改日期<br>2019/1/23 |     | 公开       |

在单步模式下，通过每一步液晶屏显示的数据与仿真波形的对比，查看流水线cpu是否正常工作。

|                                                                                     |                                                     |                 |           |          |
|-------------------------------------------------------------------------------------|-----------------------------------------------------|-----------------|-----------|----------|
|  | 标题                                                  | 文档编号            | 版本        | 页        |
|                                                                                     | Lab5: Pipelined CPU supporting 31 MIPS Instructions | XD-LAB-ARCH-005 | 1.0       | 46 of 46 |
| 作者                                                                                  | Joseph Xu                                           | 修改日期            | 2019/1/23 | 公开       |