完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
|
我正在使用基于 i.MX8M 的平台和 Vivante GC7000Lite GPU。(来自 Variscite 的 DART-MX8M)我正在尝试运行 OpenCL 加速的 OpenCV 示例代码,但我没有得到我期望的结果,想知道是否缺少某些信息。例如,如果我尝试 opencv_test_optflow:
$ /usr/bin/opencv_test_optflow [ WARN:0] 使用全球可访问的缓存目录。这可能不安全:/var/tmp/ [INFO:0] 已成功初始化 OpenCL 缓存目录:/var/tmp/opencv/3.4.0/opencl_cache/ [INFO:0] 正在为上下文准备 OpenCL 缓存配置:32 位--Vivante_Corporation--Vivante_OpenCL_Device_GC7000L_6214_0000--OpenCL_1_2_V6_2_4_p1_150331 调用期间 OpenCL 错误 CL_INVALID_WORK_GROUP_SIZE (-54):clEnqueueNDRangeKernel('sobel3', dims=2, globalsize=592x400 x1, localsize=16x16x1) sync=false OpenCL 错误 CL_INVALID_WORK_GROUP_SIZE (-54) 在调用期间 : clEnqueueNDRangeKernel('maxEigenVal', dims=1, globalsize=4096x1x1, localsize=1024x1x1) sync=false 调用期间 OpenCL 错误 CL_INVALID_WORK_GROUP_SIZE (-54):clEnqueueNDRangeKernel('pyrDown', dims=2, globalsize=768x97x1, localsize=256x1x1) sync=false 调用期间 OpenCL 错误 CL_INVALID_WORK_GROUP_SIZE (-54):clEnqueueNDRangeKernel('pyrDown',暗淡= 2 , globalsize=768x97x1, localsize=256x1x1) sync=false 调用期间 OpenCL 错误 CL_INVALID_WORK_GROUP_SIZE (-54): clEnqueueNDRangeKernel('pyrDown', dims=2, globalsize=512x49x1, localsize=256x1x1) sync=false OpenCL 错误 CL_INVALID_WORK_GROUP_尺码 (-54 )通话期间:clEnqueueNDRangeKernel('pyrDown', dims=2, globalsize=512x49x1, localsize=256x1x1) sync=false OpenCL 错误 CL_INVALID_WORK_GROUP_SIZE (-54) 通话期间:clEnqueueNDRangeKernel('pyrDown', dims=2, globalsize=256x25x1, localsize= 256x1x1) 同步=假 调用期间 OpenCL 错误 CL_INVALID_WORK_GROUP_SIZE (-54):clEnqueueNDRangeKernel('pyrDown', dims=2, globalsize=256x25x1, localsize=256x1x1) sync=false 调用期间 OpenCL 错误 CL_INVALID_WORK_GROUP_SIZE (-54):clEnqueueNDRangeKernel('pyrDown',暗淡= 2 , globalsize=768x97x1, localsize=256x1x1) sync=false 调用期间 OpenCL 错误 CL_INVALID_WORK_GROUP_SIZE (-54): clEnqueueNDRangeKernel('pyrDown', dims=2, globalsize=768x97x1, localsize=256x1x1) sync=false OpenCL 错误 CL_INVALID_WORK_GROUP_尺码 (-54 )调用期间:clEnqueueNDRangeKernel('pyrDown', dims=2, globalsize=512x49x1, localsize=256x1x1) sync=false OpenCL 错误 CL_INVALID_WORK_GROUP_SIZE (-54) 调用期间:clEnqueueNDRangeKernel('pyrDown', dims=2, globalsize=512x49x1, localsize= 256x1x1) 同步=假 调用期间 OpenCL 错误 CL_INVALID_WORK_GROUP_SIZE (-54):clEnqueueNDRangeKernel('pyrDown', dims=2, globalsize=256x25x1, localsize=256x1x1) sync=false 调用期间 OpenCL 错误 CL_INVALID_WORK_GROUP_SIZE (-54):clEnqueueNDRangeKernel('pyrDown',暗淡= 2 , globalsize=256x25x1, localsize=256x1x1) sync=false /usr/src/debug/opencv/3.4+gitAUTOINC+6d4f66472e_81ca8dab86_a62e20676a_34e4206aef_fccf7cd6a4-r0/contrib/modules/optflow/test/test_ OF_accuracy.cpp:236: 预期失败: (calcRMSE(GT , flow)) <= (target_RMSE), actual: 0.5805 vs 0.55 [ FAILED ] DenseOpticalFlow_PCAFlow.ReferenceAccuracy (65669 ms) [--------] 来自 DenseOpticalFlow_PCAFlow 的 1 次测试(总共 65669 ms) 我不明白的是为什么返回 CL_INVALID_WORK_GROUP_SIZE。localsize 平均分为 global size。它小于全球规模。它小于 1024(最大工作组大小)。为什么会失败?如果我将 NULL 作为 localsize 传递给 clEnqueueNDRangeKernel 它可以工作,但这不是通用解决方案,因为我需要手动修改所有依赖于已知 localsize 的内核。在我看来,这似乎是底层平台中的一个潜在错误,无论是在 GPU 本身还是在 BSP 中。但是,libVivanteOpenCL 似乎是封闭源代码,因此我无法进一步调查。 |
|
相关推荐
|
|
只有小组成员才能发言,加入小组>>
2139个成员聚集在这个小组
加入小组我的项目我做主,使用GN+Ninja来完成构建系统(VSCode开发RT106X)
37411 浏览 0 评论
NXP IMX8应用处理器快速入门必备:技巧、使用、设计指南
6803 浏览 1 评论
7833 浏览 1 评论
7667 浏览 0 评论
NXP i.MX6UL开发板(linux系统烧录+规格+硬件+模块移植)使用手册
5090 浏览 0 评论
1585浏览 2评论
关于NINA-W132 Wi-Fi模块SPI通信遇到的疑问求解
1225浏览 2评论
如何在MPC PowerPC MCU上首次刷写后禁用BDM?
770浏览 1评论
将HFREFR和LFREFR寄存器值设置为错误的值来将故障注入CMU,但CMU_ISR值始终为零,为什么?
761浏览 1评论
将SPSDK for FRDM-MCX-W71 SDK与VS一起安装时出现hidapi构建错误怎么解决?
705浏览 1评论
/9
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-12-15 07:36 , Processed in 0.452642 second(s), Total 40, Slave 33 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191

淘帖
504