我正在尝试调用cudppSort来对一组键/值进行排序。我正在使用以下代码来设置排序算法:
CUDPPConfiguration config;
config.op = CUDPP_ADD;
config.datatype = CUDPP_UINT;
config.algorithm = CUDPP_SORT_RADIX;
config.options = CUDPP_OPTION_KEY_VALUE_PAIRS | CUDPP_OPTION_FORWARD | CUDPP_OPTION_EXCLUSIVE;
CUDPPHandle planHandle;
CUDPPResult result = cudppPlan(&planHandle, config, number_points, 1, 0);
if (CUDPP_SUCCESS != result) {
printf("ERROR creating CUDPPPlan\n");
exit(-1);
}
程序退出,但是在线:
CUDPPResult result = cudppPlan(&planHandle, config, number_points, 1, 0);
并打印到stdout:
Cuda error: allocScanStorage in file 'c:/the/path/to/release1.1/cudpp/src/app/scan_app.cu' in line 279 : invalid configuration argument.
我查看了scan_app.cu中的行。是的,
CUT_CHECK_ERROR("allocScanStorage");
显然我的配置有一个错误导致allocScanStorage爆炸。函数中只有两次调用CUDA_SAFE_CALL,我没有看到为什么与配置有任何关系的原因。
我的配置有什么问题?
答案 0 :(得分:1)
因此,这并不是一个悬而未决的问题(我不确定这是否是正确的SO礼仪,但似乎一个回答的问题不应该无法解答......),我正在复制我在上面作出的评论作为答案,因为它是解决方案:
我想到了这一点(我现在还在学习CUDA。)因为错误检查是异步错误,如果你不经常检查它们会出现在奇怪的地方。在我调用cudppPlan之前,我的代码导致了错误,但是因为我没有检查错误,所以cudppPlan报告了错误,就好像它是在cudppPlan中一样。