使用CMake和CUDA构建共享库失败

4

我正在尝试使用CMake构建一个包含CUDA代码的共享库。我正在使用findCUDA软件包。 在链接阶段出现了问题:

Linking CXX shared library shlibcuda.so
/usr/bin/c++  -fPIC -std=c++0x -fopenmp -O3 -DNDEBUG   -shared -Wl,-soname,shlibcuda.so -o shlibcuda.so CMakeFiles/shlibcuda.dir/src/cuda/./shlibcuda_generated_calibrate.cu.o CMakeFiles/shlibcuda.dir/src/cuda/./shlibcuda_generated_cleaning.cu.o CMakeFiles/shlibcuda.dir/./shlibcuda_intermediate_link.o  -L/usr/local/cuda-6.5/lib64/libcudart.so -Wl,-rpath,/mylibs/lib:/usr/local/cuda-6.5/lib64 
/usr/bin/ld: CMakeFiles/shlibcuda.dir/./shlibcuda_intermediate_link.o: relocation R_X86_64_32S against `__nv_module_id' can not be used when making a shared object; recompile with -fPIC
CMakeFiles/shlibcuda.dir/./shlibscuda_intermediate_link.o: error adding symbols: Bad value

这个问题及其答案中,我发现问题可能是要链接的对象文件没有使用-fPIC选项编译。我在CUDA_NVCC_FLAGS中添加了-Xcompiler -fPIC
实际上,正如您在下面的行中所看到的,当构建过程到达所谓的“中间链接文件”的构建时,没有将-fPIC传递给编译器:
[100%] Building NVCC intermediate link file CMakeFiles/shlibcuda.dir/./shlibcuda_intermediate_link.o
/usr/local/cuda-6.5/bin/nvcc -m64 -ccbin "/usr/bin/cc" -dlink CMakeFiles/shlibcuda.dir/src/cuda/./shlibcuda_generated_calibrate.cu.o CMakeFiles/shlibcuda.dir/src/cuda/./shlibcuda_generated_cleaning.cu.o  -o CMakeFiles/shlibcuda.dir/./shlibcuda_intermediate_link.o

我的NVCC标志如下:

#CUDA include directories
find_package(CUDA REQUIRED)
set(CUDA_NVCC_FLAGS ${CUDA_NVCC_FLAGS}; -Xcompiler -fPIC; -O3; -gencode arch=compute_32,code=sm_32; -ccbin /usr/bin/g++ -std=c++11)

我做错了什么?如果问题是缺少-fPIC选项,在编译中间链接文件时该如何传递该选项?

我正在使用CUDA 6.5,并传递-ccbin /usr/bin/g++ -std=c++11选项,因为我需要在主机代码中使用一些c++11。

我的cmake版本为2.8.12.2。


一如既往地:提供一个MCVE将有助于解决问题。 - m.s.
你确定整个选项列表周围的引号应该在那里吗? - Angew is no longer proud of SO
@angew 是的,问题仍然存在,即使没有引号。我正在制作一个 MCVE。我还发现了这个线程,因为问题似乎是相同的,所以它可能会有用。我正在找出他们正在使用哪个版本的 cmake。 - Michele
你不能升级到最新的CMake版本并尝试一下吗? - m.s.
@m.s. 搞定了。又出现了一个问题,但是用另一个补丁修复了。现在我会等待 FindCUDA.cmake 改进后的代码发布。谢谢。 - Michele
1
问题解决了吗?请发布一个回答,解释你做了什么。 - Robert Crovella
1个回答

3
这是一个与cmake相关的问题,可以通过这个补丁来解决(自cmake 3.2.0版本以后就包括了此补丁)。有了它,即使在编译中间链接文件时,也会传递-fPIC标志。

然而,另一个问题出现了,因为在我的配置中,我必须显式地传递主机编译器:

[100%] Building NVCC intermediate link file CMakeFiles/shlibcuda.dir/./shlibcuda_intermediate_link.o
    /usr/local/cuda-6.5/bin/nvcc -Xcompiler -fPIC -O3 -gencode arch=compute_32,code=sm_32 -ccbin /usr/bin/g++ -std=c++11 -m64 -ccbin "/usr/bin/gcc-4.8" -dlink CMakeFiles/shlibcuda.dir/src/cuda/./shlibcuda_generated_calibrate.cu.o CMakeFiles/shlibcuda.dir/src/cuda/./shlibcuda_generated_cleaning.cu.o  -o CMakeFiles/shlibcuda.dir/./shlibcuda_intermediate_link.o
nvcc fatal   : redefinition of argument 'compiler-bindir'

因为-ccbin /usr/bin/g++ -std=c++11-ccbin "/usr/bin/gcc-4.8"都存在,这是已知的cmake open问题0013674号问题。讨论仍在继续,但应用该线程中附加的补丁(它只是删除CUDA_NVCC_FLAGS中“-ccbin”检查)解决了问题。

在新问题跟踪器中讨论该问题时,有一个建议是使用CUDA_HOST_COMPILER变量而不是-ccbin


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接