方已 2017-06-08 16:09 采纳率: 100%
浏览 951
已采纳

一个cuda代码,不明白哪里有错,请指教

这是设备端代码,将tmp0中的数据移动到arr数组中。每个块256个线程,块的数量根据输入的n划分,不过我不知道这有没有关系。。。。求各位解答。。。。。。。。。。
图片说明

  • 写回答

2条回答 默认 最新

  • yangbo50304 2017-06-09 01:40
    关注

    __syncthreads 是所有一个block内所有线程运行到这里后才往下运行。你放到for循环里,是不是就错了呢?
    按照你所述的需求,就不应该有for语句。

     __global_ void test(int* arr, int* tmp0)
     {
         int tid = blockDim.x*blockIdx.x+threadIdx.x;
         arr[tid] = tmp0[tid];
     }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?