From b0a4c9a47dadc3ab2c37a034866cb542f3fffa0b Mon Sep 17 00:00:00 2001 From: Jeremy Huntwork Date: Sat, 15 Sep 2007 20:45:13 +0000 Subject: Upgrade to GCC-4.2.1. Fixes #2002. Merged from jh branch, thanks to Matthew Burgess for preparing a discrete patch. git-svn-id: http://svn.linuxfromscratch.org/LFS/trunk/BOOK@8374 4aa44e1e-78dd-0310-a6d2-fbcd4c07a689 --- chapter01/changelog.xml | 5 +++++ chapter01/whatsnew.xml | 8 +++++-- chapter03/patches.xml | 8 ------- chapter05/adjusting.xml | 2 +- chapter05/gcc-pass1.xml | 29 ++++++++------------------ chapter05/gcc-pass2.xml | 55 +++++++++++++++++++++++++++++++++++-------------- chapter05/perl.xml | 5 +++++ chapter06/gcc.xml | 3 ++- chapter06/perl.xml | 4 ++++ packages.ent | 6 +++--- patches.ent | 4 ---- 11 files changed, 75 insertions(+), 54 deletions(-) diff --git a/chapter01/changelog.xml b/chapter01/changelog.xml index 9f2d73f8b..6dabdd7be 100644 --- a/chapter01/changelog.xml +++ b/chapter01/changelog.xml @@ -39,6 +39,11 @@ 2007-09-15 + + [jhuntwork] - Upgrade to GCC-4.2.1. Fixes + #2002. + Thanks to Matthew Burgess for preparing a discrete patch. + [matthew] - Upgrade to DB-4.6.19. Fixes #2051. diff --git a/chapter01/whatsnew.xml b/chapter01/whatsnew.xml index 2afda712a..e8c63c12c 100644 --- a/chapter01/whatsnew.xml +++ b/chapter01/whatsnew.xml @@ -77,10 +77,10 @@ - -gcc -dumpspecs | sed 's@^/lib/ld-linux.so.2@/tools&@g' \ +gcc -dumpspecs | sed 's@/lib/ld-linux.so.2@/tools&@g' \ > `dirname $(gcc -print-libgcc-file-name)`/specs During the build process, GCC runs a script diff --git a/chapter05/gcc-pass1.xml b/chapter05/gcc-pass1.xml index 068fdf698..5bbb78173 100644 --- a/chapter05/gcc-pass1.xml +++ b/chapter05/gcc-pass1.xml @@ -101,26 +101,15 @@ cd ../gcc-build - Continue with compiling the package: - -make bootstrap - - - The meaning of the make parameter: - - - bootstrap - - This target does not just compile GCC, but compiles it - several times. It uses the programs compiled in a first round - to compile itself a second time, and then again a third time. - It then compares these second and third compiles to make sure - it can reproduce itself flawlessly. This also implies that it - was compiled correctly. - - - - + The following command will compile GCC not once, but several times. It + uses the programs compiled in a first round to compile itself a second time, + and then again a third time. It then compares these second and third compiles + to make sure it can reproduce itself flawlessly. This is called + bootstrapping. Building GCC in this way ensures that it was + compiled correctly and is now the default configuration for the released + package. Continue with compiling by running: + +make Compilation is now complete. At this point, the test suite would normally be run, but, as mentioned before, the test suite framework is diff --git a/chapter05/gcc-pass2.xml b/chapter05/gcc-pass2.xml index 53743acb6..2be683d55 100644 --- a/chapter05/gcc-pass2.xml +++ b/chapter05/gcc-pass2.xml @@ -90,23 +90,39 @@ sed 's@\./fixinc\.sh@-c true@' gcc/Makefile.in.orig > gcc/Makefile.in - Apply the following patch to change the location of GCC's default - dynamic linker (typically ld-linux.so.2): - -patch -Np1 -i ../&gcc-specs-patch; - - The above patch also removes The following command will change the location of GCC's default + dynamic linker to use the one we installed in + /tools. It also removes /usr/include from GCC's include search path. - Patching now rather than adjusting the specs file after installation + Doing this now rather than adjusting the specs file after installation ensures that the new dynamic linker is used during the actual build of GCC. That is, all of the binaries created during the build will link - against the new Glibc. - - - The above patch is critical in ensuring a successful overall - build. Do not forget to apply it. - + against the new Glibc. Issue: + +for file in $(find gcc/config -name linux64.h -o -name linux.h) +do + cp -uv $file{,.orig} + sed -e 's@/lib\(64\)\?\(32\)\?/ld@/tools&@g' \ + -e 's@/usr@/tools@g' $file.orig > $file + echo " +#undef STANDARD_INCLUDE_DIR +#define STANDARD_INCLUDE_DIR 0" >> $file + touch $file.orig +done + + In case the above seems hard to follow, let's break it down a bit. + First we find all the files under the gcc/config directory that are named + either linux.h or linux64.h. + For each file found, we copy it to a file of the same name but with an added + suffix of .orig. Then the first sed expression prepends + /tools to every instance of /lib/ld, + /lib64/ld or /lib32/ld, while the second one + replaces hard-coded instances of /usr. Then we add our define + statements which alter the include search path to the end of the file. Finally, + we use touch to update the timestamp on the copied files. + When used in conjunction with cp -u, this prevents unexpected + changes to the original files in case the command is inadvertently run twice. + Create a separate build directory again: @@ -122,7 +138,7 @@ cd ../gcc-build --with-local-prefix=/tools --enable-clocale=gnu \ --enable-shared --enable-threads=posix \ --enable-__cxa_atexit --enable-languages=c,c++ \ - --disable-libstdcxx-pch + --disable-libstdcxx-pch --disable-bootstrap The meaning of the new configure options: @@ -177,6 +193,15 @@ cd ../gcc-build + + --disable-bootstrap + + Bootstrapping the compiler is now the default for GCC. However, + our build method should provide us with a solid compiler without the + need to bootstrap each time. + + + Compile the package: diff --git a/chapter05/perl.xml b/chapter05/perl.xml index 6e9a87b76..0885cbbec 100644 --- a/chapter05/perl.xml +++ b/chapter05/perl.xml @@ -48,6 +48,11 @@ patch -Np1 -i ../&perl-libc-patch; + Fix an incompatibility with gcc-&gcc-version;: + +mv -v makedepend.SH{,.orig} +sed 's/command /command[ -]/' makedepend.SH.orig > makedepend.SH + Prepare Perl for compilation (make sure to get the 'Data/Dumper Fcntl IO POSIX' part of the command correct—they are all letters): diff --git a/chapter06/gcc.xml b/chapter06/gcc.xml index ff6a76116..229c56398 100644 --- a/chapter06/gcc.xml +++ b/chapter06/gcc.xml @@ -83,7 +83,8 @@ cd ../gcc-build ../gcc-&gcc-version;/configure --prefix=/usr \ --libexecdir=/usr/lib --enable-shared \ --enable-threads=posix --enable-__cxa_atexit \ - --enable-clocale=gnu --enable-languages=c,c++ + --enable-clocale=gnu --enable-languages=c,c++ \ + --disable-bootstrap Compile the package: diff --git a/chapter06/perl.xml b/chapter06/perl.xml index 591e90ba8..77d027b89 100644 --- a/chapter06/perl.xml +++ b/chapter06/perl.xml @@ -47,6 +47,10 @@ echo "127.0.0.1 localhost $(hostname)" > /etc/hosts + Fix an incompatibility with gcc-&gcc-version;: + +sed -i 's/command /command[ -]/' makedepend.SH + To have full control over the way Perl is set up, you can run the interactive Configure script and hand-pick the way this package is built. If you prefer, you can use the defaults that Perl diff --git a/packages.ent b/packages.ent index a91eda630..99d1b743e 100644 --- a/packages.ent +++ b/packages.ent @@ -168,10 +168,10 @@ - - + + - + diff --git a/patches.ent b/patches.ent index 655917296..43c46b305 100644 --- a/patches.ent +++ b/patches.ent @@ -39,10 +39,6 @@ - - - - -- cgit v1.2.3-54-g00ecf