文章目录
本系列文档通过实例说明 Vivado HLS 的基础开发流程。
遗憾的是,HLS 没有必要进行更为深入的研究。因为在本人看来,HLS 仅仅是一个在 FPGA 上快速实现算法的工具,稍有些复杂的算法就几乎无法得到足够的运行效率。原本对 HLS 的幻想是像 C/C++ 代码一样在 FPGA 中执行计算,但是在后续的进阶实验中越发感受到 HLS 的局限,无论是代码本身的优化或者使用 Directive 配置都没有理想的结果。可能 HLS 面向的使用对象是不了解 FPGA 运行原理的 C/C++ 工程师,仅在对代码运行效率没有要求的情况下使用。
开发环境:
- zcu102 开发板
- Windows 10
- Vivado 2018.2.1
- Visual Studio Code
- Matlab 2017b
主要参考资料包括:
- ug998
- ug871
- ug902
- ug1197
- Vivado HLS 基本应用与图像处理视频教程
本文档说明了使用 Vivado HLS 实现算法功能的基本流程,并且配置 VS Code 为基础的代码编辑器(仅用于编辑代码)。
建立 HLS 工程
Vivado Design Suite 完整安装后,在 Win10 开始菜单中打开 HLS:
HLS 启动后,在菜单中选择 File > New Project
在弹出窗口中选择工程名称和路径,点击 Next 按钮
后续的添加源文件(source files)和测试文件(testbench files)界面默认不做操作,直接按 Next 按钮
在 solution 界面设置解决方案名称、时钟频率,并选择器件,最后点击 Finish 按钮
注意:同一个 HLS 工程对应一组源代码和测试代码,但是可以包含多个解决方案,每个解决方案可以对代码的 FPGA 实现做不同的配置。
工程建立后的 Explorer 界面如下:
配置 VS Code
配置 include 路径
首先确保 VS Code 已安装 C/C++ 插件和 C++ Intellisense 插件
进入 HLS 工程所在目录,在右键菜单选择“通过 Code 打开”
在 VS Code 中通过菜单或者快捷键打开 Command Palatte
在弹出的 Command Palatte 中输入 edit,并选择:
C/C++: Edit Configurations (UI)
在配置界面的包含路径中添加 HLS 工程 Includes 下全部的路径
注意:${workspaceFolder}/** 路径是点击输入框自动添加
其它配置项保持默认,关闭配置界面。
在 HLS 工程文件夹内添加了 .vscode 文件夹,打开其中的c_cpp_properties.json 即为前述的配置内容
配置默认文件头
参考:https://www.jianshu.com/p/07a7fd95954f
在 VS Code 菜单选择 File > Preferences > User Snippets
在弹出命令框中选择 C++
在打开的 cpp.json 文件中添加以下内容,通过关键词 hls 添加与 Vivado 建立 HDL 文件相同的文件头
{
"HLS CPP Title": {
"