二维数组作为 OpenCL 内核参数

2D Array as OpenCL kernel argument

非常直接的问题:如何使用二维数组作为 OpenCL 内核参数?

常识建议使用

__kernel void main(__global <datatype> **<name>),

然而编译器似乎并没有被这个想法逗乐:

kernel parameter cannot be declared as a pointer to a pointer.

我是否在监督显而易见的事情,或者究竟是什么,我在这里做错了吗?

编辑:

主机 (c++) 数据结构如下所示:

vector<vector<Element>>,

其中 Element 是一个包含同一数组内子节点索引的结构。基本上是指针。

您需要将二维数组缩小为一维数组。

主持人:

int array[50][50];
int * ptr_to_array_data = array[0];
int width = 50, height = 50;
cl_mem device_array = clCreateBuffer(/*context*/, CL_MEM_READ_WRITE | CL_MEM_COPY_HOST_PTR, 50 * 50 * sizeof(int), ptr_to_array_data, /*&err*/);
clSetKernelArg(/*kernel*/, 0, sizeof(cl_mem), &device_array);
clSetKernelArg(/*kernel*/, 1, sizeof(cl_int), &width);
clSetKernelArg(/*kernel*/, 2, sizeof(cl_int), &height);

设备:

kernel function(global int * array, int width, int height) {
    int id = get_global_id(0);
    int our_value = array[id];
    int x = id % width; //This will depend on how the memory is laid out in the 2d array. 
    int y = id / width; //If it's not row-major, then you'll need to flip these two statements.
    /*...*/
}

如果您的 2D 数组没有像我的示例所暗示的那样连续存储在内存中,您将需要滚动自己的函数以确保整个内存连续存储在单个堆分配的对象中。