InitBuffer
产品支持情况
功能说明
用于为TQue等队列和TBuf分配内存。
函数原型
-
为TQue等队列分配内存
template <class T> __aicore__ inline bool InitBuffer(T& que, uint8_t num, uint32_t len) // 为TQue等队列分配内存,且开发者可以自定义内存的地址信息,地址信息包含起始地址和长度。 template <class T, class U, class V, class... Addrs> __aicore__ inline bool InitBuffer(T& que, const Std::tuple<U, V>& addr0, const Addrs&... addrs) -
为TBuf分配内存
template <TPosition bufPos> __aicore__ inline bool InitBuffer(TBuf<bufPos>& buf, uint32_t len)
参数说明
表 1 bool InitBuffer(T& que, uint8_t num, uint32_t len) 原型定义模板参数说明
表 2 bool InitBuffer(T& que, uint8_t num, uint32_t len) 原型定义参数说明
分配内存块的个数。double buffer功能通过该参数开启:num设置为1,表示不开启double buffer;num设置为2,表示开启double buffer。 |
||
每个内存块的大小,单位为字节。当传入的len不满足32字节对齐时,API内部会自动向上补齐至32字节对齐,后续的数据搬运过程会涉及非对齐处理。 |
表 3 bool InitBuffer(T& que, const Std::tuple<U, V>& addr0, const Addrs&... addrs) 原型定义模板参数说明
表 4 bool InitBuffer(T& que, const Std::tuple<U, V>& addr0, const Addrs&... addrs) 原型定义参数说明
表 5 InitBuffer(TBuf<bufPos>& buf, uint32_t len)原型定义模板参数说明
TBuf所在的逻辑位置,TPosition类型。 |
表 6 InitBuffer(TBuf<bufPos>& buf, uint32_t len)原型定义参数说明
为TBuf分配的内存大小,单位为字节。当传入的len不满足32字节对齐时,API内部会自动向上补齐至32字节对齐,后续的数据搬运过程会涉及非对齐处理。 |
约束说明
- InitBuffer申请的内存会在TPipe对象销毁时通过析构函数自动释放,无需手动释放。
- 如果需要重新分配InitBuffer申请的内存,可以调用Reset,再调用InitBuffer接口。
- 一个kernel中所有使用的Buffer数量之和不能超过64。
- 自定义地址InitBuffer方式分配不建议与不指定地址的混用,可能会导致内存冲突。
返回值说明
返回Buffer初始化的结果。
调用示例
// 为TQue分配内存,分配内存块数为2,每块大小为128字节
AscendC::TPipe pipe; // Pipe内存管理对象
AscendC::TQue<AscendC::TPosition::VECOUT, 2> que; // 输出数据队列管理对象,TPosition为VECOUT
uint8_t num = 2;
uint32_t len = 128;
pipe.InitBuffer(que, num, len);
// 为TQue分配内存,开发者自定义内存的地址信息,分别为[0, 1024], [2048, 4096], [8192, 12288]
AscendC::TPipe pipe; // Pipe内存管理对象
AscendC::TQue<AscendC::TPosition::VECOUT, 1> que; // 输出数据队列管理对象,TPosition为VECOUT
auto addr0 = Std::make_tuple(0, 1024);
auto addr1 = Std::make_tuple(2048, 2048);
auto addr2 = Std::make_tuple(8192, 4096);
pipe.InitBuffer(que, addr0, addr1, addr2);
// 为TBuf分配内存,分配长度为128字节
AscendC::TPipe pipe;
AscendC::TBuf<AscendC::TPosition::A1> buf; // 输出数据管理对象,TPosition为A1
uint32_t len = 128;
pipe.InitBuffer(buf, len);