15

我在 nvidia GPU 上使用 OpenCL,当我尝试执行内核时,我不断收到 CL_INVALID_KERNEL_ARGS。我已经把它降级为一个非常简单的程序:

__kernel void foo(int a, __write_only image2d_t bar)
{
  int 2 坐标 = {0, get_global_id(0)};
  write_imagef(bar, coords, (float4)a);
}

使用以下 C 程序(为简洁起见,跳过了初始化和错误检查位)

cl_kernel foo = clCreateKernel(program, "foo", &err);
诠释一个= 42;
clSetKernelArg(foo, 0, sizeof(int), &a);

cl_image_format fmt = {CL_INTENSITY, CL_FLOAT};
cl_mem bar = clCreateImage2D(ctx, CL_MEM_WRITE_ONLY|CL_MEM_ALLOC_HOST_PTR, &fmt, 100, 1, 0, NULL, &err));
clSetKernelArg(foo, 1, sizeof(cl_mem), &bar);

size_t gws[] = {100};
大小_t lws[] = {100};
cl_event 事件;
clEnqueueNDRangeKernel(queue, foo, 1, NULL, gws, lws, 0, NULL, &evt);
clFinish(队列);

clEnqueueNDRangeKernel 不断返回 CL_INVALID_KERNEL_ARGS。有任何想法吗?

4

2 回答 2

5

请参阅https://stackoverflow.com/a/20566270/431528

您传递的缓冲区对象有多大?__constant 参数是从单独的内存空间而不是从全局内存分配的,因此您可能已经用完了常量内存

检查CL_DEVICE_MAX_CONSTANT_BUFFER_SIZE使用clGetDeviceInfo以确保您不超过该尺寸。

于 2017-06-22T10:39:33.150 回答
4

您正在尝试将主机上的变量传递给内核。您需要创建一个cl_mem变量,然后使用 复制该值clEnqueueWriteBuffer,然后将cl_memorcl_int变量传递给内核。除此之外,您的代码对我来说看起来不错。

于 2013-09-12T05:37:30.077 回答