10_ipc_memory_withpid
描述
本样例展示了同一个Device、两个进程间的内存共享,在共享内存时启用进程白名单校验。
支持的产品型号
- Atlas A3 训练系列产品/Atlas A3 推理系列产品
- Atlas A2 训练系列产品/Atlas 800I A2 推理产品/A200I A2 Box 异构组件
- Atlas 推理系列产品
- Atlas 训练系列产品
编译运行
环境安装详情以及运行详情请见example目录下的README。
CANN RUNTIME API
在该Sample中,涉及的关键功能点及其关键接口,如下所示:
- 初始化
- 调用aclInit接口初始化AscendCL配置。
- 调用aclFinalize接口实现AscendCL去初始化。
- Device管理
- 调用aclrtSetDevice接口指定用于运算的Device。
- 调用aclrtResetDeviceForce接口强制复位当前运算的Device,回收Device上的资源。
- Stream管理
- 调用aclrtCreateStream接口创建Stream。
- 调用aclrtDestroyStreamForce接口强制销毁Stream,丢弃所有任务。
- 内存管理
- 调用aclrtMalloc接口申请Device上的内存。
- 调用aclrtFree接口释放Device上的内存。
- 调用aclrtDeviceGetBareTgid接口获取当前进程的进程ID。
- 调用aclrtIpcMemGetExportKey接口将指定Device内存设置为IPC共享内存,并返回共享内存key。
- 调用aclrtIpcMemSetImportPid接口设置IPC共享内存的进程白名单。
- 调用aclrtIpcMemImportByKey接口获取key的信息,并返回本进程可以使用的Device内存地址指针。
- 调用aclrtIpcMemClose接口关闭IPC共享内存。
已知issue
暂无