source: chapter05/binutils-pass1.xml@ c00a42b

10.0 10.0-rc1 10.1 10.1-rc1 11.0 11.0-rc1 11.0-rc2 11.0-rc3 11.1 11.1-rc1 11.2 11.2-rc1 11.3 11.3-rc1 12.0 12.0-rc1 12.1 12.1-rc1 12.2 12.2-rc1 6.0 6.1 6.1.1 6.3 6.4 6.5 6.6 6.7 6.8 7.0 7.1 7.2 7.3 7.4 7.5 7.5-systemd 7.6 7.6-systemd 7.7 7.7-systemd 7.8 7.8-systemd 7.9 7.9-systemd 8.0 8.1 8.2 8.3 8.4 9.0 9.1 arm bdubbs/gcc13 ml-11.0 multilib renodr/libudev-from-systemd s6-init trunk v5_1 v5_1_1 xry111/arm64 xry111/arm64-12.0 xry111/clfs-ng xry111/lfs-next xry111/loongarch xry111/loongarch-12.0 xry111/loongarch-12.1 xry111/loongarch-12.2 xry111/mips64el xry111/multilib xry111/pip3 xry111/rust-wip-20221008 xry111/update-glibc
Last change on this file since c00a42b was f040abe, checked in by Alex Gronenwoud <alex@…>, 21 years ago

Making crossreferences from chapter 5 to 6.

git-svn-id: http://svn.linuxfromscratch.org/LFS/trunk/BOOK@3104 4aa44e1e-78dd-0310-a6d2-fbcd4c07a689

  • Property mode set to 100644
File size: 4.7 KB
Line 
1<sect1 id="ch05-binutils-pass1">
2<title>Installing Binutils-&binutils-version; - Pass 1</title>
3<?dbhtml filename="binutils-pass1.html" dir="chapter05"?>
4
5<screen>Estimated build time: &binutils-time-tools-pass1;
6Estimated required disk space: &binutils-compsize-tools-pass1;</screen>
7
8<para>For the package details see <xref linkend="contents-binutils"/>.</para>
9
10<sect2><title>&nbsp;</title><para>&nbsp;</para></sect2>
11
12<sect2>
13<title>Installation of Binutils</title>
14
15<para>It is important that Binutils be the first package to get compiled,
16because both Glibc and GCC perform various tests on the available linker and
17assembler to determine which of their own features to enable.</para>
18
19<note><para>Even though Binutils is an important toolchain package, we are not
20going to run the test suite at this early stage. First, the test suite framework
21is not yet in place and second, the programs from this first pass will soon be
22overwritten by those installed in the second pass.</para></note>
23
24<para>This package is known to behave badly when you have changed its default
25optimization flags (including the -march and -mcpu options). Therefore, if
26you have defined any environment variables that override default
27optimizations, such as CFLAGS and CXXFLAGS, we recommend unsetting or
28modifying them when building Binutils.</para>
29
30<para>The Binutils documentation recommends building Binutils outside of the
31source directory in a dedicated build directory:</para>
32
33<screen><userinput>mkdir ../binutils-build
34cd ../binutils-build</userinput></screen>
35
36<note><para>If you want the SBU values listed in the rest of the book to be of
37any use, you will have to measure the time it takes to build this package. To
38achieve this easily, you could do something like:
39<userinput>time { ./configure ... &amp;&amp; ... &amp;&amp; ... &amp;&amp; make install; }</userinput>.</para></note>
40
41<para>Now prepare Binutils for compilation:</para>
42
43<screen><userinput>../binutils-&binutils-version;/configure \
44&nbsp;&nbsp;&nbsp;&nbsp;--prefix=/tools --disable-nls</userinput></screen>
45
46<para>The meaning of the configure options:</para>
47
48<itemizedlist>
49<listitem><para><userinput>--prefix=/tools</userinput>: This tells the
50configure script to prepare to install the Binutils programs in the
51<filename>/tools</filename> directory.</para></listitem>
52
53<listitem><para><userinput>--disable-nls</userinput>: This disables
54internationalization (a word often shortened to i18n). We don't need this
55for our static programs and <emphasis>nls</emphasis> often causes problems
56when linking statically.</para></listitem>
57</itemizedlist>
58
59<para>Continue with compiling the package:</para>
60
61<screen><userinput>make configure-host
62make LDFLAGS="-all-static"</userinput></screen>
63
64<para>The meaning of the make parameters:</para>
65
66<itemizedlist>
67<listitem><para><userinput>configure-host</userinput>: This forces all the
68subdirectories to be configured immediately. A statically linked build will
69fail without it. We therefore use this option to work around the
70problem.</para></listitem>
71
72<listitem><para><userinput>LDFLAGS="-all-static"</userinput>: This tells the
73linker that all the Binutils programs should be linked statically. However,
74strictly speaking, <userinput>"-all-static"</userinput> is first passed to the
75<emphasis>libtool</emphasis> program which then passes
76<userinput>"-static"</userinput> on to the linker.</para></listitem>
77</itemizedlist>
78
79<para>And install the package:</para>
80
81<screen><userinput>make install</userinput></screen>
82
83<para>Now prepare the linker for the "locking in" of Glibc later on:</para>
84
85<screen><userinput>make -C ld clean
86make -C ld LDFLAGS="-all-static" LIB_PATH=/tools/lib</userinput></screen>
87
88<para>The meaning of the make parameters:</para>
89
90<itemizedlist>
91<listitem><para><userinput>-C ld clean</userinput>: This tells the make program
92to remove all the compiled files, but only in the <filename>ld</filename>
93subdirectory.</para></listitem>
94
95<listitem><para><userinput>-C ld LDFLAGS="-all-static" LIB_PATH=/tools/lib</userinput>:
96This option rebuilds everything in the <filename>ld</filename> subdirectory.
97Specifying the LIB_PATH makefile variable on the command line allows us to
98override the default value and have it point to our temporary tools location.
99The value of this variable specifies the linker's default library search path.
100You'll see how this preparation is used later on in the
101chapter.</para></listitem>
102</itemizedlist>
103
104<!-- HACK - Force some whitespace to appease tidy -->
105<literallayout></literallayout>
106
107<warning><para>Do not yet remove the Binutils build and source directories. You
108will need them again in their current state a bit further on in this
109chapter.</para></warning>
110
111<!-- HACK - Force some whitespace to appease tidy -->
112<literallayout></literallayout>
113
114</sect2>
115
116</sect1>
117
Note: See TracBrowser for help on using the repository browser.