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
递归内联foo_top中的所有函数,除了foo_sub2
set_directive_inline -region -recursive foo_top
set_directive_inline -off foo_sub2
#pragma HLS inline region recursive
#pragma HLS inline off