OpenCL clCreateBuffer占用太多时间

在高通平台的图像处理算法中,使用OpenCL加速时发现clCreateBuffer初始化和释放时间较长,约600ms。尝试使用ION内存优化,虽然创建buffer时间减至零点几毫秒,但创建ION内存仍需数十毫秒,首次调用时总时间变化不大。后续调用时间显著降低。使用ION内存导致系统内存占用减少,但问题未完全解决。决定采用ION内存,因在Camera相关代码中已有应用且不影响算法运行时间。
摘要由CSDN通过智能技术生成

最近在做一个图像处理的算法,跑在高通平台上,需要使用OpenCL加速。代码分为三个部分:
1. 初始化
2. 处理图像
3. 释放资源

为了尽可能地减少算法的运行时间,我将一切可以预处理的内容都放到了初始化中,其中就包括了创建buffer。在初始化中,我调用clCreateBuffer()创建了9个buffer,共计约占用600MB内存。然后在处理图像中重复使用这些buffer,最后在释放资源中释放所有buffer。

但是在实际测试后发现,每调用一次clCreateBuffer(),都会花费大约70ms的时间,这样一来,创建所有buffer就花费了约600ms的时间。同样地,在释放这些buffer时,每个也会花费几十毫秒的时间。如此,初始化释放资源的时间就令人比较难以接受。

经同事提醒,我想到了高通文档《Qualcomm® Snapdragon™ Mobile Platform OpenCL General Programming and Optimization》中提到的ION内存。文档中说,使用ION可以避免内存拷贝。那么对缩短创建buffer的时间会不会也有帮助呢?毕竟在我的印象中,使用new创建一段几百MB的内存也才花费几毫秒的时间。

使用ION内存来创建OpenCL buffer需要cl_qcom_ion_host_ptr扩展(在上述文档中有提到),其说明及示例代码在OpenCL官网可以查到,为了方便,我直接贴

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值