函数:malloc_host
产品支持情况
产品 |
是否支持 |
---|---|
|
√ |
|
√ |
|
√ |
|
√ |
|
√ |
|
√ |
功能说明
应用程序在Host上运行时,调用该接口申请的是Host内存(该内存是锁页内存),由系统保证内存首地址64字节对齐。
应用程序在Device上运行时,调用该接口申请的是Device内存,且Device上的内存按普通页申请,如需首地址64字节对齐,需要用户自行处理对齐。
函数原型
- C函数原型
1
aclError aclrtMallocHost(void **hostPtr, size_t size)
- python函数
1
host_ptr, ret= acl.rt.malloc_host(size)
参数说明
参数名 |
说明 |
---|---|
size |
int,申请内存的大小,单位Byte。size不能为0。 |
返回值说明
返回值 |
说明 |
---|---|
host_ptr |
int,指向Host上已分配内存的指针地址。 |
ret |
int,错误码,返回0表示成功,返回其它值表示失败。 |
约束说明
- 本接口分配的内存不会对内容进行初始化,建议在使用内存前先调用acl.rt.memset接口先初始化内存,清除内存中的随机数。
- 本接口内部不会进行隐式的Device同步或流同步。如果申请内存成功或申请内存失败会立刻返回结果。
- 使用acl.rt.malloc_host接口申请的内存,需要通过acl.rt.free_host接口释放内存。
- 使用acl.rt.malloc_host接口分配过多的锁页内存,将导致操作系统用于分页的物理内存变少,从而降低系统整体的性能。
- 频繁调用acl.rt.malloc_host接口申请内存、调用acl.rt.free_host接口释放内存,会损耗性能,建议用户提前做内存预先分配或二次管理,避免频繁申请/释放内存。
- 若用户使用本接口申请大块内存并自行划分、管理内存时,每段内存需同时满足以下需求:
- 内存大小向上对齐成32整数倍加32字节(m = ALIGN_UP[len, 32] + 32字节)。
- 内存起始地址需满足64字节对齐(ALIGN_UP[m, 64])。
len表示某段内存的大小,ALIGN_UP[len, k]表示向上按k字节对齐:((len - 1) / k + 1) * k。
父主题: 内存管理