lfs-笔记

来源:互联网 发布:清华大学知乎 编辑:程序博客网 时间:2024/05/18 06:20
bin=ld0. ld,gcc,glibc,其中glibc是核心,一步步转向新系统1.用host的glibc-0,gcc-0,ld-0生成了ld-1,ld-1会link  host/lib下的库(也只能这样,因为新的还没生出来)2.用ld-0,glibc-0,gcc-0生成gcc-1,gcc-1会使用host/lib下的ld-0而不是ld-1(也只能这样,因为它是新生出来的,没有修改过linker)  好了,现在有了  ld-1指向glibc-0,由指向glibc-0的gcc-0,ld-0生成  gcc-1,指向glibc-0,由指向glibc-0的gcc-0,ld-0生成    但它们都有“问题”3.用有“问题”的ld-1和gcc-1(通过./configure进行配置--with-binutils=/tools/bin)  生成glibc-1(我们自己生成的glibc,安装到工具目录tools下面,形成工具链的一部分)      这个时候,我们有了  ld-1指向glibc-0,由指向glibc-0的gcc-0,ld-0生成  gcc-1,指向glibc-0,由指向glibc-0的gcc-0,ld-1生成  glibc-1,由ld-1,gcc-1生成4.调整ld-1和gcc-1指向glibc-1(/tools/lib)而不再指向系统的lib和ld0(glibc-0)  4.1 需要调整ld-1,让它指向生成的tools下的glibc-1(make clean ...的那几句重新生成ld),新的ld-1被称为ld-a      (使用glibc-1即tools/lib)  4.2 修改gcc-1的SPEC文件,让gcc-1指向glibc-1的linker,也就是上面的ld-a,新的gcc-1被称为gcc-a  现在,我们有了:    ld-a指向glibc-1、由指向glibc-0的ld-0,gcc-0生成    gcc-a指向glibc-1、由指向glibc-0的ld-0,gcc-0生成    glibc-1用ld-1,gcc-1生成5.  需要“自编译所有东西”,所以"*-0"式的host的东西都不要,需要在工具链内部重新生成。    这时候用上面那三个东西,它们自成体系,生成ld-2,gcc-2; 以后再编译工具链其它工具的话就使用:    ld-2指向glibc-1、由指向glibc-1的gcc-a,ld-a生成    gcc-2指向glibc-1、由指向glibc-1的gcc-a,ld-a生成    glibc-1用ld-1,gcc-1生成6.  chroot,转到新系统中,首先应该编译glibc-2(使用ld-2/gcc-2/glibc-1)    并将glibc-2安装到新系统的/usr等系统目录    7. 第二次调整工具链   对于chroot后的新系统,由于ld-2和gcc-2都指向tools/lib,而我们现在是新系统需要指向新的   /usr/lib、/lib等新“系统目录”所以也需要调整工具链:   ld-b:指向glibc-2,由指向glibc-1的gcc-a,ld-a生成   gcc-b:指向glibc-2,由指向glibc-1的gcc-a,ld-a生成8. 生成ld-3,gcc-3   ld-3:指向glibc-2,由指向glibc-2的gcc-b,ld-b生成   gcc-3:指向glibc-2,由指向glibc-2的gcc-b,ld-b生成   此时,我们已经有了新系统中的所有东西ld-3、gcc-3、glibc-2   11l

原创粉丝点击