-3

我有一些 CUDA 代码正在编译到 .a 库中,还有一些(与 CUDA 相关的)常规 C++ 代码用于使用它的应用程序。一切都在进行中间链接。

现在,在一台机器上(使用 CUDA 8.0 RC)构建成功,但在另一台机器上(使用 Maxwell 而不是 Kepler 卡,以防万一)我得到:

/tmp/tmpxft_00001796_00000000-2_ktkernels_intermediate_link.reg.c:25: multiple definition of `__cudaRegisterLinkedBinary_66_tmpxft_00007a5f_00000000_16_cuda_device_runtime_compute_52_cpp1_ii_8b1a5d37'
CMakeFiles/tester.dir/tester_intermediate_link.o:/tmp/tmpxft_0000180b_00000000-2_tester_intermediate_link.reg.c:4: first defined here
collect2: error: ld returned 1 exit status
CMakeFiles/tester.dir/build.make:1766: recipe for target 'bin/tester' failed
make[2]: *** [bin/tester] Error 1

我实际上开始从编译到调用库代码的二进制文件中删除文件 - 只有当我删除所有文件时,链接才会成功。

我的问题:

  • 在什么情况下会出现这种不一致的行为?
  • 这可能是库和二进制文件“第二次链接”的结果吗?
  • 我可以做些什么来准确地确定实际冲突的内容(例如要查找哪些符号)?
  • 如果实际上没有任何冲突,我应该怎么做才能避免这种情况?

笔记:

  • 在一台机器上我使用的是 CUDA 7.5,在另一台机器上它是 CUDA 8.0 RC。
4

1 回答 1

2
  • 在什么情况下会出现这种不一致的行为?

如果您尝试在单个应用程序中连接多个设备。

  • 这可能是库和二进制文件“第二次链接”的结果吗?

几乎毫无疑问。

  • 我可以做些什么来准确地确定实际冲突的内容(例如要查找哪些符号)?

冲突是运行时在设备链接阶段生成的样板的多个定义,运行时 API 用于将设备代码加载到上下文中。

  • 如果实际上没有任何冲突,我应该怎么做才能避免这种情况?

冲突是真实的。避免涉及正确链接单独编译的设备代码。除此之外,我无法确切告诉您如何解决它,因为您选择不告诉我们您在做什么。

于 2016-07-06T14:36:28.177 回答