diff options
author | Jeremy Huntwork <jhuntwork@linuxfromscratch.org> | 2006-01-30 01:45:25 +0000 |
---|---|---|
committer | Jeremy Huntwork <jhuntwork@linuxfromscratch.org> | 2006-01-30 01:45:25 +0000 |
commit | 1ba726fd6f7114e4a9961d25d63535d273356071 (patch) | |
tree | a287f2f741b366889d7ce67564075ea928fb5b1e /chapter06 | |
parent | bedc966aee03e11f5672450812c1ee92a0505454 (diff) |
Restore the use of *startfile_prefix_spec
git-svn-id: http://svn.linuxfromscratch.org/LFS/trunk/BOOK@7314 4aa44e1e-78dd-0310-a6d2-fbcd4c07a689
Diffstat (limited to 'chapter06')
-rw-r--r-- | chapter06/gcc.xml | 5 | ||||
-rw-r--r-- | chapter06/readjusting.xml | 34 |
2 files changed, 19 insertions, 20 deletions
diff --git a/chapter06/gcc.xml b/chapter06/gcc.xml index e8c49be34..b67e4ede7 100644 --- a/chapter06/gcc.xml +++ b/chapter06/gcc.xml @@ -99,6 +99,11 @@ To support those packages, create this symlink:</para> <screen><userinput>ln -sv ../usr/bin/cpp /lib</userinput></screen> +<para>Many packages use the name <command>cc</command> to call the C +compiler. To satisfy those packages, create a symlink:</para> + +<screen><userinput>ln -sv gcc /usr/bin/cc</userinput></screen> + <note><para>At this point, it is strongly recommended to repeat the sanity check performed earlier in this chapter. Refer back to <xref linkend="ch-system-readjusting" role=","/> and repeat the check. If the results diff --git a/chapter06/readjusting.xml b/chapter06/readjusting.xml index ef46f1a3d..eb81b8091 100644 --- a/chapter06/readjusting.xml +++ b/chapter06/readjusting.xml @@ -19,18 +19,24 @@ be guided from that same <filename class="directory">/tools/lib</filename> directory to the LFS <filename class="directory">/{,usr/}lib</filename> directories.</para> -<para>First, create a symlink to the adjusted linker we created in chapter 5.</para> +<para>First, backup the <filename class="directory">/tools</filename> linker, and +replace it with the adjusted linker we made in chapter 5. We'll also create a +link to its counterpart in <filename class="directory">/tools/$MACHTYPE/bin</filename></para> -<screen><userinput>ln -sv /tools/bin/ld-new /usr/bin/ld</userinput></screen> +<screen><userinput>mv -v /tools/bin/{ld,ld-old} +mv -v /tools/$MACHTYPE/bin/{ld,ld-old} +mv -v /tools/bin/{ld-new,ld} +ln -sv /tools/bin/ld /tools/$MACHTYPE/bin/ld</userinput></screen> <para>Next, amend the GCC specs file so that it points to the new -dynamic linker. A <command>sed</command> command accomplishes this:</para> +dynamic linker, and so that GCC knows where to find its start files. +A <command>perl</command> command accomplishes this:</para> -<screen><userinput>SPECFILE=`dirname $(gcc -print-libgcc-file-name)`/specs && -gcc -dumpspecs > $SPECFILE && -sed -i -e '/^\*link:$/{n;s,$, -L/usr/lib,}' \ - -e 's@^/tools/lib/ld-linux.so.2@/lib/ld-linux.so.2@g' $SPECFILE && -unset SPECFILE</userinput></screen> +<screen><userinput>gcc -dumpspecs | \ +perl -pi -e 's@/tools/lib/ld-linux.so.2@/lib/ld-linux.so.2@g;' \ + -e 's@\*startfile_prefix_spec:\n@$_/usr/lib/ @g;' > \ + `dirname $(gcc --print-libgcc-file-name)`/specs +</userinput></screen> <para>It is a good idea to visually inspect the specs file to verify the intended change was actually made.</para> @@ -43,18 +49,6 @@ dynamic linker in the above commands. Refer back to <xref linkend="ch-tools-toolchaintechnotes" role=","/> if necessary.</para></important> -<para>Now create a temporary wrapper script for <filename>gcc</filename>. -This script will point to the real <filename>gcc</filename> -in <filename class="directory">/tools</filename> but with adjusted parameters -to ensure that GCC in the next section links to our newly installed Glibc.</para> - -<screen><userinput>cat > /usr/bin/gcc << "EOF" -#!/bin/bash -/tools/bin/gcc -B/usr/lib/ -B/usr/bin/ $@ -EOF -chmod 755 /usr/bin/gcc -ln -s gcc /usr/bin/cc</userinput></screen> - <caution><para>It is imperative at this point to stop and ensure that the basic functions (compiling and linking) of the adjusted toolchain are working as expected. To do this, perform a sanity |