链接器抱怨缺少-fPIC

时间:2018-09-13 14:03:15

标签: python gcc cython cross-compiling

我正在尝试交叉编译冻结的Cython程序以用于RPi。

链接产生(用于Python库的许多对象)

/usr/bin/arm-linux-gnueabihf-ld: 
/root/xxx_Build/usr/local/lib/python3.7/config-3.7m-arm-linux-gnueabihf/libpython3.7m.a(getopt.o): relocation R_ARM_THM_MOVW_ABS_NC against `a local symbol' can not be used when making a shared object; recompile with -fPIC

链接器应创建一个可执行文件(而不是共享对象)。为什么?

编译(我的模块):

cython_freeze.py -o main.c sub.py
cython sub2.py

{crossPrefix}gcc -fPIC -pthread -O2 -Wall -Wextra -fno-strict-aliasing -fwrapv -I{crossRoot}{pythonInclude} -c -o main.o main.c'
{crossPrefix}gcc -fPIC -pthread -O2 -Wall -Wextra -fno-strict-aliasing -fwrapv -I{crossRoot}{pythonInclude} -c -o sub.o sub.c'

链接:

{crossPrefix}gcc -Xlinker -export-dynamic -L{crossRoot}/usr/local/lib/{pythonCommand}/config-{pythonVersion}m-{crossPrefixM} main.o sub.o -l{pythonCommand}m -lm -lpthread -ldl -lutil -o 

版本:

  • Python 3.7.0(来自带有默认构建的python.org)
  • Cython 0.28.5
  • 主机UBUNTU 18.04 x64
  • 目标UBUNTU MATE 16.04 Raspberry Pi 3 B +

以上过程适用于

  • Python 3.6.4
  • Cython 0.23.3
  • 主机UBUNTU 16.04 x64
  • 目标UBUNTU MATE 16.04 Raspberry Pi 3 B +

1 个答案:

答案 0 :(得分:3)

  

链接器应创建一个可执行文件(而不是共享对象)。为什么?

从Ubuntu 17.04开始,Ubuntu成为GCC构建配置的趋势 默认情况下生成PIE(位置独立的可执行文件),因此生成PIC对象 文件默认情况下。 PIE增强了系统安全性,因为此类可执行文件可以在ASLR

的情况下运行

请参阅:

$ cat /etc/*-release | grep VERSION
VERSION="18.04.1 LTS (Bionic Beaver)"
VERSION_ID="18.04"
VERSION_CODENAME=bionic

$ echo "int main(void) { return 0; }" | gcc -x c -
$ file a.out
a.out: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, for GNU/Linux 3.2.0, BuildID[sha1]=3597d2a178dfb7ff7b0ba10886819bf19e40d596, not stripped

PIE是共享对象,因此PIE链接中的所有对象文件都必须编译-fPIC。这将 默认情况下,新编译的目标文件为true,但显然不 libpython3.7m.a

您可以通过在链接选项中添加-no-pie来坚持使用老式可执行文件。 (在这种情况下,您无需使用-fPIC来编译自己的代码)。

相关问题