123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176 |
- Index: chapter05/gcc-pass1.xml
- ===================================================================
- --- chapter05/gcc-pass1.xml (revision 11147)
- +++ chapter05/gcc-pass1.xml (working copy)
- @@ -68,8 +68,7 @@
- class="directory">/usr/include</filename> from GCC's include search path.
- Issue:</para>
-
- -<screen><userinput remap="pre">for file in \
- - $(find gcc/config -name linux64.h -o -name linux.h -o -name sysv4.h)
- +<screen><userinput remap="pre">for file in gcc/config/{linux,i386/linux{,64}}.h
- do
- cp -uv $file{,.orig}
- sed -e 's@/lib\(64\)\?\(32\)\?/ld@/tools&@g' \
- @@ -97,7 +96,18 @@
- Finally, we use <command>touch</command> to update the timestamp on the
- copied files. When used in conjunction with <command>cp -u</command>, this
- prevents unexpected changes to the original files in case the commands are
- - inadvertently run twice. </para>
- + inadvertently run twice.</para>
- +
- + <para>Finally, on x86_64 hosts, set the default directory name for
- + 64-bit libraries to <quote>lib</quote>:</para>
- +
- +<screen><userinput remap="pre">case $(uname -m) in
- + x86_64)
- + sed -e '/m64=/s/lib64/lib/' \
- + -i.orig gcc/config/i386/t-linux64
- + ;;
- +esac</userinput></screen>
- +
- <!--
- <para>GCC doesn't detect stack protection correctly, which causes problems
- for the build of Glibc-&glibc-version;, so fix that by issuing the following
- @@ -123,6 +133,7 @@
- --target=$LFS_TGT \
- --prefix=/tools \
- --with-glibc-version=2.11 \
- + --with-slibdir=/tools/lib \
- --with-sysroot=$LFS \
- --with-newlib \
- --without-headers \
- Index: chapter05/gcc-pass2.xml
- ===================================================================
- --- chapter05/gcc-pass2.xml (revision 11147)
- +++ chapter05/gcc-pass2.xml (working copy)
- @@ -70,8 +70,7 @@
- use the one installed in <filename
- class="directory">/tools</filename>.</para>
-
- -<screen><userinput remap="pre">for file in \
- - $(find gcc/config -name linux64.h -o -name linux.h -o -name sysv4.h)
- +<screen><userinput remap="pre">for file in gcc/config/{linux,i386/linux{,64}}.h
- do
- cp -uv $file{,.orig}
- sed -e 's@/lib\(64\)\?\(32\)\?/ld@/tools&@g' \
- @@ -84,6 +83,16 @@
- touch $file.orig
- done</userinput></screen>
-
- + <para>If building on x86_64, change the default directory name for 64-bit
- + libraries to <quote>lib</quote>:</para>
- +
- +<screen><userinput remap="pre">case $(uname -m) in
- + x86_64)
- + sed -e '/m64=/s/lib64/lib/' \
- + -i.orig gcc/config/i386/t-linux64
- + ;;
- +esac</userinput></screen>
- +
- <para>As in the first build of GCC it requires the GMP, MPFR and MPC
- packages. Unpack the tarballs and move them into the required directory
- names:</para>
- @@ -117,6 +126,7 @@
- --prefix=/tools \
- --with-local-prefix=/tools \
- --with-native-system-header-dir=/tools/include \
- + --with-slibdir=/tools/lib \
- --enable-languages=c,c++ \
- --disable-libstdcxx-pch \
- --disable-multilib \
- Index: chapter06/creatingdirs.xml
- ===================================================================
- --- chapter06/creatingdirs.xml (revision 11147)
- +++ chapter06/creatingdirs.xml (working copy)
- @@ -24,9 +24,7 @@
- mkdir -pv /usr/{,local/}share/man/man{1..8}
-
- case $(uname -m) in
- - x86_64) ln -sv lib /lib64
- - ln -sv lib /usr/lib64
- - ln -sv lib /usr/local/lib64 ;;
- + x86_64) mkdir -v /lib64 ;;
- esac
-
- mkdir -v /var/{log,mail,spool}
- Index: chapter06/gcc.xml
- ===================================================================
- --- chapter06/gcc.xml (revision 11147)
- +++ chapter06/gcc.xml (working copy)
- @@ -45,6 +45,16 @@
-
- <screen><userinput remap="pre">patch -Np1 -i ../gcc-6.1.0-asan-1.patch</userinput></screen>
- -->
- + <para>If building on x86_64, change the default direcotory name for 64-bit
- + libraries to <quote>lib</quote>:</para>
- +
- +<screen><userinput remap="pre">case $(uname -m) in
- + x86_64)
- + sed -e '/m64=/s/lib64/lib/' \
- + -i.orig gcc/config/i386/t-linux64
- + ;;
- +esac</userinput></screen>
- +
- <para>The GCC documentation recommends building GCC in a dedicated build directory:</para>
-
- <screen><userinput remap="pre">mkdir -v build
- @@ -175,10 +185,8 @@
-
- <para>Depending on your machine architecture, the above may differ slightly,
- the difference usually being the name of the directory
- - after <filename class="directory">/usr/lib/gcc</filename>. If your machine is
- - a 64-bit system, you may also see a directory named <filename class="directory">lib64</filename>
- - towards the end of the string. The important thing to
- - look for here is that <command>gcc</command> has found all three
- + after <filename class="directory">/usr/lib/gcc</filename>. The important
- + thing to look for here is that <command>gcc</command> has found all three
- <filename>crt*.o</filename> files under the
- <filename class="directory">/usr/lib</filename> directory.</para>
-
- Index: chapter06/glibc.xml
- ===================================================================
- --- chapter06/glibc.xml (revision 11147)
- +++ chapter06/glibc.xml (working copy)
- @@ -57,6 +57,18 @@
-
- <screen><userinput remap="pre">patch -Np1 -i ../&glibc-fhs-patch;</userinput></screen>
-
- + <para>Create a symlink for LSB compliance and, for x86_64, a
- + compatibility symlink required for the dynamic loader to function
- + correctly:</para>
- +
- +<screen><userinput remap="pre">case $(uname -m) in
- + x86) ln -s ld-linux.so.2 /lib/ld-lsb.so.3
- + ;;
- + x86_64) ln -s ../lib/ld-linux-x86-64.so.2 /lib64
- + ln -s ../lib/ld-linux-x86-64.so.2 /lib64/ld-lsb-x86-64.so.3
- + ;;
- +esac</userinput></screen>
- +
- <para>The Glibc documentation recommends building Glibc
- in a dedicated build directory:</para>
-
- @@ -67,7 +79,8 @@
-
- <screen><userinput remap="configure">../configure --prefix=/usr \
- --enable-kernel=&min-kernel; \
- - --enable-obsolete-rpc</userinput></screen>
- + --enable-obsolete-rpc \
- + libc_cv_slibdir=/lib</userinput></screen>
-
- <para>Compile the package:</para>
-
- Index: chapter06/libcap.xml
- ===================================================================
- --- chapter06/libcap.xml (revision 11147)
- +++ chapter06/libcap.xml (working copy)
- @@ -55,7 +55,7 @@
-
- <para>Install the package:</para>
-
- -<screen><userinput remap="install">make RAISE_SETFCAP=no prefix=/usr install
- +<screen><userinput remap="install">make RAISE_SETFCAP=no lib=lib prefix=/usr install
- chmod -v 755 /usr/lib/libcap.so</userinput></screen>
-
- <variablelist>
|