gcc-inst.xml 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. <sect2><title>&nbsp;</title><para>&nbsp;</para></sect2>
  2. <sect2>
  3. <title>Installation of GCC</title>
  4. <para>We won't be needing a C++ compiler until Chapter 6. So, only
  5. the gcc-core tarball needs to be unpacked at this time.</para>
  6. <para>This package is known to behave badly when you have changed its
  7. default optimization flags (including the -march and -mcpu options).
  8. Therefore, if you have defined any environment variables that override
  9. default optimizations, such as CFLAGS and CXXFLAGS, we recommend unsetting
  10. or modifying them when building GCC.</para>
  11. <para>It is recommended by the GCC installation documentation to build
  12. GCC outside of the source directory in a dedicated directory:</para>
  13. <para><screen><userinput>mkdir ../gcc-build
  14. cd ../gcc-build</userinput></screen></para>
  15. <para>Prepare GCC to be compiled:</para>
  16. <para><screen><userinput>../gcc-&gcc-version;/configure --prefix=/static \
  17. &nbsp;&nbsp;&nbsp;--disable-nls --disable-shared \
  18. &nbsp;&nbsp;&nbsp;--with-as=$LFS/static/bin/as \
  19. &nbsp;&nbsp;&nbsp;--with-ld=$LFS/static/bin/ld</userinput></screen></para>
  20. <para>The meaning of the configure options are:</para>
  21. <itemizedlist>
  22. <listitem><para><userinput>--prefix=/static:</userinput> This is NOT a
  23. typo. GCC hard codes some paths while compiling and so we need to pass
  24. <filename class="directory">/static</filename> as the prefix during the
  25. configure stage. We will pass the real installation prefix (<filename
  26. class="directory">$LFS/static</filename> during the installation
  27. stage later on.</para></listitem>
  28. <listitem><para><userinput>--disable-shared:</userinput> This prevents the
  29. build of dynamic libraries. They are useless to us at the moment. We'll
  30. create them when we reinstall GCC in chapter 6.</para></listitem>
  31. <listitem><para><userinput>--with-as=$LFS/static/bin/as and
  32. --with-ld=$LFS/static/bin/ld:</userinput> GCC can be miscompiled if your
  33. host distribution's Binutils package is quite old. We need a good working
  34. static GCC until we reinstall GCC later in chapter 6. So by using
  35. <filename>as</filename> and <filename>ld</filename> from the Binutils
  36. package we compiled earlier in this chapter we ensure that GCC will work
  37. correctly.</para></listitem>
  38. </itemizedlist>
  39. <para>Continue with compiling the package:</para>
  40. <para><screen><userinput>make BOOT_LDFLAGS="-static" bootstrap</userinput></screen></para>
  41. <para>The meaning of the make options are:</para>
  42. <itemizedlist>
  43. <listitem><para><userinput>BOOT_LDFLAGS="-static":</userinput> This is
  44. GCC's equivalent to make LDFLAGS="-static" as we use with other packages to
  45. compile them statically.</para></listitem>
  46. <listitem><para><userinput>bootstrap:</userinput> The
  47. <emphasis>bootstrap</emphasis> target doesn't just compile GCC, but it
  48. compiles GCC a second time. It uses the first compiled programs to compile
  49. itself a second and third time to make sure the compiler compiled properly
  50. and can compile itself properly.</para></listitem>
  51. </itemizedlist>
  52. <para>And finish off installing the package:</para>
  53. <para><screen><userinput>make prefix=$LFS/static install-no-fixedincludes</userinput></screen></para>
  54. <para>The meaning of the make option is:</para>
  55. <itemizedlist>
  56. <listitem><para><userinput>install-no-fixedincludes:</userinput> This prevents
  57. the fixincludes script from running. Preventing this is necessary because
  58. under normal circumstances the GCC installation will run the fixincludes
  59. script which scans your system for header files that need to be fixed. It
  60. might find that the Glibc header files of your host system need to be fixed.
  61. If so, it will fix them and put them in
  62. <filename>$LFS/static/lib/gcc-lib/i686-pc-linux-gnu/3.2</filename>. Later on
  63. in chapter 6 you will install Glibc which will put its header files in
  64. <filename>/usr/include</filename>. Next you will install other programs that
  65. use the Glibc headers and GCC will look in
  66. <filename>/static/lib/gcc-lib</filename> before looking in
  67. <filename>/usr/include</filename>, with the result of finding and using the
  68. fixed Glibc header files from your host distribution, which are probably
  69. incompatible with the Glibc version actually used on the LFS
  70. system.</para></listitem>
  71. </itemizedlist>
  72. <para>As the finishing touch we'll create the <filename
  73. class="symlink">$LFS/static/bin/cc</filename> symlink. A lot of programs
  74. and scripts try to run <userinput>cc</userinput> instead of
  75. <userinput>gcc</userinput> This is to keep programs generic and usable on
  76. all kinds of Unix systems. Not everybody has GNU CC installed. Just running
  77. cc (C Compiler) leaves the user free to decide which C compiler to install.
  78. The symlink will point to the system's default compiler.</para>
  79. <para><screen><userinput>ln -s gcc $LFS/static/bin/cc</userinput></screen></para>
  80. </sect2>