source: chapter05/binutils-pass1.xml@ c76accc

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 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/mips64el xry111/pip3 xry111/rust-wip-20221008 xry111/update-glibc
Last change on this file since c76accc was 90e3cb3, checked in by Alex Gronenwoud <alex@…>, 20 years ago

Replacing several <userinput> tags by <command>.

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

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