EnableL1BankConflictOptimise【免费下载链接】asc-devkit本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言原生支持C和C标准规范主要由类库和语言扩展层构成提供多层级API满足多维场景算子开发诉求。项目地址: https://gitcode.com/cann/asc-devkit功能说明根据GetTiling接口计算出的Tiling参数获取是否可以开启L1 Bank冲突优化功能。若可以开启该功能则与TilingKey机制配合使用通过增加TilingKey关联Host侧与Kernel侧实现并在Kernel侧增加代码实现分支将MatmulConfig中的enableL1BankConflictOptimise设置为true即可优化L1上的Bank冲突。函数原型bool EnableL1BankConflictOptimise()参数说明无返回值说明falseKernel侧不能开启L1 Bank冲突优化。trueKernel侧可以开启L1 Bank冲突优化。约束说明使用创建的Tiling对象调用本接口且需在完成Tiling计算GetTiling后调用本接口。调用示例auto ascendcPlatform platform_ascendc::PlatformAscendC(context-GetPlatformInfo()); matmul_tiling::MatmulApiTiling tiling(ascendcPlatform); tiling.SetAType(matmul_tiling::TPosition::GM, matmul_tiling::CubeFormat::ND, matmul_tiling::DataType::DT_FLOAT16); tiling.SetBType(matmul_tiling::TPosition::GM, matmul_tiling::CubeFormat::ND, matmul_tiling::DataType::DT_FLOAT16); tiling.SetCType(matmul_tiling::TPosition::GM, matmul_tiling::CubeFormat::ND, matmul_tiling::DataType::DT_FLOAT); tiling.SetBiasType(matmul_tiling::TPosition::GM, matmul_tiling::CubeFormat::ND, matmul_tiling::DataType::DT_FLOAT); tiling.SetShape(1024, 1024, 1024); tiling.SetOrgShape(1024, 1024, 1024); tiling.SetBias(true); tiling.SetBufferSpace(-1, -1, -1); optiling::TCubeTiling tilingData; int ret tiling.GetTiling(tilingData); // Kernel侧是否可以开启L1 Bank冲突优化可与TilingKey机制结合使用 bool enableL1BankConflictOptimise tiling.EnableL1BankConflictOptimise();【免费下载链接】asc-devkit本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言原生支持C和C标准规范主要由类库和语言扩展层构成提供多层级API满足多维场景算子开发诉求。项目地址: https://gitcode.com/cann/asc-devkit创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考