Atlas 200/300/500 推理产品,不支持该接口。
申请Device物理内存,并返回一个物理内存handle。
本接口可配合aclrtReserveMemAddress接口(申请虚拟内存)、aclrtMapMem接口(建立虚拟内存与物理内存之间的映射)使用,以便申请地址连续的虚拟内存、最大化利用物理内存地址的目的。
本接口可配合aclrtMemExportToShareableHandle接口(导出物理内存handle)、aclrtMemImportFromShareableHandle(导入共享handle)使用,用于实现多进程之间的物理内存共享。同时,也支持在共享物理内存时,使用虚拟内存,请参见aclrtMemExportToShareableHandle接口处的说明。
在Atlas 推理系列产品上,由于Device上没有HBM内存,使用本接口申请ACL_HBM_MEM_HUGE类型的内存时,AscendCL系统内部自动转换为申请ACL_DDR_MEM_HUGE类型的DDR内存。
在 Atlas 200I/500 A2推理产品上,由于Device上没有HBM内存,使用本接口申请ACL_HBM_MEM_HUGE类型的内存时,AscendCL系统内部自动转换为申请ACL_DDR_MEM_HUGE类型的DDR内存。
aclError aclrtMallocPhysical(aclrtDrvMemHandle *handle, size_t size, const aclrtPhysicalMemProp *prop, uint64_t flags)
参数名 |
输入/输出 |
说明 |
---|---|---|
handle |
输出 |
存放物理内存信息的handle。 |
size |
输入 |
物理内存大小,单位Byte。 先调用aclrtMemGetAllocationGranularity接口获取内存申请粒度,然后再调用本接口申请物理内存时size按获取到的内存申请粒度对齐,以便节约内存。 当前内存申请粒度固定2M,因此size当前需按照2M对齐。 |
prop |
输入 |
物理内存属性信息。 |
flags |
输入 |
预留,当前只能设置为0。 |
返回0表示成功,返回其它值表示失败。