当从CUDA Samples中删除cutil.h头时,会引入一些新的头文件,如helper_cuda.h,helper_functions.h。
我使用的主要关键字之一是CUDA_CHECK_ERROR,我认为它已被checkCudaErrors取代。
在我的大多数代码中,宏编译并运行良好。但是当我在具有名为check(..)的函数的类中使用它时,checkCudaErrors函数会产生编译错误。
以下是一个例子:
#include <stdio.h>
#include <cuda_runtime.h>
#include <helper_cuda.h>
#include <helper_functions.h>
template<typename T>
class Trivial {
public:
void check()
{
}
void initialize()
{
checkCudaErrors(cudaMalloc(NULL, 1));
}
T val;
};
int main(int argc, char **argv)
{
Trivial<int> tt;
tt.initialize();
return 0;
}
和编译结果:(使用GCC 4.5编译时也会出现相同的错误!)
1>------ Build started: Project: ZERO_CHECK, Configuration: Release x64 ------
2>------ Build started: Project: massivecc, Configuration: Release x64 ------
2> trivial_main.cpp
2>..\src\trivial_main.cpp(19): error C2660: 'Trivial<T>::check' : function does not take 4 arguments
2> with
2> [
2> T=int
2> ]
2> ..\src\trivial_main.cpp(18) : while compiling class template member function 'void Trivial<T>::initialize(void)'
2> with
2> [
2> T=int
2> ]
2> ..\src\trivial_main.cpp(29) : see reference to class template instantiation 'Trivial<T>' being compiled
2> with
2> [
2> T=int
2> ]
3>------ Skipped Build: Project: ALL_BUILD, Configuration: Release x64 ------
3>Project not selected to build for this solution configuration
========== Build: 1 succeeded, 1 failed, 1 up-to-date, 1 skipped ==========
删除模板参数时会出现同样的错误。
答案 0 :(得分:0)
我必须将check(..)函数的定义从helper_functions.h复制到我的类的头文件中才能编译该类。
#include <stdio.h>
#include <cuda_runtime.h>
#include <helper_cuda.h>
#include <helper_functions.h>
class Trivial {
public:
template< typename T >
bool check(T result, char const *const func, const char *const file, int const line)
{
if (result) {
fprintf(stderr, "CUDA error at %s:%d code=%d(%s) \"%s\" \n",
file, line, static_cast<unsigned int>(result), _cudaGetErrorEnum(result), func);
return true;
} else {
return false;
}
}
void check() { }
void initialize()
{
checkCudaErrors(cudaMalloc(NULL, 1));
}
};
int main(int argc, char **argv)
{
Trivial tt;
tt.initialize();
return 0;
}
所以,这主要解决了我的问题,我的代码编译成功。
答案 1 :(得分:0)
参考第680行的helper_cuda.h中的源代码
https://github.com/pathscale/nvidia_sdk_samples/blob/master/vectorAdd/common/inc/helper_cuda.h
你发现checkCudaErrors声明了一个#define checkCudaErrors(val)检查((val),#val, FILE , LINE ),它接受一个参数并调用check使用基于config.Note的3个其他参数,它也在第680行中定义
在您的情况下,您定义一个不带任何参数的检查。不同声明和定义的情况,多重定义。