musl 无法将 libc.a 链接到共享库

Posted

技术标签:

【中文标题】musl 无法将 libc.a 链接到共享库【英文标题】:musl fails to link libc.a into shared library 【发布时间】:2016-07-07 17:03:09 【问题描述】:

我有一个 C99 共享库,我想将它链接到几个静态库中(通过 --whole-archive)。 注意:所有的静态库都是用-fPIC构建的

我也想构建一个通用的 linux 二进制文件,因此决定使用 musl。当我尝试从 musl 链接静态 libc.a 时,我收到以下错误:

# Building shared library tgt/Linux-x86_64/mylib/lib/mylib.so
/root/mylib/./tgt/Linux-x86_64/libmusl/bin/musl-gcc -Wl,-whole-archive -L./tgt/Linux-x86_64/libmusl/lib -L./tgt/Linux-x86_64/libz/lib -L./tgt/Linux-x86_64/libssl/lib -L./tgt/Linux-x86_64/libsasl/lib -L./tgt/Linux-x86_64/librdkafka/lib -L./tgt/Linux-x86_64/libcurl/lib -L./tgt/Linux-x86_64/libgjalloc/lib -L./tgt/Linux-x86_64/libavro/lib -L./tgt/Linux-x86_64/libunwind/lib -l:libc.a -l:libpthread.a -l:libz.a -l:libssl.a -l:libcrypto.a -l:libsasl2.a -l:libm.a -l:librt.a -l:libcrypt.a -l:libunwind-x86_64.a -l:librdkafka.a -l:libcurl.a -l:libgjalloc.a -l:libavro.a -Wl,-no-whole-archive -shared -fPIC -o tgt/Linux-x86_64/mylib/lib/mylib.so ./tgt/Linux-x86_64/mylib/obj/myfile.o ./tgt/Linux-x86_64/mylib/obj/myotherfile.o ./tgt/Linux-x86_64/mylib/obj/cJSON.o
/usr/bin/ld: ./tgt/Linux-x86_64/libmusl/lib/libc.a(exit.lo): relocation R_X86_64_PC32 against undefined hidden symbol `__fini_array_start' can not be used when making a shared object
/usr/bin/ld: final link failed: Bad value
collect2: error: ld returned 1 exit status
make: *** [tgt/Linux-x86_64/mylib/lib/mylib.so] Error 1

我的 musl 体型如下:

cd mystatic_libs_build_dir/musl; \
./configure CFLAGS='-fPIC' \
--enable-shared \
--enable-static \
--prefix=/root/mylib/tgt/Linux-x86_64/libmusl; \
make; make install;
# libmusl is available

【问题讨论】:

【参考方案1】:

exit.lo 将用汇编程序编写,这就是为什么您的 CFLAGS='-fPIC' 没有达到您想要的效果。这要么是 1. 'musl' 中的错误,要么是 2. 故意的,它们不支持静态链接到 .so 中。

我认为这是无意的,并针对“musl”提交了一个错误

如果您需要快速修复,也可以自己编辑 asm。

最后你也许可以将 musl 配置为不使用 asm 构建?

有点离题,但通用二进制文件的其他选项是:

    只需在您支持的最旧版本的 Linux 上链接 glibc。 与其苦苦依赖“musl”,不如直接使用 Linux 内核 api。

【讨论】:

【参考方案2】:

只要你自己的代码用CFLAGS="-fPIC -Wa,-mrelax-relocations=no"重新编译musl(你的binutils版本必须>=2.27)。

【讨论】:

以上是关于musl 无法将 libc.a 链接到共享库的主要内容,如果未能解决你的问题,请参考以下文章

无法链接到 OpenCV (Linux) 的共享库

无法链接到共享库

如何将共享库链接到Linux中的其他共享库?

共享库如何免受利用?

无法将共享库与 -mx32 和 gcc 4.7 或 gcc 4.8 链接

将静态库链接到共享库(例如openmp)是一个好主意