【发布时间】:2017-11-26 10:24:14
【问题描述】:
当我尝试将数据循环回内核函数时,我的代码中断,经过几次迭代后它停止工作,只给出 0 作为答案,有人知道为什么吗?如果我循环调用内核的整个方法,它可以工作,但要慢得多
cl_mem *ptrInput = &Pressure_BUFF;
cl_mem *ptrOutput = &Pressure_OUT_BUFF;
for(int i = 0; i<Interaction_per_frame; i++){
clSetKernelArg(kernel_2, 4, sizeof(Pressure_BUFF), ptrInput);
clEnqueueNDRangeKernel(queue_2, kernel_2, 1, NULL,&work_units_per_kernel, NULL, 0, NULL, NULL);
clFinish(queue_2);//Terminar de calcular
cl_mem *ptrTpm = ptrInput;
ptrInput = ptrOutput;
ptrOutput = ptrTpm;
}
clEnqueueReadBuffer(queue_2, Pressure_OUT_BUFF, CL_TRUE, 0,sizeof(Pressure), Pressure, 0, NULL, NULL);
【问题讨论】:
-
使用
clEnqueueCopyBuffer代替 cl_mem 杂耍。
标签: c++ visual-studio kernel opencl