【发布时间】:2010-11-05 07:57:50
【问题描述】:
是否可以在一个系统上同时运行基于 glibc 和 uClibc 的应用程序?
背景: 我们有基于二进制 gcc 的交叉编译器配置为与 uClibc 链接。我们已经用它交叉编译了 glibc。现在我们要构建一些应用程序,以便它们与 glibc 而不是 uClibc 链接。我们不想重建编译器。
【问题讨论】:
是否可以在一个系统上同时运行基于 glibc 和 uClibc 的应用程序?
背景: 我们有基于二进制 gcc 的交叉编译器配置为与 uClibc 链接。我们已经用它交叉编译了 glibc。现在我们要构建一些应用程序,以便它们与 glibc 而不是 uClibc 链接。我们不想重建编译器。
【问题讨论】:
glibc 和 uClibc 并存,一些程序链接到一个,而其他程序链接到另一个,这没有问题。但是,附加库存在问题。您系统上的每个共享库都将针对 glibc 或 uClibc 构建(使用相应的头文件,它们为标准库函数定义不同的 ABI),例如,如果 glibc 程序和 uClibc 程序都需要 ncurses,则需要构建两个版本的 ncurses,并有办法确保在运行时加载给定程序的正确版本。或者,您可以选择仅使用一组共享库,并将静态库用于链接到另一个 libc 的程序,但您仍然需要构建 2 组库。
【讨论】:
是的,这应该是完全可能的,但您可能不得不使用 LD_PRELOAD_PATH。如果您是静态链接,请更改为动态链接。
【讨论】:
几乎不可能将它们混合在同一个 FHS 中,因为 ABI 和包含目录不兼容。但是,您可以通过调整 ELF 中的动态链接器字段并利用 gcc/binutils 中的 sysroot 功能将它们中的任何一个安装在目录偏移中。 Gentoo 社区[1] 正在进行一项实验,称为 Prefix/libc。
【讨论】: