ROCT进程间共享内存实现分析

本文深入探讨了ROCT中进程间共享内存的实现,重点在于shareHandle的使用。export进程通过hsaKmtAllocMemroy、hsaKmtMapMemoryToGPU等API申请和共享内存,而import进程则通过hsaKmtRegisterSharedHandle进行导入。关键在于shareHandle,它在export进程中创建并与内存handle关联,在import进程中用于查找物理内存。共享share_handle可借助Linux标准库的shmget、shmat等函数实现。
摘要由CSDN通过智能技术生成

一.export进程涉及的API

(1) hsaKmtAllocMemroy——申请一块内存对应的虚拟地址和物理地址

(2) hsaKmtMapMemoryToGPU——为虚拟地址和物理地址建立映射关系

(3) hsaKmtShareMemory——将申请的内存共享出去(创建shareHandle,通过参数返回)

(4) hsaKmtUnmapMemoryToGPU——解除虚拟地址和物理内存的映射

(5) hsaKmtFreeMemory——释放分配的虚拟地址和物理内存

二.import进程涉及的API

(1) hsaKmtRegisterSharedHandle——导入export进程创建的共享内存(通过参数传入shareHandle),并为其分配虚拟地址

(2) hsaKmtMapMemoryToGPU——为虚拟地址和共享内存建立映射关系

(3) hsaKmtUnmapMemoryToGPU —— 解除虚拟地址和共享内存的映射

(4) hsaKmtDeregisterMemory —— 释放分配的虚拟地址

三.可见ROCT进程间内存共享实现的关键是shareHandle

1.shareHandle是什么?

struct kfd_ioctl_ipc_export_handle_args {
	__u64 handle;		/* to KFD */
	__u32 share_handle[4];	/* from KFD */
	__u32 gpu_id;		/* to KFD */
	__u32 flags;		/* to KF
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

denglin12315

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值