HLS优化调试技巧

本文介绍了HLS设计的优化策略,包括通过分析数据流和依赖性确定优化目标,利用pragma loop_tripcount调整延迟,解决csim和cosim结果不一致的问题,以及在dataflow设计中避免hang问题。此外,还强调了CModel优化技巧,如循环优化、数据流平衡和资源复用,并提醒注意BRAM初始化和数组索引溢出。建议使用最新HLS工具并参考优秀代码进行调试。
摘要由CSDN通过智能技术生成

对于一个HLS设计,第一步是得到一个csim正确的版本,在此基础上:

  • 确定优化方向,分析数据流和数据间的dependency,综合考虑resource and throughput, 基本确定能达到的优化目标;

    - 对于primitive,一般是throughput优先,尽可能做到一拍处理更大位宽的数据。
  • 根据HLS synth report, 分析整体的latency以及其具体组成,然后从对latency影响最大的模块开始着手优化;

    - pragma loop_tripcount对于分析整体latency很有帮助,一般按照实际情况设置,或者设置为10的整数倍,不同层级在数量级上有一定的区分可便于分析。
  • 对于csim和cosim结果不一致的情况

    1. 一般原因均是因为变量、数组没有初始化引起的,因为未初始化的变量csim时会初始化为0,而cosim不会。有时候我们未对变量进行初始化,而且根据设计流程也应该是先写后读,但实际执行过程却不是这样,所以要特别注意;

    2. 另一个可能出现结果不一致的情况就是操作数组时出现边界溢出的情况,所以要特别注意。

    3. 还有就是为了做到ii=1使用了:#pragma HLS dependence variable = temp_array inter false, 可是代码运行中还是出现还未成功写入数据就读了该地址的值,导致错误;如果有这种情况需要用大于原本ii的深度的cache,去防止上述问题,一方面可以基于单周期刷RAM的方式解决。如下所示,函数foo1只能做到ii=2,如果直接加 "#pragma HLS dependenc

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值