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

INLINE directive

去除子函数层次结构,使Vivado HLS更好的分配资源并减少DSP和内存的使用率。子函数使用内联操作使自身逻辑融入到调用函数当中,优化结果结果的同时也增加了运行时间。HLS会自动内联较小的函数,要关闭自动内联可以设置inline directive 为off状态。

Syntax

set_directive_inline [OPTIONS] <location>

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中
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值