DSP

Xilinx HLS 优化指令整理------INLINE

2019-07-13 17:47发布

class="markdown_views prism-dracula"> INLINE directive 去除子函数层次结构,使Vivado HLS更好的分配资源并减少DSP和内存的使用率。子函数使用内联操作使自身逻辑融入到调用函数当中,优化结果结果的同时也增加了运行时间。HLS会自动内联较小的函数,要关闭自动内联可以设置inline directive 为off状态。 Syntax set_directive_inline [OPTIONS] Options
1、-off
关闭内联。
2、-recursive
默认情况下,内联只在当前层执行,内联函数下的函数并没有内联。-recursive 指令递归的内联该阶层下的所有函数。
3、-region
指点区域的所有函数被内联。
Pragma #pragma HLS inline <region | recursive | off> Examples
内联所有foo_top中的函数,不内联其中函数的子函数: set_directive_inline -region foo_top #pragma HLS inline region 使函数foo_sub1内联: set_directive_inline foo_sub1 #pragma HLS inline 递归内联foo_top中的所有函数,除了foo_sub2 set_directive_inline -region -recursive foo_top set_directive_inline -off foo_sub2 #pragma HLS inline region recursive //指令位于foo_top中 #pragma HLS inline off //指令位于foo_sub2中