我是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
答案 0 :(得分:0)
您对clEnqueueMapBuffer
的第二次通话应该是CL_MAP_READ
,而不是CL_MAP_WRITE
,因为您想要阅读数据。