LFS 5.7.Glibc-2.29 的健全性检查失败

LFS 5.7.Glibc-2.29 的健全性检查失败

我想在没有 sudo 权限的 CentOS v.7.6.1810 上交叉编译 LFS(我想在服务器上自定义我的环境)。一个问题是全球范围内许多软件包都已过时(例如2.7、4.8.5、3.82 python)。gccgmake

在这个设置中,我从 LFS 的第 4 章开始,将所有 PATH 从 /tools 更改为 /path/to/my/folder/tools (我相信我做得足够准确)。一切都很顺利,直到第 5.7 章。首先,Glibc 希望有更新的 python 和 gmake。因此我遵循了 5.27.1 和 5.30.1 章节。

之后,一切都编译良好,我在健全性检查步骤中停止了(http://www.linuxfromscratch.org/lfs/view/stable/chapter05/glibc.html)。我从sources/glibc/build文件夹执行它,并得到一个错误:

> echo 'int main(){}' > dummy.c
> $LFS_TGT-gcc dummy.c

/path/to/my/folder/tools/lib/gcc/x86_64-lfs-linux-gnu/8.2.0/../../../../x86_64-lfs-linux-gnu/bin/ld: cannot find crt1.o: No such file or directory
/path/to/my/folder/tools/lib/gcc/x86_64-lfs-linux-gnu/8.2.0/../../../../x86_64-lfs-linux-gnu/bin/ld: cannot find crti.o: No such file or directory
/path/to/my/folder/tools/lib/gcc/x86_64-lfs-linux-gnu/8.2.0/../../../../x86_64-lfs-linux-gnu/bin/ld: cannot find /path/to/my/folder/tools/lib/libc.so.6 inside /path/to/my/folder
/path/to/my/folder/tools/lib/gcc/x86_64-lfs-linux-gnu/8.2.0/../../../../x86_64-lfs-linux-gnu/bin/ld: cannot find /path/to/my/folder/tools/lib/libc_nonshared.a inside /path/to/my/folder
/path/to/my/folder/tools/lib/gcc/x86_64-lfs-linux-gnu/8.2.0/../../../../x86_64-lfs-linux-gnu/bin/ld: cannot find /path/to/my/folder/tools/lib/ld-linux-x86-64.so.2 inside /path/to/my/folder
collect2: error: ld returned 1 exit status

我检查了 /path/to/my/folder/tools/lib/ 以及所有想要的文件(crt1.o、crti.o、libc.so.6、libc_nonshared.a、ld-linux-x86-64.so.2 ) 在那儿。

我尝试提供文件的符号链接,它适用于 crt1.o 和 crti.o,但不适用于其他文件。

> ln -s /path/to/my/folder/tools/lib/crt1.o crt1.o
> ln -s /path/to/my/folder/tools/lib/crti.o crti.o
> ln -s /path/to/my/folder/tools/lib/libc_nonshared.a libc_nonshared.a

/path/to/my/folder/tools/lib/gcc/x86_64-lfs-linux-gnu/8.2.0/../../../../x86_64-lfs-linux-gnu/bin/ld: cannot find /path/to/my/folder/tools/lib/libc.so.6 inside /path/to/my/folder
/path/to/my/folder/tools/lib/gcc/x86_64-lfs-linux-gnu/8.2.0/../../../../x86_64-lfs-linux-gnu/bin/ld: cannot find /path/to/my/folder/tools/lib/libc_nonshared.a inside /path/to/my/folder
/path/to/my/folder/tools/lib/gcc/x86_64-lfs-linux-gnu/8.2.0/../../../../x86_64-lfs-linux-gnu/bin/ld: cannot find /path/to/my/folder/tools/lib/ld-linux-x86-64.so.2 inside /path/to/my/folder
collect2: error: ld returned 1 exit status

我尝试更改。但是,在调用和其他工具LD_LIBRARY_PATH时,这样做会出现奇怪的分段错误。创造有助于回归事物。lscatLD_LIBRARY_PATH=''

> export LD_LIBRARY_PATH=/path/to/my/folder/tools/lib
> ls
Segmentation fault (core dumped)
> export LD_LIBRARY_PATH=/path/to/my/folder/tools/lib64
> ls
Segmentation fault (core dumped)
> export LD_LIBRARY_PATH=''
> ls
...Dispalays content of the directory...

更新:现在我重新安装了旧版本的 LFS (8.1),这样我从一开始就满足了所有先决条件。我再次从第四章开始,直到臭名昭著的检查之前没有出现任何错误。 Tim 的建议很有帮助,系统没有被破坏,但是分段错误不允许创建 a.out:

> echo 'int main(){}' > dummy.c
> LD_LIBRARY_PATH=/path/to/my/folder/tools/lib $LFS_TGT-gcc dummy.c
Segmentation fault (core dumped)
> readelf -l a.out | grep ': /path/to/my/folder/tools'
readelf: a.out: Error: No such file

受到类似问题的启发https://stackoverflow.com/questions/15928925/lfs-7-2-glibc-2-16-0-make-error并尝试做出LD_LIBRARY_PATH相应的改变。这似乎不起作用。

> echo 'int main(){}' > dummy.c
> LD_LIBRARY_PATH=/path/to/my/folder/tools/libgcc/x86_64-lfs-linux-gnu/7.2.0 $LFS_TGT-gcc dummy.c
/path/to/my/folder/tools/lib/gcc/x86_64-lfs-linux-gnu/8.2.0/../../../../x86_64-lfs-linux-gnu/bin/ld: cannot find crt1.o: No such file or directory
/path/to/my/folder/tools/lib/gcc/x86_64-lfs-linux-gnu/8.2.0/../../../../x86_64-lfs-linux-gnu/bin/ld: cannot find crti.o: No such file or directory
/path/to/my/folder/tools/lib/gcc/x86_64-lfs-linux-gnu/8.2.0/../../../../x86_64-lfs-linux-gnu/bin/ld: cannot find /path/to/my/folder/tools/lib/libc.so.6 inside /path/to/my/folder
/path/to/my/folder/tools/lib/gcc/x86_64-lfs-linux-gnu/8.2.0/../../../../x86_64-lfs-linux-gnu/bin/ld: cannot find /path/to/my/folder/tools/lib/libc_nonshared.a inside /path/to/my/folder
/path/to/my/folder/tools/lib/gcc/x86_64-lfs-linux-gnu/8.2.0/../../../../x86_64-lfs-linux-gnu/bin/ld: cannot find /path/to/my/folder/tools/lib/ld-linux-x86-64.so.2 inside /path/to/my/folder
collect2: error: ld returned 1 exit status
> readelf -l a.out | grep ': /path/to/my/folder/tools'
readelf: a.out: Error: No such file

您能否提出建议,如何处理这个令人讨厌的ld问题。我知道跳过 LFS 步骤是不好的。不幸的是,我没有办法解决这个问题,但我想尽可能升级我的本地环境。谢谢你!

答案1

如果你按照书上的步骤一步一步来,LFS 就不可能行不通。但如果你跳过步骤、重新调整事情等等 - 你就得靠自己了,因为即使在这个轻量级版本中,GNU Linux 也太复杂了。

所以——跟着书走,书就是好书。如果出现错误,请重新阅读本书,返回并检查所有内容。

您写道,您必须执行无序的 Python 和 gmake 编译。为什么?如果您的主机系统不满足 LFS 要求 - 它将无法工作。那么 - 你的主机是否有 Python 3.4http://www.linuxfromscratch.org/lfs/view/stable/chapter02/hostreqs.html?你执行version-check.sh脚本了吗?您是否将其打印的所有版本与书中给出的版本进行了检查?

编辑:当某些软件包(如 Python 或 gmake)在主机系统上太旧且无法更改时,您可以尝试从本地源编译并安装它们,仅供您的用户使用。您必须prefix在配置过程中设置:

./configure --prefix=$HOME

然后你必须做一些调整 - 添加$HOME/bin到你的PATH等。

相关内容