nvcc fatal : Unsupported gpu architecture 'compute_11'
使用VS编译OpenCV编译源代码时候,对Cmake生成的工程文件编译,会出现 nvcc fatal : Unsupported gpu architecture 'compute_11' 问题。原因是CUDA7.5不支持较为古老的显卡版本,因此1.1,2.0,2.1,之类的显卡选项是多余的。
需要更改Cmake GUI对工程的配置,去掉对compute_11的支持
1. 打开cmakelist.txt
CMake的选项中声明 -D CUDA_GENERATION=Kepler
即添加:
if(WIN32 AND NOT MINGW) add_definitions(-D_VARIADIC_MAX=10) endif(WIN32 AND NOT MINGW) #此处为添加代码 if(1) add_definitions( -D_CUDA_GENERATION=Maxwell)
不能消除这种现象,问题没有得到解决。
参考:安装caffe的血泪史
linux版本编译OpenCV可能出现的Compute_11问题
对于Maxwell的支持,参考:Vs13+Win7+OpenCV2.4.13+CUDA7.5支持
2.
改正方法:
把CUDA栏目里面,CUDA_ARCH_BIN 项目里面,3.0前面的都去掉,改成如下所示。
之前,
1. 先把CUDA_generation 修改为Auto
2. 打开 sources\cmake 目录,使用文本编辑器编辑OpenCVDetectCUDA.cmake
找到下面一段
if(NOT DEFINED __cuda_arch_bin) if(ANDROID) set(__cuda_arch_bin "3.2") set(__cuda_arch_ptx "") else() if(${CUDA_VERSION} VERSION_LESS "5.0") set(__cuda_arch_bin "1.1 1.2 1.3 2.0 2.1(2.0) 3.0") else() set(__cuda_arch_bin "1.1 1.2 1.3 2.0 2.1 3.0 3.5") endif() set(__cuda_arch_ptx "3.0") endif() endif()
把第二个1.1 1.2 1.3 2.0 2.1 去掉,修改为
if(NOT DEFINED __cuda_arch_bin) if(ANDROID) set(__cuda_arch_bin "3.2") set(__cuda_arch_ptx "") else() if(${CUDA_VERSION} VERSION_LESS "5.0") set(__cuda_arch_bin "1.1 1.2 1.3 2.0 2.1(2.0) 3.0") else() set(__cuda_arch_bin "3.0 3.5") endif() set(__cuda_arch_ptx "3.0") endif() endif()
或者直接修改为使用于本机GTX960 显卡的 5.2,
才能把CUDA_ARCH_BIN 的1.1 1.2 1.3 2.0 2.1 去掉,进而解决 nvcc fatal : Unsupported gpu architecture 'compute_11' 问题。
若不能通过编辑选项去掉,应该有其他可行的方法???
则可以编译通过。