我正在尝试使用我的AMD CPU上的OpenCL 1.1 C ++处理图像。
特征是:
using CPU: AMD Turion(tm) 64 X2 Mobile Technology TL-60
initCL:CL_DEVICE_IMAGE2D_MAX_WIDTH :8192
initCL:CL_DEVICE_IMAGE2D_MAX_HEIGHT :8192
initCL:timer resolution in ns:1
initCL:CL_DEVICE_GLOBAL_MEM_SIZE in bytes:1975189504
initCL:CL_DEVICE_GLOBAL_MEM_CACHE_SIZE in bytes:65536
initCL:CL_DEVICE_MAX_CONSTANT_BUFFER_SIZE in bytes:65536
initCL:CL_DEVICE_LOCAL_MEM_SIZE in bytes:32768
initCL:CL_DEVICE_MAX_COMPUTE_UNITS:2
initCL:CL_DEVICE_MAX_WORK_GROUP_SIZE:1024
initCL:CL_DEVICE_MAX_WORK_ITEM_DIMENSIONS:3
initCL:CL_DEVICE_MAX_WORK_ITEM_SIZES:dim=0, size 1024
initCL:CL_DEVICE_MAX_WORK_ITEM_SIZES:dim=1, size 1024
initCL:CL_DEVICE_MAX_WORK_ITEM_SIZES:dim=2, size 1024
createCLKernel:mean_value
createCLKernel:CL_KERNEL_WORK_GROUP_SIZE:1024
createCLKernel:CL_KERNEL_LOCAL_MEM_SIZE used by the kernel in bytes:0
createCLKernel:CL_KERNEL_PREFERRED_WORK_GROUP_SIZE_MULTIPLE:1
内核目前是空的:
__kernel void mean_value(image2d_t p_image,
__global ulong4* p_meanValue)
{
}
执行调用是:
cl::NDRange l_globalOffset;
// The global worksize is the entire image
cl::NDRange l_globalWorkSize(l_width, l_height);
// Needs to be determined
cl::NDRange l_localWorkSize;//(2, 2);
// Computes the mean value
cl::Event l_profileEvent;
gQueue.enqueueNDRangeKernel(gKernelMeanValue, l_globalOffset, l_globalWorkSize,
l_localWorkSize, NULL, &l_profileEvent);
如果l_width=558
和l_height=328
,l_localWorkSize
不能大于(2,2),否则我会收到此错误:“工作组大小无效”
是因为我只有2个核心吗? 是否有规则来确定l_localWorkSize?
答案 0 :(得分:0)
您可以使用 clGetDeviceInfo 函数检查2件事:
CL_DEVICE_MAX_WORK_GROUP_SIZE 检查4对您的工作组来说是不是太大了
CL_DEVICE_MAX_WORK_ITEM_SIZES 检查维度上的工作项数量是否太大。
并且组大小可能限于核心数这一事实是有意义的:如果你有工作项间通信/同步,你会希望它们同时被执行,否则OpenCL驱动程序会有模仿这可能至少很难,在一般情况下可能是不可能的。
答案 1 :(得分:0)
我在OpenCL规范中读到enqueueNDRangeKernel()
如果l_globalWorkSize
可被l_localWorkSize
整除,则{{1}}成功。就我而言,我可以设置为(2,41)。