news 2026/5/11 13:16:37

CANN asc-devkit寄存器存储接口

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
CANN asc-devkit寄存器存储接口

asc_storeunalign_post_postupdate

【免费下载链接】asc-devkit本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言,原生支持C和C++标准规范,主要由类库和语言扩展层构成,提供多层级API,满足多维场景算子开发诉求。项目地址: https://gitcode.com/cann/asc-devkit

产品支持情况

产品是否支持
Ascend 950PR/Ascend 950DT

功能说明

reg计算数据搬运接口,适用于从矢量数据寄存器连续非32B对齐的起始地址连续搬出到UB的尾块场景。

该接口每调用一次接口会更新目的操作数在UB上的地址。

需要先调用下列接口之一后,再调用本接口。

  • asc_storeunalign_postupdate使用uint32_t作为存储偏移量的接口。

搬运原理如下: 记目的操作数的起始地址为 dst_start,结束地址为 dst_end,尾块元素个数为 unalign_count = (dst_end - dst_end / 32 * 32) / sizeof(T)。 则搬运的数据会分为两部分,分别是:

  • 32B对齐的主块部分[dst_start, dst_end - unalign_count * sizeof(T)]。
  • 非32B对齐的尾块部分[dst_end - unalign_count * sizeof(T), dst_end]。 store_unalign或store_unalign_postupdate接口执行时,会将主块搬出至UB,尾块暂存至非对齐寄存器[0, unalign_count]。 本接口执行时,会将尾块从非对齐寄存器[0, unalign_count]搬出至UB。

函数原型

__simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ int8_t*& dst, vector_store_unalign src, int32_t offset) __simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ uint8_t*& dst, vector_store_unalign src, int32_t offset) __simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ fp4x2_e2m1_t*& dst, vector_store_unalign src, int32_t offset) __simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ fp4x2_e1m2_t*& dst, vector_store_unalign src, int32_t offset) __simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ int4b_t*& dst, vector_store_unalign src, int32_t offset) __simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ fp8_e8m0_t*& dst, vector_store_unalign src, int32_t offset) __simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ fp8_e5m2_t*& dst, vector_store_unalign src, int32_t offset) __simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ fp8_e4m3fn_t*& dst, vector_store_unalign src, int32_t offset) __simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ hifloat8_t*& dst, vector_store_unalign src, int32_t offset) __simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ int16_t*& dst, vector_store_unalign src, int32_t offset) __simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ uint16_t*& dst, vector_store_unalign src, int32_t offset) __simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ half*& dst, vector_store_unalign src, int32_t offset) __simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ bfloat16_t*& dst, vector_store_unalign src, int32_t offset) __simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ int32_t*& dst, vector_store_unalign src, int32_t offset) __simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ uint32_t*& dst, vector_store_unalign src, int32_t offset) __simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ float*& dst, vector_store_unalign src, int32_t offset) __simd_callee__ inline void asc_storeunalign_post_postupdate(__ubuf__ int64_t*& dst, vector_store_unalign src, int32_t offset)

参数说明

参数名输入/输出描述
dst输出目的操作数(矢量)的起始地址。
src输入非对齐寄存器,用于保存非对齐数据,长度32B。
offset输入目的操作数结束地址的偏移,类型为地址寄存器,单位为元素个数。

非对齐寄存器和地址寄存器的详细说明请参见reg数据类型定义.md。

返回值说明

流水类型

PIPE_V

约束说明

  • 该接口中的dst不需要32B对齐,但数据类型为T的dst需要sizeof(T) Byte对齐。
  • 调用本接口之前,需要调用asc_storeunalign_postupdate使用uint32_t作为存储偏移量的接口,且本接口与前序接口的非对齐寄存器要保持一致。

调用示例

// dst地址为8,非32B对齐,占用的地址为UB[8:520]。 __ubuf__ uint32_t* dst = (__ubuf__ uint32_t*)asc_get_phy_buf_addr(8); vector_store_unalign ureg; vector_uint32_t src; uint32_t count = 64; uint32_t repeat = 2; for (uint32_t i = 0; i < repeat; i++) { // 其他reg操作 // 第一次:src[0:62] 写入 dst[0:62](即UB[8:256]);同时src[62:64] 写入 ureg[0:2];同时dst自增为dst[64](即UB[264]) // 第二次:ureg[0:2] + src[0:62] 写入 dst[-2:62](即UB[256:512]);同时src[62:64] 写入 ureg[0:2];同时dst自增为dst[128](即UB[520]) asc_storeunalign_postupdate(dst[i * count], ureg, src, count); } // dst结束地址为520,但此时dst已经自增到了520,所以offset要配置为0 int32_t offset = repeat * count; // ureg[0:2] 写入 dst[126:128](即UB[512:520]) asc_storeunalign_post(dst, ureg, offset);

【免费下载链接】asc-devkit本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言,原生支持C和C++标准规范,主要由类库和语言扩展层构成,提供多层级API,满足多维场景算子开发诉求。项目地址: https://gitcode.com/cann/asc-devkit

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/11 13:10:32

CANN/ge ACL设置张量原始形状

aclSetTensorOriginShape 【免费下载链接】ge GE&#xff08;Graph Engine&#xff09;是面向昇腾的图编译器和执行器&#xff0c;提供了计算图优化、多流并行、内存复用和模型下沉等技术手段&#xff0c;加速模型执行效率&#xff0c;减少模型内存占用。 GE 提供对 PyTorch、T…

作者头像 李华
网站建设 2026/5/11 13:08:36

Authorizer与React集成:前端认证的完整实现方案

Authorizer与React集成&#xff1a;前端认证的完整实现方案 【免费下载链接】authorizer Your data, your control. Fully open source, authentication and authorization. No lock-ins. Deployment in Railway in 120 seconds || Spin a docker image as a micro-service in …

作者头像 李华
网站建设 2026/5/11 13:07:36

终极指南:BepInEx如何彻底改变Unity游戏插件开发体验

终极指南&#xff1a;BepInEx如何彻底改变Unity游戏插件开发体验 【免费下载链接】BepInEx Unity / XNA game patcher and plugin framework 项目地址: https://gitcode.com/GitHub_Trending/be/BepInEx BepInEx是一个功能强大的插件和模组框架&#xff0c;专为Unity Mo…

作者头像 李华
网站建设 2026/5/11 12:58:17

【信息系统项目管理师-论文真题】2025上半年(第二批)论文详解(包括解题思路和写作要点)

更多内容请见: 《备考信息系统项目管理师》 - 专栏介绍和目录 文章目录 论文:信息系统项目的不确定性绩效域 写作思路 写作参考 论文:信息系统项目的不确定性绩效域 请以论《信息系统项目的不确定性绩效域》为题进行论述 1、论述参与管理信息系统项目的背景、项目规模、发…

作者头像 李华
网站建设 2026/5/11 12:54:31

CANN/asc-devkit SetSize API文档

SetSize 【免费下载链接】asc-devkit 本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言&#xff0c;原生支持C和C标准规范&#xff0c;主要由类库和语言扩展层构成&#xff0c;提供多层级API&#xff0c;满足多维场景算子开发诉求。 项目地址: https://gitcode.com/ca…

作者头像 李华