2 CUDA 学习笔记——一维索引与线程检测

本文介绍CUDA中基于网格和块计算全局数据访问索引的方法,通过一维信息计算线程索引,并提供了一个错误处理宏,用于封装所有CUDAAPI调用,简化错误检查流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

线程索引:基于以网格和块的一维信息来计算全局数据访问的唯一索引:

int idx = blockIdx.x*blockDim.x+treadIdx.x;

 

定义一个错误处理宏封装所有的CUDA API调用,简化错误检查过程:(\ 不能省去)

#define CHECK(call)                                                                      \

{

    const cudaError_t error =call;                                                       \

    if(error != cudaSuccess)                                                                \

    {                                                                                                \

        printf("Error: %s:%d,", __FILE__, __LINE__);                             \

        printf("code:%d, reason: %s \n",error,cudaGetErrorString(error));   \

        exit(1);                                                                                     \

    }

}

调用方式如下,此仅以调试为目的的,核函数启动后添加这个检查点会阻塞主机端线程,使该检查点成为全局屏障。

CHECK(cudaDeviceSynchronize());

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值