HLS是高层次综合的简称,将C程序转换成verilog HDL或者VHDL代码,封装成IP便于导入硬件语言编写的程序中。HLS只适用于算法设计,不能取代硬件语言。
流水灯实验之于硬件开发如同“Hello World!”之于软件编程。本次实验通过移位器实现led灯循环点亮。
核心文件.cpp和头文件.h放在Source目录下,测试文件.cpp放在Test Bench目录里。
头文件中 { #ifndef SHIFT_LED_H #define SHIFT_LED_H #endif } 设置的目的是防止头文件被重复调用。“被重复调用”是指一个头文件在同一个cpp文件中被include了多次,这种错误常常是由于include嵌套造成的。比如:存在a.h文件#include "c.h"而此时b.cpp文件导入了#include “a.h” 和#include "c.h"此时就会造成c.h重复引用。 如果_SHIFT_LED_H_没有被宏定义,那么宏定义_SHIFT_LED_H_并且执行后面的语句,否则执行#endif后面的代码。
ap_fixed函数包含在设置 int 自定义位宽的"ap_int.h"头文件中,它的用法是ap_fixed<n,m>,n表示数据总位宽,m表示整数部分位宽,那么小数部分位宽是n-m。该函数实现端口数据位宽的约束。
端口的输入输出约束是Insert Directive实现。对于led_o, mode选择ap_ovld,而led_i选择ap_vld。
运行Solution下的Run C/RTL cosimulation,在solution目录下多了一个sim文件夹,在其verilog文件夹下生成波形文件shift_led.wlf。用modelsim打开可以查看波形。
通过Solution下的Export RTL进行代码封装,生成的IP在solution-impl-ip-.zip,可以用于硬件平台测试。
VIVADO HLS入门之shift_led
最新推荐文章于 2024-06-12 22:16:39 发布