前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >HLS IP Library?

HLS IP Library?

作者头像
Lauren的FPGA
发布2020-03-26 16:39:44
1.3K0
发布2020-03-26 16:39:44
举报
文章被收录于专栏:Lauren的FPGALauren的FPGA

Vivado HLS提供了IP Library,这个C Library使得HLS可以直接由相应的C代码推断出Xilinx的IP,从而保证了高质量的FPGA实现。这个IP Library包含的IP如下表所示(表格来源:ug902(V2019.2),Table 26)。可以看到FFT、FIR、DDS和SRL等都包含其中。

以FFT为例,我们看看具体使用方法。首先,在用户头文件中需要添加hls_fft.h,如下图所示。同时,根据设计需求设置相关参数,如输入数据位宽、输出数据位宽、配置位宽、FFT长度等,这些参数的具体含义可参考pg109。如下代码第107行是关键部分,实现了对FFT IP的配置。struct config1中的变量都有默认值,如果没有声明,HLS会按默认值处理。

再看函数定义部分,如下图所示。注意代码的第141行,完成了以C语言的方式对FFT IP的实例化。此外,Xilinx建议,需要在一个使用了DATA FLOW的Region内(set_directive_dataflow)使用FFT函数,这样才能保证FFT函数的输入、输出数组最终被采用流式数组的方式实现。

从这个案例中,我们也可以学到如何声明复数数据类型。同时需要注意,在使用complex时,复数的实部和虚部拼接构成complex。例如,设置复数位宽为16位,这里的16位是实部和虚部均为16位。HLS综合报告接口部分显示的是32位,高16位为实部,低16位为虚部,如下图所示。

文 | Lauren 图 | Lauren

Copyright @ Lauren的FPGA

转载事宜请私信 | 获得授权后方可转载

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-03-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Lauren的FPGA 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档