BatchMatmulGetTmpBufSizeV2
功能说明
BatchMatmul Tiling调用GetTiling接口获取Tiling参数后,根据Tiling结构体信息获取L1 Buffer/Unified Buffer/L0C Buffer的使用大小。
函数原型
int32_t BatchMatmulGetTmpBufSizeV2(AscendC::tiling::TCubeTiling &tiling, matmul_tiling::SysTilingTempBufSize &bufSize)
参数说明
表 1 参数说明
BatchMatmul Tiling的结构体,即BatchMatmulTiling对象得到的TCubeTiling结构体。 TCubeTiling为Kernel侧定义的Matmul TilingData,与入参为带AscendC::tiling命名空间的TCubeTiling结构体的GetTiling接口配合使用。 |
||
根据TCubeTiling结构体信息获取L1 Buffer/Unified Buffer/L0C Buffer的使用大小。 struct SysTilingTempBufSize {
int32_t ubSize = 0; // Unified Buffer大小
int32_t l1Size = 0; // L1 Buffer大小
int32_t l0cSize = 0; // L0C Buffer大小
};
|
返回值说明
-1表示获取失败; 0表示获取成功。
约束说明
无
调用示例
auto ascendcPlatform = platform_ascendc::PlatformAscendC(context->GetPlatformInfo());
matmul_tiling::BatchMatmulTiling tiling(ascendcPlatform);
AscendC::tiling::TCubeTiling tilingData;
... // 初始化tilingData,详见MatmulTiling类使用说明
int ret = tiling.GetTiling(tilingData); // 获取Tiling参数
SysTilingTempBufSize bufSize;
BatchMatmulGetTmpBufSizeV2(tilingData, bufSize);