VIVADO HLS入门之shift_led

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,可以用于硬件平台测试。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值