Luc*_*uca 15 c++ cuda cmake c++11
我在使用CMake编译CUDA代码时遇到问题.我使用的是CUDA 7,nvcc的版本信息如下:
nvcc: NVIDIA (R) Cuda compiler driver
Copyright (c) 2005-2014 NVIDIA Corporation
Built on Tue_Dec__9_18:10:46_CST_2014
Cuda compilation tools, release 7.0, V7.0.17
Run Code Online (Sandbox Code Playgroud)
我的CMake文件使用find_cuda宏,如下所示:
find_package(CUDA)
if(CUDA_FOUND)
list(APPEND CUDA_NVCC_FLAGS "-arch=sm_20;--compiler-options;-std=c++11;-O2;-DVERBOSE")
endif(CUDA_FOUND)
Run Code Online (Sandbox Code Playgroud)
在许多帖子建议需要这个之后,我添加了std = c ++ 11编译器标志.但是,无论是否有此标志,我都会得到完全相同的错误.
我还添加了以下内容以从nvcc编译标志中删除C++ 11支持,但这也不会改变任何内容.
if(CMAKE_COMPILER_IS_GNUCC)
string(REPLACE "-std=c++11" "" CUDA_HOST_FLAGS "${CUDA_HOST_FLAGS}")
string(REPLACE "-std=c++0x" "" CUDA_HOST_FLAGS "${CUDA_HOST_FLAGS}")
endif(CMAKE_COMPILER_IS_GNUCC)
Run Code Online (Sandbox Code Playgroud)
我得到的错误如下:
/usr/lib/gcc/x86_64-linux-gnu/4.8/include/stddef.h(432): error: identifier "nullptr" is undefined
/usr/lib/gcc/x86_64-linux-gnu/4.8/include/stddef.h(432): error: expected
a ";"
/usr/include/x86_64-linux-gnu/c++/4.8/bits/c++config.h(190): error:
expected a ";"
/usr/include/c++/4.8/exception(63): error: expected a ";"
/usr/include/c++/4.8/exception(68): error: expected a ";"
/usr/include/c++/4.8/exception(76): error: expected a ";"
/usr/include/c++/4.8/exception(83): error: expected a ";"
/usr/include/c++/4.8/exception(93): error: expected a "{"
/usr/include/c++/4.8/bits/exception_ptr.h(64): error: function
"std::current_exception" returns incomplete type
"std::__exception_ptr::exception_ptr"
Run Code Online (Sandbox Code Playgroud)
我正在使用gcc 4.8但是也得到了与4.7相同的错误.我在cmake 2.8.12.2上.
使用CMAKE verbose进行编译为nvcc编译提供以下标志:
/usr/local/cuda-7.0/bin/nvcc /home/xargon/Dropbox/code/gpu-mosaicing
/src/gpu/kernels/bgra_2_gray.cu -c -o /home/xargon/code/mosaicing_bin
/gpu/kernels/CMakeFiles/kernels.dir//./kernels_generated_bgra_2_gray.cu.o
-ccbin /usr/bin/cc -m64 -DUSE_CUDA -DUSE_OPENCV -DUSE_QT -Xcompiler
,\"-std=c++11\",\"-O3\",\"-DNDEBUG\" -arch=sm_20 --compiler-options
-std=c++11 -O2 -DVERBOSE -DNVCC -I/usr/local/cuda-7.0/include -I/usr/local
/include/opencv -I/usr/local/include -I/home/xargon/Dropbox/code/gpu-
mosaicing/src/cpu/gui/qt -I/usr/include -I/home/xargon/Dropbox/code/gpu-
mosaicing/src/cpu/core -I/home/xargon/Dropbox/code/gpu-mosaicing/src/cpu
/datasources -I/home/xargon/Dropbox/code/gpu-mosaicing/src/gpu
/intraoperability -I/home/xargon/Dropbox/code/gpu-mosaicing/src/utils
-I/usr/local/cuda-7.0/include
Run Code Online (Sandbox Code Playgroud)
m.s*_*.s. 21
这对我使用CUDA 7,gcc 4.8.2和CMake 3.0.2.
我更新了代码并添加了一个基于推力的简单示例,以明确您可以在CUDA代码中使用C++ 11
的CMakeLists.txt
project(cpp11)
find_package(CUDA)
list(APPEND CUDA_NVCC_FLAGS "-arch=sm_20;-std=c++11;-O2;-DVERBOSE")
SET(CUDA_PROPAGATE_HOST_FLAGS OFF)
CUDA_ADD_EXECUTABLE(cpp11 main.cpp test.h test.cu)
Run Code Online (Sandbox Code Playgroud)
test.h
#ifndef TEST_H
#define TEST_H
int run();
#endif
Run Code Online (Sandbox Code Playgroud)
test.cu
#include "test.h"
#include <thrust/device_vector.h>
#include <thrust/reduce.h>
#include <thrust/sequence.h>
template<typename T>
struct Fun
{
__device__ T operator()(T t1, T t2)
{
auto result = t1+t2;
return result;
}
};
int run()
{
const int N = 100;
thrust::device_vector<int> vec(N);
thrust::sequence(vec.begin(),vec.end());
auto op = Fun<int>();
return thrust::reduce(vec.begin(),vec.end(),0,op);
}
Run Code Online (Sandbox Code Playgroud)
main.cpp中
#include <iostream>
#include "test.h"
int main()
{
std::cout << run() << std::endl;
return 0;
}
Run Code Online (Sandbox Code Playgroud)
小智 10
list(APPEND CUDA_NVCC_FLAGS "-std=c++11")SET(CUDA_PROPAGATE_HOST_FLAGS OFF)可能是不够的,它可能导致我无法在.cu文件中设置断点
如果在搜索为以太坊CUDA挖掘编译Genoils CPP-Ethereum构建的方法时遇到这个问题,我的问题是通过编辑cpp-ethereum/libethash-cuda文件夹中的CMakeLists.txt文件来解决的.
它声明:
set(CUDA_NVCC_FLAGS
${CUDA_NVCC_FLAGS};
-gencode etc etc)
Run Code Online (Sandbox Code Playgroud)
在分号后添加"-std = c ++ 11",如下所示:
set(CUDA_NVCC_FLAGS
${CUDA_NVCC_FLAGS};
-std=c++11
-gencode etc etc)
Run Code Online (Sandbox Code Playgroud)