下载
中文
注册

函数:dvpp_malloc

C函数原型

aclError acldvppMalloc(void **devPtr, size_t size)

Python函数

dev_ptr, ret = acl.media.dvpp_malloc(size)

函数功能

该接口主要用于分配内存给Device侧媒体数据处理时使用,申请的大页内存满足数据处理的要求(例如,内存首地址128对齐)。

输入说明

size:int,申请内存的大小,单位Byte。

返回值说明

dev_ptr:int,Device上已分配内存的指针地址。

ret:int,错误码。
  • 返回0表示成功。
  • 返回其它值表示失败。

约束说明

  • 调用该接口申请内存后,如果内存不再使用,需及时调用acl.media.dvpp_free接口释放内存。
  • 频繁调用acl.media.dvpp_malloc接口申请内存、调用acl.media.dvpp_free接口释放内存,会损耗性能,建议用户提前做内存预先分配或二次管理,避免频繁申请/释放内存。
  • 调用acl.media.dvpp_malloc接口申请内存时,会对用户输入的“size”按向上对齐成32整数倍后,再多加32字节。
  • 媒体数据处理的输出作为模型推理的输入时,若用户使用本接口申请大块内存并自行划分、管理内存时,每段内存需同时满足以下要求:
    • 内存大小向上对齐成32整数倍+32字节(m = ALIGN_UP[len, 32] + 32字节)。
    • 内存起始地址需满足128字节对齐(ALIGN_UP[m, 128])。
    说明:

    “len”表示某段内存的大小,ALIGN_UP[len,k]表示向上按“k”字节对齐:((len - 1) / k + 1) * k。

  • 调用该接口申请大页内存失败,仅表示系统内的大页内存不够。

    Atlas 200/300/500 推理产品关于系统内预留大页的说明请参见总体说明

    Atlas A2训练系列产品关于系统内预留大页的说明请参见总体说明

参考资源

接口调用流程及示例,参见媒体数据处理V1