【问题标题】:"Recompile with -fPIC" error persists even after adding -fPIC compile flag即使添加了 -fPIC 编译标志,“使用 -fPIC 重新编译”错误仍然存​​在
【发布时间】:2016-04-25 11:29:33
【问题描述】:

我已经下载了一些我想从源代码编译的 C++。从命令行运行cmake ../src 然后make 后,在构建目录中,我收到以下错误:

/usr/bin/ld: /usr/local/lib/libBulletCollision.a(btDbvtBroadphase.o):
relocation R_X86_64_32S against `_ZTV16btDbvtBroadphase' can not be used when making a shared object;
recompile with -fPIC

我相信这与尝试创建共享库有关,但没有提供必要的内存来这样做(尽管我并不完全理解这一点......)。无论如何,按照我看到的建议,我尝试了以下方法:

make CXXFLAGS='-fPIC'

但是,这给了我与以前完全相同的错误。关于为什么这不能解决问题的任何想法?

【问题讨论】:

  • 先运行make clean
  • makefile 不能开箱即用真的很奇怪。大概,如果你下载了软件,它应该包含正确的makefile?您确定错误与下载的库有关吗?
  • 我尝试先运行make clean,但这并没有帮助。我已经按照 GitHub 项目页面 (github.com/dartsim/dart/wiki/…) 上的所有说明进行操作,其中说它应该可以为 Ubuntu 14.04 编译...
  • 为什么在/usr/local中有自己的子弹版本,为什么不使用系统版本呢?请注意,错误消息是关于重新编译子弹,而不是飞镖。

标签: c++ ubuntu gcc g++ shared-libraries


【解决方案1】:

我相信 Mark 说的错误是关于 libBulletCollision.a 是正确的。您正在构建一个使用-fPIC 构建的.so,但链接到一个不使用-fPIC.a。您将需要更改和构建静态库或使用 -fPIC 重新构建和安装新的依赖 libBulletCollision.a

顺便说一句,您应该在 cmake 配置步骤中以更永久的方式将-fPIC 标志添加到您的构建中,而不是在运行make 时以这种临时方式覆盖CXXFLAGS

在调试构建时,将make VERBOSE=1 与 cmake 生成的 makefile 构建一起使用非常有帮助。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2013-08-25
    • 2016-09-12
    • 1970-01-01
    • 1970-01-01
    • 2013-09-20
    • 1970-01-01
    • 2012-11-28
    相关资源
    最近更新 更多