diff --git a/README.md b/README.md index fbf5f63..f10d111 100644 --- a/README.md +++ b/README.md @@ -4,7 +4,9 @@ (PS: 能求个 star⭐ 吗 QAQ ~) -## 为什么需要本仓库? +[TOC] + +## 为什么创建本仓库? 1. 开发环境配置困难,为配置开发环境需要付出很多精力,开发效率低 2. 学生在运行 build.batbuild.sh 时经常遇到问题 @@ -22,98 +24,99 @@ 下列内容主要讲述如何使用本仓库来完成开发环境的一键配置和一键烧板 -1. **使用 Vscode + Dev Container 来一键完成环境配置** - > 如果你已经在你的设备上完成了开发的环境配置,可以跳过此内容。 - > **此部分内容搬运自 [YatCPU 的 Dev Container 环境配置](http://tokisakix.cn/2023/11/14/%5BDocker%5D%20YatCPU%20%E7%9A%84%20Dev%20container%20%E7%8E%AF%E5%A2%83%E9%85%8D%E7%BD%AE/)**,你可以前往文档原地址获得更好的阅读体验 +### 使用 Vscode + Dev Container 来一键完成环境配置 - 使用 Docker + Dev Container 配置开发环境比较简单,而且也经过了测试,所以,我们推荐在 Windows 上直接使用 Dev Container 来设置开发环境。 +> 如果你已经在你的设备上完成了开发的环境配置,可以跳过此内容。 +> **此部分内容搬运自 [YatCPU 的 Dev Container 环境配置](http://tokisakix.cn/2023/11/14/%5BDocker%5D%20YatCPU%20%E7%9A%84%20Dev%20container%20%E7%8E%AF%E5%A2%83%E9%85%8D%E7%BD%AE/)**,你可以前往文档原地址获得更好的阅读体验 - 按照安装指南配置好 Dev Container 环境,环境中含有 Scala 开发环境以及 Verilator 仿真器,但不包含 Vivado。如果你不需要烧板,那么使用 Dev Container 环境就可以完成所有实验以及软件测试了。 +使用 Docker + Dev Container 配置开发环境比较简单,而且也经过了测试,所以,我们推荐在 Windows 上直接使用 Dev Container 来设置开发环境。 - **软件安装** +按照安装指南配置好 Dev Container 环境,环境中含有 Scala 开发环境以及 Verilator 仿真器,但不包含 Vivado。如果你不需要烧板,那么使用 Dev Container 环境就可以完成所有实验以及软件测试了。 - 安装 VSCode,直接在[官网下载](https://code.visualstudio.com/) +**软件安装** - 安装 Docker,直接在[官网下载](https://www.docker.com/),你可以参照这个[视频教程](https://docker.easydoc.net/doc/81170005/cCewZWoN/lTKfePfP)配置 +安装 VSCode,直接在[官网下载](https://code.visualstudio.com/) - **安装 Dev Containers 插件** +安装 Docker,直接在[官网下载](https://www.docker.com/),你可以参照这个[视频教程](https://docker.easydoc.net/doc/81170005/cCewZWoN/lTKfePfP)配置 - 在 VSCode 的扩展处搜索 Dev Containers,下载安装 +**安装 Dev Containers 插件** - ![image](asset/devcontainer1.png) +在 VSCode 的扩展处搜索 Dev Containers,下载安装 - **使用 Dev Containers 打开项目** +![image](asset/devcontainer1.png) - 我们可以按 VSCode 左下角的蓝色按钮来运行 Dev Containers: +**使用 Dev Containers 打开项目** - 在上方的运行选项中选择在容器中重新打开,这个命令会让 Dev container 自动根据 devcontainer.json 里的配置信息来创建 Docker 环境 +我们可以按 VSCode 左下角的蓝色按钮来运行 Dev Containers: - ![image](asset/devcontainer2.png) +在上方的运行选项中选择在容器中重新打开,这个命令会让 Dev container 自动根据 devcontainer.json 里的配置信息来创建 Docker 环境 - 如果你是第一次在容器中打开,你可能需要十几分钟的时间等待容器配置完毕,如果在配置过程中发生异常,请检查你的网络情况后再次运行 +![image](asset/devcontainer2.png) - **运行测试** +如果你是第一次在容器中打开,你可能需要十几分钟的时间等待容器配置完毕,如果在配置过程中发生异常,请检查你的网络情况后再次运行 - 上述步骤完成后,我们就可以像在 Dev container 为我们配置好的开发环境中运行、调试代码了。 +**运行测试** - 新建终端输入 sbt test,期望你有如下输出 +上述步骤完成后,我们就可以像在 Dev container 为我们配置好的开发环境中运行、调试代码了。 - ![image](asset/devcontainer3.png) +新建终端输入 sbt test,期望你有如下输出 - ```bash - [info] All tests passed. - [success] Total time: 181 s (03:01), completed Nov 14, 2023, 3:24:02 PM - ``` +![image](asset/devcontainer3.png) - 后续当你需要再次启动开发环境时,按相同的步骤运行 Dev Containers 即可,此时 Dev Containers 会自动使用之前已经配置好的环境,不需要再次花费十几分钟等待环境配置 +```bash +[info] All tests passed. +[success] Total time: 181 s (03:01), completed Nov 14, 2023, 3:24:02 PM +``` -2. **使用一键烧板脚本** +后续当你需要再次启动开发环境时,按相同的步骤运行 Dev Containers 即可,此时 Dev Containers 会自动使用之前已经配置好的环境,不需要再次花费十几分钟等待环境配置 - > 此烧板脚本对任意方式配置的开发环境都有效,因为 vivado 的烧板跟开发环境是**相互独立**的,如果你使用 Dev Container 或 WSL 配置环境,你需要回到 Windows 下打开 PowerShell 进行烧板。 - > **此部分内容借鉴自 [YatCPU 的烧板验证](https://yatcpu.sysu.tech/getting-started/program-device/)** +### 使用一键烧板脚本 - 原则上你可以在任意一个 lab 文件夹中使用下方的脚本进行烧板,下方的演示路径为 2023-fall-yatcpu-repo/mini-yatcpu/ +> 此烧板脚本对任意方式配置的开发环境都有效,因为 vivado 的烧板跟开发环境是**相互独立**的,如果你使用 Dev Container 或 WSL 配置环境,你需要回到 Windows 下打开 PowerShell 进行烧板。 +> **此部分内容借鉴自 [YatCPU 的烧板验证](https://yatcpu.sysu.tech/getting-started/program-device/)** - **生成 Verilog 文件** +原则上你可以在任意一个 lab 文件夹中使用下方的脚本进行烧板,下方的演示路径为 2023-fall-yatcpu-repo/mini-yatcpu/ - 根据开发板型号,在命令行输入对应型号的运行指令,运行相应目录的 Top.scala 文件,生成的结果位于 verilog/开发板名称 目录下的 Top.v,下方是参考的代码: +**生成 Verilog 文件** - ``` - sbt "runMain board.basys3.VerilogGenerator" - sbt "runMain board.verilator.VerilogGenerator" - sbt "runMain board.pynq.VerilogGenerator" - sbt "runMain board.z710.VerilogGenerator" - ``` +根据开发板型号,在命令行输入对应型号的运行指令,运行相应目录的 Top.scala 文件,生成的结果位于 verilog/开发板名称 目录下的 Top.v,下方是参考的代码: - **生成比特流二进制文件** +``` +sbt "runMain board.basys3.VerilogGenerator" +sbt "runMain board.verilator.VerilogGenerator" +sbt "runMain board.pynq.VerilogGenerator" +sbt "runMain board.z710.VerilogGenerator" +``` - 下面的教程以 ZYBO-Z710 开发板为例,其他开发板可以根据开发板名称自行替换。 +**生成比特流二进制文件** - 执行下述指令,可以根据 verilog/z710/Top.v 生成二进制文件 vivado/z710/riscv-z710/riscv-z710.runs/impl_1/Top.bit。 +下面的教程以 ZYBO-Z710 开发板为例,其他开发板可以根据开发板名称自行替换。 - 假设你的 Vivado 安装目录是 ~/Xilinx(其他目录自行修改): +执行下述指令,可以根据 verilog/z710/Top.v 生成二进制文件 vivado/z710/riscv-z710/riscv-z710.runs/impl_1/Top.bit。 - ``` - cd vivado/z710 - ~/Xilinx/Vivado/2020.1/bin/vivado -mode batch -source ./generate_bitstream.tcl - ``` +假设你的 Vivado 安装目录是 ~/Xilinx(其他目录自行修改): - **烧板** +``` +cd vivado/z710 +~/Xilinx/Vivado/2020.1/bin/vivado -mode batch -source ./generate_bitstream.tcl +``` - 执行下述指令,可以将二进制文件 vivado/z710/riscv-z710/riscv-z710.runs/impl_1/Top.bit 烧录到跟设备连接的开发板上。 +**烧板** - 假设你的 Vivado 安装目录是 ~/Xilinx(其他目录自行修改): +执行下述指令,可以将二进制文件 vivado/z710/riscv-z710/riscv-z710.runs/impl_1/Top.bit 烧录到跟设备连接的开发板上。 - ``` - cd vivado/z710 - ~/Xilinx/Vivado/2020.1/bin/vivado -mode batch -source ./program_device.tcl - ``` +假设你的 Vivado 安装目录是 ~/Xilinx(其他目录自行修改): - **如果烧板无误,你会看到黄灯亮起** +``` +cd vivado/z710 +~/Xilinx/Vivado/2020.1/bin/vivado -mode batch -source ./program_device.tcl +``` - ![image](asset/z710.jpg) +**如果烧板无误,你会看到黄灯亮起** - 后续将上述 program_device.tcl 换成 generate_and_program.tcl 可以将生成比特流和烧板在一个脚本中完成。 +![image](asset/z710.jpg) + +后续将上述 program_device.tcl 换成 generate_and_program.tcl 可以将生成比特流和烧板在一个脚本中完成。 ## 外部参考链接 - [YatCPU 文档地址](https://yatcpu.sysu.tech)