binutils-pass1.xml 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. <?xml version="1.0" encoding="ISO-8859-1"?>
  2. <!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.3//EN" "http://www.oasis-open.org/docbook/xml/4.3/docbookx.dtd" [
  3. <!ENTITY % general-entities SYSTEM "../general.ent">
  4. %general-entities;
  5. ]>
  6. <sect1 id="ch-tools-binutils-pass1" role="wrap">
  7. <title>Binutils-&binutils-version; - Pass 1</title>
  8. <?dbhtml filename="binutils-pass1.html"?>
  9. <indexterm zone="ch-tools-binutils-pass1">
  10. <primary sortas="a-Binutils">Binutils</primary>
  11. <secondary>tools, pass 1</secondary></indexterm>
  12. <sect2 role="package"><title/>
  13. <xi:include xmlns:xi="http://www.w3.org/2003/XInclude" href="../chapter06/binutils.xml" xpointer="xpointer(/sect1/sect2[1]/para[1])"/>
  14. <segmentedlist>
  15. <segtitle>&buildtime;</segtitle>
  16. <segtitle>&diskspace;</segtitle>
  17. <seglistitem><seg>1.0 SBU</seg><seg>194 MB</seg></seglistitem>
  18. </segmentedlist>
  19. <xi:include xmlns:xi="http://www.w3.org/2003/XInclude" href="../chapter06/binutils.xml" xpointer="xpointer(/sect1/sect2[1]/segmentedlist[2])"/>
  20. </sect2>
  21. <sect2 role="installation">
  22. <title>Installation of Binutils</title>
  23. <para>It is important that Binutils be the first package to get compiled,
  24. because both Glibc and GCC perform various tests on the available linker and
  25. assembler to determine which of their own features to enable.</para>
  26. <para>This package is known to behave badly when you change its default
  27. optimization flags (including the <parameter>-march</parameter> and
  28. <parameter>-mcpu</parameter> options). Therefore, if you have defined any
  29. environment variables that override default optimizations, such as CFLAGS and
  30. CXXFLAGS, we recommend un-setting them when building Binutils.</para>
  31. <para>The Binutils documentation recommends building Binutils outside of the
  32. source directory in a dedicated build directory:</para>
  33. <screen><userinput>mkdir ../binutils-build
  34. cd ../binutils-build</userinput></screen>
  35. <note><para>If you want the SBU values listed in the rest of the book to be of
  36. any use, you will have to measure the time it takes to build this package --
  37. from the configuration up to and including the first install. To achieve this
  38. easily, you could wrap the four commands in a <command>time</command> command
  39. like this: <userinput>time { ./configure ... &amp;&amp; ... &amp;&amp; ...
  40. &amp;&amp; make install; }</userinput>.</para></note>
  41. <para>Now prepare Binutils for compilation:</para>
  42. <screen><userinput>../binutils-&binutils-version;/configure --prefix=/tools --disable-nls</userinput></screen>
  43. <para>The meaning of the configure options:</para>
  44. <variablelist>
  45. <varlistentry>
  46. <term><parameter>--prefix=/tools</parameter></term>
  47. <listitem><para>This tells the configure script to prepare to install the Binutils
  48. programs in the <filename class="directory">/tools</filename> directory.</para></listitem>
  49. </varlistentry>
  50. <varlistentry>
  51. <term><parameter>--disable-nls</parameter></term>
  52. <listitem><para>This disables internationalization (a word often shortened to
  53. i18n). We don't need this for our static programs and <emphasis>nls</emphasis>
  54. often causes problems when linking statically.</para></listitem>
  55. </varlistentry>
  56. </variablelist>
  57. <para>Continue with compiling the package:</para>
  58. <screen><userinput>make configure-host
  59. make LDFLAGS="-all-static"</userinput></screen>
  60. <para>The meaning of the make parameters:</para>
  61. <variablelist>
  62. <varlistentry>
  63. <term><parameter>configure-host</parameter></term>
  64. <listitem><para>This forces all the subdirectories to be configured immediately.
  65. A statically linked build will fail without it. We therefore use this option to work
  66. around the problem.</para></listitem>
  67. </varlistentry>
  68. <varlistentry>
  69. <term><parameter>LDFLAGS="-all-static"</parameter></term>
  70. <listitem><para>This tells the linker that all the Binutils programs should be
  71. linked statically. However, strictly speaking, <parameter>"-all-static"</parameter>
  72. is passed to the <command>libtool</command> program, which then passes
  73. <parameter>"-static"</parameter> to the linker.</para></listitem>
  74. </varlistentry>
  75. </variablelist>
  76. <para>Compilation is complete. Normally we would now run the test suite, but
  77. at this early stage the test suite framework (Tcl, Expect and DejaGNU) is not
  78. yet in place. And there would be little point in running the tests anyhow,
  79. since the programs from this first pass will soon be replaced by those from the
  80. second.</para>
  81. <para>Now install the package:</para>
  82. <screen><userinput>make install</userinput></screen>
  83. <para>Now prepare the linker for the <quote>Adjusting</quote> phase later on:</para>
  84. <screen><userinput>make -C ld clean
  85. make -C ld LDFLAGS="-all-static" LIB_PATH=/tools/lib</userinput></screen>
  86. <para>The meaning of the make parameters:</para>
  87. <variablelist>
  88. <varlistentry>
  89. <term><parameter>-C ld clean</parameter></term>
  90. <listitem><para>This tells the make program to remove all the compiled files
  91. in the <filename class="directory">ld</filename> subdirectory.</para></listitem>
  92. </varlistentry>
  93. <varlistentry>
  94. <term><parameter>-C ld LDFLAGS="-all-static"
  95. LIB_PATH=/tools/lib</parameter></term>
  96. <listitem><para>This option rebuilds everything in the
  97. <filename class="directory">ld</filename> subdirectory. Specifying the LIB_PATH
  98. makefile variable on the command line allows us to override the default value
  99. and have it point to our temporary tools location. The value of this variable
  100. specifies the linker's default library search path. You will see how this
  101. preparation is used later on in the chapter.</para></listitem>
  102. </varlistentry>
  103. </variablelist>
  104. <warning><para><emphasis>Do not yet remove</emphasis> the Binutils build and
  105. source directories. You will need them again in their current state a bit
  106. further on in this chapter.</para></warning>
  107. </sect2>
  108. <sect2 role="content"><title/>
  109. <para>The details on this package are found in <xref linkend="contents-binutils"/>.</para>
  110. </sect2>
  111. </sect1>