复合数据类型在Vivado HLS中的应用

更多精彩内容,请微信搜索“FPGAer俱乐部”关注我们

在C++中常用的复合数据类型,一种是结构体,另一种就是枚举类型。


1

   

struct


对于struct来说,如果出现在顶层函数,并作为顶层函数参数的时候,struct里的scalar变量就会被映射scalar类型的端口,数组就会被映射为相应的memory端口。在实际使用中,建议预先把结构体在头文件里声明。对于结构体中的元素,Vivado hls里提供相应的data pack优化方式,这种优化方式分为两种,即field_level 和struct_level。


2

   

两者区别 


结构体里field_level所有元素的位宽必须以8 bits为边界,比如说,一个变量为6 bits就必须扩展到8 bits,如果一个struct有五个元素,每个元素6 bits,每个元素扩展到8 bits,此时总位宽就会被扩展为40 bits。而struct_level不改变每个元素的实际位宽,但是对于封装后的总位宽要以8 bits为边界,比如说,上面的·总位宽就会被扩展到32 bits。 

注意:比较这两种类型的data pack优化方式,会发现两者的clock,latency和interval,以及资源利用率都是一致的。data pack可以降低latency和interval,提高数据的吞吐率,这是因为这里data pack对for循环进行展开。 

3

   

Enum


Enumerated Type是将一个数值定义为一个符号常量,需要用到关键字enum。枚举类型的元素会被自动的分配到一个整数,其中起始值为0,后面依次加1。这样是为了提高代码的可读性。 

4

   

总结


Vivado hls既支持结构体,也支持枚举类型,这两种类型都可以作为接口出现在顶层函数。如果结构体出现在顶层函数,可以通过field_level 和struct_level进行封装,如果枚举类型作为接口出现在顶层函数,它实际上是整数,vivado会自动推断相应mode的数据位宽。


本文转载于:https://blog.csdn.net/weixin_36520607/article/details/53448036,如涉及侵权,请私信小编删除。

============华 丽 的 分 割 线============


想加入我们FPGA学习交流群吗?可以长按或扫描以下二维码,审核通过后我们邀请您加入

这些微信群旨在打造一个提供给FPGA工程开发人员及兴趣爱好者(统称“FPGAer”)进行技术交流、答疑解惑和学习的平台。而且我们也将会通过网络举办FPGA技术讲座,分享相关研究文献 



了解更多FPGA知识可以长按或扫描以下二维码关注FPGAer俱乐部



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值