如何在OpenCL中打印内核的结果?

时间:2014-11-28 16:24:06

标签: c++ opencl

我是OpenCL的新手。我正在尝试使用OpenCL c ++内核语言扩展http://amd-dev.wpengine.netdna-cdn.com/wordpress/media/2012/10/CPP_kernel_language.pdf。我正在尝试使用本文档的第10页代码打印结果。请从本文档中找到以下代码,如果在任何地方出错,请纠正我。

class Test{
public:
    void setX(int value){ x = value;}
    int getX(){ return x;}
private:
    int x;
};

int main() {
    cl_mem classObj = clCreateBuffer(context, CL_MEM_USE_HOST_PTR, sizeof(Test), &tempClass, &ret);
    void* dm_idata = clEnqueueMapBuffer(command_queue, classObj, CL_TRUE, CL_MAP_WRITE, 0 , sizeof(Test), 0, NULL, NULL, &ret);
    tempClass.setX(10); //prints this value
    clEnqueueUnmapMemObject(command_queue, classObj, dm_idata, 0, NULL, NULL);//class is passed to the device
    ret = clEnqueueNDRangeKernel(command_queue, kernel, 1, NULL, &global_item_size, &local_item_size, 0, NULL, NULL);
    clEnqueueMapBuffer(command_queue, classObj, CL_TRUE, CL_MAP_WRITE, 0, sizeof(Test), 0, NULL, NULL, &ret);//class is passed back to the host
    printf("\n temp value: %d\n", tempClass.getX());
}

这是内核代码。

class Test {
    setX (int value);
private:
     int x;
};

__kernel void foo(__global Test* Inclass){   

if(get_global_id(0) == 0)
    Inclass->setX(6);
}

它从主机代码打印值。我需要从内核获得结果。任何帮助都非常感谢。

我得到的结果是

临时值= 10

1 个答案:

答案 0 :(得分:0)

您对clEnqueueMapBuffer的第二次通话应该是CL_MAP_READ,而不是CL_MAP_WRITE,因为您想要阅读数据。