This discussion has been locked.
You can no longer post new replies to this discussion. If you have a question you can start a new discussion

Zero Copy Buffers using cl_arm_import_memory extension in OpenCL 1.2 - arm mali midgard GPUs.

Hi,

I wish to allocate a vector and use it's data pointer to allocate a zero copy buffer on the GPU. There is this cl_arm_import_memory extension which can be used to do this. But I am not sure wether its supported for all mali midgard OpenCL drivers or not.

I was going through this link and I am quite puzzled by the following lines : -

      If the extension string cl_arm_import_memory_host is exposed then importing
      from normal userspace allocations (such as those created via malloc) is
      supported.

What exactly does these lines mean ? I am specifically working on rockchip's RK3399 boards. Kindly help.
Parents
  • Hi,

    This is expected behaviour. What you are likely measuring (I can confirm if you tell me exactly how you're measuring this) is the cost of maintaining data consistency between the CPU and GPU.

    Conceptually, running a kernel on imported host memory has roughly the same cost as unmapping a buffer, running the kernel and mapping the buffer on the CPU again.

    You can reduce that cost to a minimum by batching kernels into as few flush groups as possible. Later drivers are better at this.

    Regards,

    Kévin

Reply
  • Hi,

    This is expected behaviour. What you are likely measuring (I can confirm if you tell me exactly how you're measuring this) is the cost of maintaining data consistency between the CPU and GPU.

    Conceptually, running a kernel on imported host memory has roughly the same cost as unmapping a buffer, running the kernel and mapping the buffer on the CPU again.

    You can reduce that cost to a minimum by batching kernels into as few flush groups as possible. Later drivers are better at this.

    Regards,

    Kévin

Children