source: chapter05/gcc-pass1.xml@ 54092c6

multilib-10.1
Last change on this file since 54092c6 was 54092c6, checked in by Thomas Trepl <thomas@…>, 4 years ago

Updates after 9.1 release

git-svn-id: http://svn.linuxfromscratch.org/LFS/branches/multilib@11766 4aa44e1e-78dd-0310-a6d2-fbcd4c07a689

  • Property mode set to 100644
File size: 13.5 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
4 <!ENTITY % general-entities SYSTEM "../general.ent">
5 %general-entities;
6]>
7
8<sect1 id="ch-tools-gcc-pass1" role="wrap" xreflabel="gcc-pass1">
9 <?dbhtml filename="gcc-pass1.html"?>
10
11 <sect1info condition="script">
12 <productname>gcc-pass1</productname>
13 <productnumber>&gcc-version;</productnumber>
14 <address>&gcc-url;</address>
15 </sect1info>
16
17 <title>GCC-&gcc-version; - Pass 1</title>
18
19 <indexterm zone="ch-tools-gcc-pass1">
20 <primary sortas="a-GCC">GCC</primary>
21 <secondary>tools, pass 1</secondary>
22 </indexterm>
23
24 <sect2 role="package">
25 <title/>
26
27 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
28 href="../chapter06/gcc.xml"
29 xpointer="xpointer(/sect1/sect2[1]/para[1])"/>
30
31 <segmentedlist>
32 <segtitle>&buildtime;</segtitle>
33 <segtitle>&diskspace;</segtitle>
34
35 <seglistitem>
36 <seg>&gcc-ch5p1-sbu;</seg>
37 <seg>&gcc-ch5p1-du;</seg>
38 </seglistitem>
39 </segmentedlist>
40
41 </sect2>
42
43 <sect2 role="installation">
44 <title>Installation of Cross GCC</title>
45
46 <para arch="default">GCC now requires the GMP, MPFR, and MPC packages. As
47 these packages may not be included in your host distribution, they will be
48 built with GCC. Unpack each package into the GCC source directory and
49 rename the resulting directories so the GCC build procedures will
50 automatically use them:</para>
51
52 <para arch="ml_32,ml_x32,ml_all">GCC now requires the GMP, ISL, MPFR, and MPC packages.
53 As these packages may not be included in your host distribution, they will
54 be built with GCC. Unpack each package into the GCC source directory and
55 rename the resulting directories so the GCC build procedures will
56 automatically use them:</para>
57
58 <note><para>There are frequent misunderstandings about this chapter. The
59 procedures are the same as every other chapter as explained earlier (<xref
60 linkend='buildinstr'/>). First extract the gcc tarball from the sources
61 directory and then change to the directory created. Only then should you
62 proceed with the instructions below.</para></note>
63
64<screen arch="default"><userinput remap="pre">tar -xf ../mpfr-&mpfr-version;.tar.xz
65mv -v mpfr-&mpfr-version; mpfr
66tar -xf ../gmp-&gmp-version;.tar.xz
67mv -v gmp-&gmp-version; gmp
68tar -xf ../mpc-&mpc-version;.tar.gz
69mv -v mpc-&mpc-version; mpc</userinput></screen>
70<screen arch="ml_32,ml_x32,ml_all"><userinput remap="pre">tar -xf ../mpfr-&mpfr-version;.tar.xz
71mv -v mpfr-&mpfr-version; mpfr
72tar -xf ../gmp-&gmp-version;.tar.xz
73mv -v gmp-&gmp-version; gmp
74tar -xf ../mpc-&mpc-version;.tar.gz
75mv -v mpc-&mpc-version; mpc
76tar -xf ../isl-&isl-version;.tar.xz
77mv -v isl-&isl-version; isl</userinput></screen>
78
79 <para>The following command will change the location of GCC's default
80 dynamic linker to use the one installed in <filename
81 class="directory">/tools</filename>. It also removes <filename
82 class="directory">/usr/include</filename> from GCC's include search path.
83 Issue:</para>
84
85<screen><userinput remap="pre">for file in gcc/config/{linux,i386/linux{,64}}.h
86do
87 cp -uv $file{,.orig}
88 sed -e 's@/lib\(64\)\?\(32\)\?\(x32\)\?/ld@/tools&amp;@g' \
89 -e 's@/usr@/tools@g' $file.orig &gt; $file
90 touch $file.orig
91done
92sed -e "/^#define[[:blank:]]*STANDARD_STARTFILE_PREFIX_1/ s;\".*\";\"/tools/lib/\";" \
93 -e "/^#define[[:blank:]]*STANDARD_STARTFILE_PREFIX_2/ s;\".*\";\"\";" \
94 -i gcc/gcc.c</userinput></screen>
95
96 <para>In case the above seems hard to follow, let's break it down a bit.
97 First we copy the files <filename>gcc/config/linux.h</filename>,
98 <filename>gcc/config/i386/linux.h</filename>, and
99 <filename>gcc/config/i368/linux64.h</filename> to a file of
100 the same name but with an added suffix of <quote>.orig</quote>. Then the
101 first sed expression prepends <quote>/tools</quote> to every instance of
102 <quote>/lib/ld</quote>, <quote>/lib64/ld</quote> or
103 <quote>/lib32/ld</quote>, while the second one replaces hard-coded
104 instances of <quote>/usr</quote>. Next, we add our define statements which
105 alter the default startfile prefix to the end of the file. Note that the
106 trailing <quote>/</quote> in <quote>/tools/lib/</quote> is required.
107 Finally, we use <command>touch</command> to update the timestamp on the
108 copied files. When used in conjunction with <command>cp -u</command>, this
109 prevents unexpected changes to the original files in case the commands are
110 inadvertently run twice.</para>
111
112 <para arch="default">Finally, on x86_64 hosts, set the default directory
113 name for 64-bit libraries to <quote>lib</quote>:</para>
114
115<screen arch="default"><userinput remap="pre">case $(uname -m) in
116 x86_64)
117 sed -e '/m64=/s/lib64/lib/' \
118 -i.orig gcc/config/i386/t-linux64
119 ;;
120esac</userinput></screen>
121
122<screen arch="ml_32,ml_x32,ml_all"><userinput remap="pre">sed -e '/m64=/s/lib64/lib/' \
123 -e '/m32=/s/m32=.*/m32=..\/lib32$(call if_multiarch,:i386-linux-gnu)/' \
124 -i.orig gcc/config/i386/t-linux64</userinput></screen>
125
126<!--
127 <para>GCC doesn't detect stack protection correctly, which causes problems
128 for the build of Glibc-&glibc-version;, so fix that by issuing the following
129 command:</para>
130
131<screen><userinput remap="pre">sed -i '/k prot/agcc_cv_libc_provides_ssp=yes' gcc/configure</userinput></screen>
132-->
133
134<!--
135 <para>Also fix a problem identified upstream:</para>
136
137<screen><userinput remap="pre">sed -i 's/if \((code.*))\)/if (\1 \&amp;\&amp; \!DEBUG_INSN_P (insn))/' gcc/sched-deps.c</userinput></screen>
138-->
139
140 <!-- Following patch might be obsolete with gcc >= 8.2.1 -->
141 <!-- see: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=86724 -->
142 <!-- Fix applied in ch5-gcc-pass{1,2}, ch6-gcc -->
143<!--
144 <para arch="ml_32,ml_x32,ml_all">Fix an issue with isl-&isl-version;:</para>
145
146<screen arch="ml_32,ml_x32,ml_all"><userinput remap="pre">sed -e "/#include &lt;isl\/schedule_node.h&gt;/ a#include &lt;isl/id.h&gt;\n#include &lt;isl/space.h&gt;" \
147 -i gcc/graphite.h</userinput></screen>
148-->
149
150 <para>The GCC documentation recommends building GCC
151 in a dedicated build directory:</para>
152
153<screen><userinput remap="pre">mkdir -v build
154cd build</userinput></screen>
155
156 <para>Prepare GCC for compilation:</para>
157
158<screen><userinput arch="default" remap="configure">mloptions="--disable-multilib"</userinput>
159<userinput arch="ml_32,ml_x32,ml_all" remap="configure">mloptions="--enable-multilib --with-multilib-list=m64"</userinput>
160<userinput arch="ml_32,ml_all" remap="configure">mloptions="$mloptions,m32"</userinput>
161<userinput arch="ml_x32,ml_all" remap="configure">mloptions="$mloptions,mx32"</userinput>
162<userinput remap="configure">../configure \
163 --target=$LFS_TGT \
164 --prefix=/tools \
165 --with-glibc-version=2.11 \
166 --with-sysroot=$LFS \
167 --with-newlib \
168 --without-headers \
169 --with-local-prefix=/tools \
170 --with-native-system-header-dir=/tools/include \
171 --disable-nls \
172 --disable-shared \
173 --disable-decimal-float \
174 --disable-threads \
175 --disable-libatomic \
176 --disable-libgomp \
177 --disable-libquadmath \
178 --disable-libssp \
179 --disable-libvtv \
180 --disable-libstdcxx \
181 --enable-languages=c,c++ \
182 $mloptions</userinput></screen>
183
184 <variablelist>
185 <title>The meaning of the configure options:</title>
186
187 <varlistentry>
188 <term><parameter>--with-glibc-version=2.11</parameter></term>
189 <listitem>
190 <para>This option ensures the package will be compatible with the host's
191 version of glibc. It is set to the minimum glibc requirement
192 specified in the <xref linkend="ch-partitioning-hostreqs"/>.</para>
193 </listitem>
194 </varlistentry>
195
196 <varlistentry>
197 <term><parameter>--with-newlib</parameter></term>
198 <listitem>
199 <para>Since a working C library is not yet available, this ensures
200 that the inhibit_libc constant is defined when building libgcc. This prevents
201 the compiling of any code that requires libc support.</para>
202 </listitem>
203 </varlistentry>
204
205 <varlistentry>
206 <term><parameter>--without-headers</parameter></term>
207 <listitem>
208 <para>When creating a complete cross-compiler, GCC requires
209 standard headers compatible with the target system. For our
210 purposes these headers will not be needed. This switch prevents
211 GCC from looking for them.</para>
212 </listitem>
213 </varlistentry>
214
215 <varlistentry>
216 <term><parameter>--with-local-prefix=/tools</parameter></term>
217 <listitem>
218 <para>The local prefix is the location in the system that GCC will search
219 for locally installed include files. The default is <filename>/usr/local</filename>.
220 Setting this to <filename>/tools</filename> helps keep the host location of
221 <filename>/usr/local</filename> out of this GCC's search path.</para>
222 </listitem>
223 </varlistentry>
224
225 <varlistentry>
226 <term><parameter>--with-native-system-header-dir=/tools/include</parameter></term>
227 <listitem>
228 <para>By default, GCC searches <filename>/usr/include</filename> for
229 system headers. In conjunction with the sysroot switch, this would
230 normally translate to <filename>$LFS/usr/include</filename>. However
231 the headers that will be installed in the next two sections will go
232 to <filename>$LFS/tools/include</filename>. This switch ensures that
233 gcc will find them correctly. In the second pass of GCC, this same
234 switch will ensure that no headers from the host system are
235 found.</para>
236 </listitem>
237 </varlistentry>
238
239 <varlistentry>
240 <term><parameter>--disable-shared</parameter></term>
241 <listitem>
242 <para>This switch forces GCC to link its internal libraries
243 statically. We do this to avoid possible issues with the host
244 system.</para>
245 </listitem>
246 </varlistentry>
247
248 <varlistentry>
249 <term><parameter>--disable-decimal-float, --disable-threads,
250 --disable-libatomic, --disable-libgomp, <!--- -disable-libmpx,-->
251 --disable-libquadmath, --disable-libssp, --disable-libvtv,
252 --disable-libstdcxx</parameter></term>
253 <listitem>
254 <para>These switches disable support for the decimal floating point
255 extension, threading, libatomic, libgomp, <!--libmpx, --> libquadmath, libssp,
256 libvtv, and the C++ standard library respectively. These features
257 will fail to compile when building a cross-compiler and are not
258 necessary for the task of cross-compiling the temporary libc.</para>
259 </listitem>
260 </varlistentry>
261
262 <varlistentry arch="default">
263 <term><parameter>--disable-multilib</parameter></term>
264 <listitem>
265 <para>On x86_64, LFS does not yet support a multilib configuration.
266 This switch is harmless for x86.</para>
267 </listitem>
268 </varlistentry>
269
270 <varlistentry arch="ml_32,ml_x32,ml_all">
271 <term><parameter>--enable-multilib,
272 --with-multilib-list=m32,m64,mx32</parameter></term>
273 <listitem>
274 <para>LFS now supports a multilib configuration. Enable it for the
275 32bit, the 64-bit, and the mixed mode.</para>
276 </listitem>
277 </varlistentry>
278
279 <varlistentry>
280 <term><parameter>--enable-languages=c,c++</parameter></term>
281 <listitem>
282 <para>This option ensures that only the C and C++ compilers are built.
283 These are the only languages needed now.</para>
284 </listitem>
285 </varlistentry>
286
287 </variablelist>
288
289 <para>Compile GCC by running:</para>
290
291<screen><userinput remap="make">make</userinput></screen>
292
293 <para>Compilation is now complete. At this point, the test suite would
294 normally be run, but, as mentioned before, the test suite framework is
295 not in place yet. The benefits of running the tests at this point
296 are minimal since the programs from this first pass will soon be
297 replaced.</para>
298
299 <para>Install the package:</para>
300
301<screen><userinput remap="install">make install</userinput></screen>
302<!--
303 <para>Using <parameter>- -disable-shared</parameter> means that the
304 <filename>libgcc_eh.a</filename> file isn't created and installed. The
305 Glibc package depends on this library as it uses
306 <parameter>-lgcc_eh</parameter> within its build system. This dependency
307 can be satisfied by creating a symlink to <filename>libgcc.a</filename>,
308 since that file will end up containing the objects normally contained in
309 <filename>libgcc_eh.a</filename>:</para>
310
311<screen><userinput remap="install">ln -sv libgcc.a `$LFS_TGT-gcc -print-libgcc-file-name | sed 's/libgcc/&amp;_eh/'`</userinput></screen>
312-->
313 </sect2>
314
315 <sect2 role="content">
316 <title/>
317
318 <para>Details on this package are located in
319 <xref linkend="contents-gcc" role="."/></para>
320
321 </sect2>
322
323</sect1>
Note: See TracBrowser for help on using the repository browser.