hls_zcu102_0_基础流程与放弃

本文详细介绍了在zcu102开发板上使用Vivado HLS进行FPGA设计的基础流程,包括创建HLS项目,配置VS Code,编写和添加代码,C Simulation,C Synthesis,C/RTL Cosimulation,以及导出HLS IP到Vivado工程。在实践中遇到的限制和代码优化问题也进行了讨论。
摘要由CSDN通过智能技术生成


本系列文档通过实例说明 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

主要参考资料包括:


本文档说明了使用 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": {
   
		"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值