1

是否有一个 CUDA 函数用于打印调用者提供的错误消息和描述当前 cudaStatus(或调用者提供的 cudaStatus)的错误消息 a-laperror ()

4

1 回答 1

3

我认为没有内置的 cuda API 函数可以做到这一点。

该宏将执行您所描述的操作:

#define cudaCheckErrors(msg) \
    do { \
        cudaError_t __err = cudaGetLastError(); \
        if (__err != cudaSuccess) { \
            fprintf(stderr, "Fatal error: %s (%s at %s:%d)\n", \
                msg, cudaGetErrorString(__err), \
                __FILE__, __LINE__); \
            fprintf(stderr, "*** FAILED - ABORTING\n"); \
            exit(1); \
        } \
    } while (0)

上述宏的用法只是在任何 cuda API 调用或任何 cuda 内核调用之后插入它。建议在每次cuda API 调用和内核调用之后插入它,例如:

cudaMemcpy(d_A, A, sizeof(A), cudaMemcpyHostToDevice);
cudaCheckErrors("cudaMemcpy fail");
my_kernel<<<blocks, threads>>>(d_A);
cudaCheckErrors("kernel launch fail");
cudaDeviceSynchronize();
cudaCheckErrors("cudaDeviceSynchronize fail");

它打印用户定义的消息 ( msg) 并解码 cuda API 错误并打印相应的错误字符串消息:

Fatal error: kernel launch fail (invalid configuration argument at t128.cu:44)
*** FAILED - ABORTING

您可能还对此处的错误处理讨论感兴趣。

针对以下问题,您可以轻松制作函数调用版本:

void cudaCheckErrors(char *msg){
        cudaError_t __err = cudaGetLastError(); \
        if (__err != cudaSuccess) { fprintf(stderr, "Fatal error: %s (%s at %s:%d)\n", msg, cudaGetErrorString(__err),  __FILE__, __LINE__);
            fprintf(stderr, "*** FAILED - ABORTING\n");
            exit(1);
        }
}
于 2013-04-29T16:05:54.790 回答