当前位置: 首页 > news >正文

CANN/runtime共享Buffer管理预留接口

20. 共享Buffer管理(预留,暂不支持)

【免费下载链接】runtime本项目提供CANN运行时组件和维测功能组件。项目地址: https://gitcode.com/cann/runtime

本章节描述预留的共享 Buffer 管理接口(当前版本暂不支持)。

  • aclError aclrtAllocBuf(aclrtMbuf *buf, size_t size):申请指定大小的共享Buffer。
  • aclError aclrtFreeBuf(aclrtMbuf buf):释放通过aclrtAllocBuf接口申请的共享Buffer。
  • aclError aclrtGetBufData(const aclrtMbuf buf, void **dataPtr, size_t *size):获取共享Buffer的数据区指针和数据区长度,用户可以使用此指针填入数据。
  • aclError aclrtSetBufUserData(aclrtMbuf buf, const void *dataPtr, size_t size, size_t offset):设置共享Buffer的私有数据区数据,从用户内存拷贝到共享Buffer的私有数据区的指定偏移位置,用于设置控制信息作为上下文传递。
  • aclError aclrtGetBufUserData(const aclrtMbuf buf, void *dataPtr, size_t size, size_t offset):获取共享Buffer的私有数据区数据,偏移offset后,拷贝至用户申请的内存区域。
  • aclError aclrtGetBufDataLen(aclrtMbuf buf, size_t *len):获取共享Buffer中有效数据的长度。
  • aclError aclrtSetBufDataLen(aclrtMbuf buf, size_t len):设置共享Buffer中有效数据的长度。
  • aclError aclrtCopyBufRef(const aclrtMbuf buf, aclrtMbuf *newBuf):对共享Buffer数据区的引用拷贝,创建并返回一个新的Mbuf管理结构指向相同的数据区。
  • aclError aclrtAppendBufChain(aclrtMbuf headBuf, aclrtMbuf buf):将共享Buffer添加到Mbuf链表中。
  • aclError aclrtGetBufFromChain(aclrtMbuf headBuf, uint32_t index, aclrtMbuf *buf):从Mbuf链表中获取第index个共享Buffer。
  • aclError aclrtGetBufChainNum(aclrtMbuf headBuf, uint32_t *num):从Mbuf链表中获取共享Buffer的个数。

aclrtAllocBuf

aclError aclrtAllocBuf(aclrtMbuf *buf, size_t size)

功能说明

申请指定大小的共享Buffer。

参数说明

参数名输入/输出说明
buf输出申请到的共享Buffer。类型定义请参见aclrtMbuf。
size输入用于指定数据区的内存大小,单位Byte,不能超过4G。

返回值说明

返回0表示成功,返回其他值表示失败,请参见aclError。




aclrtFreeBuf

aclError aclrtFreeBuf(aclrtMbuf buf)

功能说明

释放通过aclrtAllocBuf接口申请的共享Buffer。

参数说明

参数名输入/输出说明
buf输入待释放的共享Buffer。类型定义请参见aclrtMbuf。

返回值说明

返回0表示成功,返回其他值表示失败,请参见aclError。




aclrtGetBufData

aclError aclrtGetBufData(const aclrtMbuf buf, void **dataPtr, size_t *size)

功能说明

获取共享Buffer的数据区指针和数据区长度,用户可以使用此指针填入数据。

接口调用顺序:调用aclrtAllocBuf或aclrtCopyBufRef接口申请到共享Buffer后,因此需由用户调用aclrtGetBufData接口获取共享Buffer的内存指针及长度后,再自行向内存中填充有效数据,然后再调用aclrtSetBufDataLen接口设置共享Buffer中有效数据的长度,且长度必须小于aclrtGetBufData获取到的size大小。

参数说明

参数名输入/输出说明
buf输入共享Buffer,类型定义请参见aclrtMbuf。
须通过acltdtAllocBuf或aclrtCopyBufRef接口申请获得。
dataPtr输出数据区指针(Device侧地址)。
size输出数据区的长度,单位为Byte。

返回值说明

返回0表示成功,返回其他值表示失败,请参见aclError。




aclrtSetBufUserData

aclError aclrtSetBufUserData(aclrtMbuf buf, const void *dataPtr, size_t size, size_t offset)

功能说明

设置共享Buffer的私有数据区数据,从用户内存拷贝到共享Buffer的私有数据区的指定偏移位置,用于设置控制信息作为上下文传递。当前默认私有数据区大小是96Byte,offset+size必须小于或等于96Byte,否则返回报错。

参数说明

参数名输入/输出说明
buf输出共享Buffer,类型定义请参见aclrtMbuf。
须通过aclrtAllocBuf或aclrtCopyBufRef接口申请获得。
dataPtr输入存放用户数据的内存地址指针。
size输入用户数据的长度,单位为Byte。
数据长度小于或等于96Byte。
offset输入地址偏移,单位为Byte。
偏移量小于或等于96Byte。

返回值说明

返回0表示成功,返回其他值表示失败,请参见aclError。




aclrtGetBufUserData

aclError aclrtGetBufUserData(const aclrtMbuf buf, void *dataPtr, size_t size, size_t offset)

功能说明

获取共享Buffer的私有数据区数据,偏移offset后,拷贝至用户申请的内存区域。当前默认私有数据区大小是96Byte,offset+size必须小于或等于96Byte,否则返回报错。

参数说明

参数名输入/输出说明
buf输入共享Buffer,类型定义请参见aclrtMbuf。
须通过aclrtAllocBuf或aclrtCopyBufRef接口申请获得。
dataPtr输出存放用户数据的内存地址指针。
size输入用户数据的长度,单位为Byte。
数据长度小于或等于96Byte。
offset输入地址偏移,单位为Byte。
偏移量小于或等于96Byte。

返回值说明

返回0表示成功,返回其他值表示失败,请参见aclError。




aclrtGetBufDataLen

aclError aclrtGetBufDataLen(aclrtMbuf buf, size_t *len)

功能说明

获取共享Buffer中有效数据的长度。

通过aclrtSetBufDataLen接口设置共享Buffer中有效数据的长度后,可调用本接口获取有效数据的长度,否则,通过本接口获取到的长度为0。

参数说明

参数名输入/输出说明
buf输入共享Buffer,类型定义请参见aclrtMbuf。
须通过aclrtAllocBuf或aclrtCopyBufRef接口申请获得。
len输出有效数据的长度,单位为Byte。

返回值说明

返回0表示成功,返回其他值表示失败,请参见aclError。




aclrtSetBufDataLen

aclError aclrtSetBufDataLen(aclrtMbuf buf, size_t len)

功能说明

设置共享Buffer中有效数据的长度。

接口调用顺序:调用aclrtAllocBuf或aclrtCopyBufRef接口申请到共享Buffer后,因此需由用户调用aclrtGetBufData接口获取共享Buffer的内存指针及长度后,再自行向内存中填充有效数据,然后再调用aclrtSetBufDataLen接口设置共享Buffer中有效数据的长度,且长度必须小于aclrtGetBufData获取到的size大小。

参数说明

参数名输入/输出说明
buf输入共享Buffer,类型定义请参见aclrtMbuf。
须通过aclrtAllocBuf或aclrtCopyBufRef接口申请获得。
len输入有效数据的长度,单位为Byte。

返回值说明

返回0表示成功,返回其他值表示失败,请参见aclError。




aclrtCopyBufRef

aclError aclrtCopyBufRef(const aclrtMbuf buf, aclrtMbuf *newBuf)

功能说明

对共享Buffer数据区的引用拷贝,创建并返回一个新的Mbuf管理结构指向相同的数据区。

参数说明

参数名输入/输出说明
buf输入共享Buffer。类型定义请参见aclrtMbuf。
共享Buffer可通过aclrtAllocBuf或aclrtCopyBufRef接口申请获得。
newBuf输出返回一个新的共享Buffer,指向相同的数据区。类型定义请参见aclrtMbuf。

返回值说明

返回0表示成功,返回其他值表示失败,请参见aclError。




aclrtAppendBufChain

aclError aclrtAppendBufChain(aclrtMbuf headBuf, aclrtMbuf buf)

功能说明

将共享Buffer添加到Mbuf链表中。共享Buffer链最大支持128个共享Buffer。共享Buffer可通过aclrtAllocBuf或aclrtCopyBufRef接口申请获得。

参数说明

参数名输入/输出说明
headBuf输入Mbuf链表中的第一个共享Buffer。类型定义请参见aclrtMbuf。
buf输入待添加的共享Buffer。类型定义请参见aclrtMbuf。

返回值说明

返回0表示成功,返回其他值表示失败,请参见aclError。




aclrtGetBufFromChain

aclError aclrtGetBufFromChain(aclrtMbuf headBuf, uint32_t index, aclrtMbuf *buf)

功能说明

从Mbuf链表中获取第index个共享Buffer。

参数说明

参数名输入/输出说明
headBuf输入Mbuf链表中的第一个共享Buffer。类型定义请参见aclrtMbuf。
index输入Mbuf链表中的索引(从0开始计数)。
buf输出输出第index个共享Buffer。类型定义请参见aclrtMbuf。

返回值说明

返回0表示成功,返回其他值表示失败,请参见aclError。




aclrtGetBufChainNum

aclError aclrtGetBufChainNum(aclrtMbuf headBuf, uint32_t *num)

功能说明

从Mbuf链表中获取共享Buffer的个数。

参数说明

参数名输入/输出说明
headBuf输入Mbuf链表中的第一个共享Buffer。类型定义请参见aclrtMbuf。
num输出共享Buffer的个数。

返回值说明

返回0表示成功,返回其他值表示失败,请参见aclError。

【免费下载链接】runtime本项目提供CANN运行时组件和维测功能组件。项目地址: https://gitcode.com/cann/runtime

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

http://www.jsqmd.com/news/787625/

相关文章:

  • 机器学习过拟合:从原理到实战的完整诊断与优化指南
  • AI Agent技能库:153个专业工具赋能AI编程助手实战指南
  • 基于MCP协议构建多模态AI工具集成平台:Stitch-Pro-MCP实战指南
  • MySQL数据库开发工具箱:从环境配置到性能优化的完整工程实践
  • 轻量级智能体框架MiniAgent:快速构建AI应用的核心原理与实践
  • ChatGPT伦理风险与学术诚信:AI对话机器人的双刃剑效应
  • ARM VFP架构与VLDR伪指令深度解析
  • Motif强化学习算法鲁棒性分析:超参数敏感性与数据依赖评估
  • 猫抓浏览器扩展:3步掌握全网视频资源捕获的终极方案
  • 命令行AI助手cgip:无缝集成大模型,提升终端工作效率
  • Kasetto:声明式AI技能管理工具,实现跨团队环境一致性
  • MAX3735A与DS1859接口设计中的保护机制与优化方案
  • AI Agent生态搜索器a2asearch-mcp:MCP协议下的工具发现与集成指南
  • 量化交易入门:基于TradeClaw开源工具的策略开发与回测实战
  • CANN/pyasc双曲正弦函数API文档
  • AI工作流编排框架aiflows:从消息驱动到DAG的智能应用开发实践
  • Crux:可组合终端工作区,重塑开发者工作流
  • 基于MCP协议的开源客户端openmcp-client:标准化AI工具集成实践
  • 初创团队如何借助Taotoken的透明计费与用量看板控制AI成本
  • Acontext:AI智能体技能记忆层的透明化设计与工程实践
  • 合肥十大专业灭鼠公司测评(2026):合规资质+长效防复发,靠谱服务商精选 - 速递信息
  • 构建自我进化的代码库:从CI/CD到智能修复的工程实践
  • MySQL-基础篇-MySQL概述
  • CANN/GE UDF日志接口简介
  • MediaCreationTool.bat实用指南:3种方法轻松绕过Windows 11硬件限制
  • 泰州群利起重设备有限公司,升降货梯品质保障厂家究竟有何过人之处?
  • 2026净化车间工程装修优选指南:微生物实验室|无尘车间装修实力派服务商 - 栗子测评
  • 大宗批发饮品,固体饮料厂家,哪家价格实惠款式丰富? - 速递信息
  • 2026惠州底盘维修哪家好?惠州专业汽车保养/更换变速箱油店铺口碑推荐指南 - 栗子测评
  • 自适应力差量化在布料解缠中的机器人应用