aclrtMapMem
产品支持情况
产品  | 
是否支持  | 
|---|---|
√  | 
|
√  | 
|
√  | 
|
√  | 
|
√  | 
|
√  | 
功能说明
将虚拟内存映射到物理内存。
本接口需与以下其它接口配合使用,以便申请地址连续的虚拟内存、最大化利用物理内存:
- 申请虚拟内存(aclrtReserveMemAddress接口);
 - 申请物理内存(aclrtMallocPhysical接口);
 - 将虚拟内存映射到物理内存(aclrtMapMem接口);
 - 执行任务(调用具体的任务接口);
 - 取消虚拟内存与物理内存的映射(aclrtUnmapMem接口);
 - 释放物理内存(aclrtFreePhysical接口);
 - 释放虚拟内存(aclrtReleaseMemAddress接口)。
 
函数原型
aclError aclrtMapMem(void *virPtr, size_t size, size_t offset, aclrtDrvMemHandle handle, uint64_t flags)
参数说明
参数名  | 
输入/输出  | 
说明  | 
|---|---|---|
virPtr  | 
输入  | 
待映射的虚拟内存地址指针。 这个地址不一定是起始地址,用户也可以根据起始地址自行偏移后,再映射。 虚拟内存地址当前需按照2M对齐。  | 
size  | 
输入  | 
待映射的内存大小,单位Byte。 size当前需按照2M对齐。  | 
offset  | 
输入  | 
物理内存偏移值,当前只能设置为0。  | 
handle  | 
输入  | 
物理内存信息handle。 通过aclrtReserveMemAddress接口预留出来的一整段虚拟地址,由用户自行管理、划分时,不能同时与两个Device上申请的物理地址绑定。 通过aclrtReserveMemAddress接口预留出来的一整段虚拟地址,由用户自行管理、划分时,不能同时与aclrtMallocPhysical、aclrtMemImportFromShareableHandle接口输出的handle绑定。  | 
flags  | 
输入  | 
预留,当前只能设置为0。  | 
返回值说明
返回0表示成功,返回其他值表示失败,请参见aclError。
约束说明
父主题: 内存管理