SetL2CacheHint
产品支持情况
功能说明
设置GlobalTensor是否使能L2 Cache,默认使能L2 Cache。
函数原型
template<CacheRwMode rwMode = CacheRwMode::RW>
__aicore__ inline void SetL2CacheHint(CacheMode mode);
参数说明
表 1 模板参数说明
enum CacheRwMode {
READ = 1,
WRITE = 2,
RW = 3
};
|
表 2 参数说明
返回值说明
无。
约束说明
无
调用示例
void Init(__gm__ uint8_t *src_gm, __gm__ uint8_t *dst_gm)
{
uint64_t dataSize = 256; //设置input_global的大小为256
AscendC::GlobalTensor<int32_t> inputGlobal; // 类型为int32_t
inputGlobal.SetGlobalBuffer(reinterpret_cast<__gm__ int32_t *>(src_gm), dataSize); // 设置源操作数在Global Memory上的起始地址为src_gm,所占外部存储的大小为256个int32_t
inputGlobal.SetL2CacheHint(AscendC::CacheMode::CACHE_MODE_DISABLE); // 设置GlobalTensor不会写入L2 Cache
AscendC::LocalTensor<int32_t> inputLocal = inQueueX.AllocTensor<int32_t>();
AscendC::DataCopy(inputLocal, inputGlobal, dataSize); // 将Global Memory上的inputGlobal拷贝到Local Memory的inputLocal上
...
}