source: chapter05/gcc-pass1.xml@ 4aff396

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 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 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 4aff396 was 4aff396, checked in by Matthew Burgess <matthew@…>, 12 years ago

Upgrade to MPFR-3.1.1. Fixes #3133.

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

  • Property mode set to 100644
File size: 9.7 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">
9 <?dbhtml filename="gcc-pass1.html"?>
10
11 <sect1info condition="script">
12 <productname>gcc</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>GCC now requires the GMP, MPFR and MPC packages. As these packages may
47 not be included in your host distribution, they will be built with
48 GCC. Unpack each package into the GCC source directory and rename the
49 resulting directories so the GCC build procedures will automatically
50 use them:</para>
51
52 <note><para>There are frequent misunderstandings about this chapter. The
53 procedures are the same as every other chapter as explained earlier (<xref
54 linkend='buildinstr'/>). First extract the gcc tarball from the sources
55 directory and then change to the directory created. Only then should you
56 proceed with the instructions below.</para></note>
57
58<screen><userinput remap="pre">tar -Jxf ../mpfr-&mpfr-version;.tar.xz
59mv -v mpfr-&mpfr-version; mpfr
60tar -Jxf ../gmp-&gmp-version;.tar.xz
61mv -v gmp-&gmp-version; gmp
62tar -zxf ../mpc-&mpc-version;.tar.gz
63mv -v mpc-&mpc-version; mpc</userinput></screen>
64
65 <para>The following command will change the location of GCC's default
66 dynamic linker to use the one installed in <filename
67 class="directory">/tools</filename>. It also removes <filename
68 class="directory">/usr/include</filename> from GCC's include search path.
69 Issue:</para>
70
71<screen><userinput remap="pre">for file in \
72 $(find gcc/config -name linux64.h -o -name linux.h -o -name sysv4.h)
73do
74 cp -uv $file{,.orig}
75 sed -e 's@/lib\(64\)\?\(32\)\?/ld@/tools&amp;@g' \
76 -e 's@/usr@/tools@g' $file.orig &gt; $file
77 echo '
78#undef STANDARD_STARTFILE_PREFIX_1
79#undef STANDARD_STARTFILE_PREFIX_2
80#define STANDARD_STARTFILE_PREFIX_1 "/tools/lib/"
81#define STANDARD_STARTFILE_PREFIX_2 ""' &gt;&gt; $file
82 touch $file.orig
83done</userinput></screen>
84
85 <para>In case the above seems hard to follow, let's break it down a bit.
86 First we find all the files under the <filename
87 class="directory">gcc/config</filename> directory that are named either
88 <filename>linux.h</filename>, <filename>linux64.h</filename> or
89 <filename>sysv4.h</filename>. For each file found, we copy it to a file of
90 the same name but with an added suffix of <quote>.orig</quote>. Then the
91 first sed expression prepends <quote>/tools</quote> to every instance of
92 <quote>/lib/ld</quote>, <quote>/lib64/ld</quote> or
93 <quote>/lib32/ld</quote>, while the second one replaces hard-coded
94 instances of <quote>/usr</quote>. Next, we add our define statements which
95 alter the default startfile prefix to the end of the file. Note that the
96 trailing <quote>/</quote> in <quote>/tools/lib/</quote> is required.
97 Finally, we use <command>touch</command> to update the timestamp on the
98 copied files. When used in conjunction with <command>cp -u</command>, this
99 prevents unexpected changes to the original files in case the commands are
100 inadvertently run twice. </para>
101
102 <para>The GCC documentation recommends building GCC outside of the
103 source directory in a dedicated build directory:</para>
104
105<screen><userinput remap="pre">mkdir -v ../gcc-build
106cd ../gcc-build</userinput></screen>
107
108 <para>Prepare GCC for compilation:</para>
109
110<screen><userinput remap="configure">../gcc-&gcc-version;/configure \
111 --target=$LFS_TGT \
112 --prefix=/tools \
113 --with-sysroot=$LFS \
114 --with-newlib \
115 --without-headers \
116 --with-local-prefix=/tools \
117 --with-native-system-header-dir=/tools/include \
118 --disable-nls \
119 --disable-shared \
120 --disable-multilib \
121 --disable-decimal-float \
122 --disable-threads \
123 --disable-libmudflap \
124 --disable-libssp \
125 --disable-libgomp \
126 --disable-libquadmath \
127 --enable-languages=c \
128 --with-mpfr-include=$(pwd)/../gcc-&gcc-version;/mpfr/src \
129 --with-mpfr-lib=$(pwd)/mpfr/src/.libs</userinput></screen>
130
131 <variablelist>
132 <title>The meaning of the configure options:</title>
133
134 <varlistentry>
135 <term><parameter>--with-newlib</parameter></term>
136 <listitem>
137 <para>Since a working C library is not yet available, this ensures
138 that the inhibit_libc constant is defined when building libgcc. This prevents
139 the compiling of any code that requires libc support.</para>
140 </listitem>
141 </varlistentry>
142
143 <varlistentry>
144 <term><parameter>--without-headers</parameter></term>
145 <listitem>
146 <para>When creating a complete cross-compiler, GCC requires
147 standard headers compatible with the target system. For our
148 purposes these headers will not be needed. This switch prevents
149 GCC from looking for them.</para>
150 </listitem>
151 </varlistentry>
152
153 <varlistentry>
154 <term><parameter>--with-local-prefix=/tools</parameter></term>
155 <listitem>
156 <para>The local prefix is the location in the system that GCC will search
157 for locally installed include files. The default is <filename>/usr/local</filename>.
158 Setting this to <filename>/tools</filename> helps keep the host location of
159 <filename>/usr/local</filename> out of this GCC's search path.</para>
160 </listitem>
161 </varlistentry>
162
163 <varlistentry>
164 <term><parameter>--with-native-system-header-dir=/tools/include</parameter></term>
165 <listitem>
166 <para>By default GCC searches <filename>/usr/include</filename> for system
167 headers. In conjunction with the sysroot switch, this would translate normally
168 to <filename>$LFS/usr/include</filename>. However the headers that will be installed
169 in the next two sections will go to <filename>$LFS/tools/include</filename>. This
170 switch ensures that gcc will find them correctly. In the second pass of GCC, this
171 same switch will ensure that no headers from the host system are found.</para>
172 </listitem>
173 </varlistentry>
174
175 <varlistentry>
176 <term><parameter>--disable-shared</parameter></term>
177 <listitem>
178 <para>This switch forces GCC to link its internal libraries
179 statically. We do this to avoid possible issues with the host
180 system.</para>
181 </listitem>
182 </varlistentry>
183
184 <varlistentry>
185 <term><parameter>--disable-decimal-float, --disable-threads, --disable-libmudflap, --disable-libssp, --disable-libgomp, --disable-libquadmath</parameter></term>
186 <listitem>
187 <para>These switches disable support for the decimal floating point
188 extension, threading, libmudflap, libssp and libgomp and libquadmath
189 respectively. These features will fail to compile when building a
190 cross-compiler and are not necessary for the task of cross-compiling
191 the temporary libc.</para>
192 </listitem>
193 </varlistentry>
194
195 <varlistentry>
196 <term><parameter>--disable-multilib</parameter></term>
197 <listitem>
198 <para>On x86_64, LFS does not yet support a multilib configuration.
199 This switch is harmless for x86.</para>
200 </listitem>
201 </varlistentry>
202
203 <varlistentry>
204 <term><parameter>--enable-languages=c</parameter></term>
205 <listitem>
206 <para>This option ensures that only the C compiler is built.
207 This is the only language needed now.</para>
208 </listitem>
209 </varlistentry>
210
211 </variablelist>
212
213 <para>Compile GCC by running:</para>
214
215<screen><userinput remap="make">make</userinput></screen>
216
217 <para>Compilation is now complete. At this point, the test suite would
218 normally be run, but, as mentioned before, the test suite framework is
219 not in place yet. The benefits of running the tests at this point
220 are minimal since the programs from this first pass will soon be
221 replaced.</para>
222
223 <para>Install the package:</para>
224
225<screen><userinput remap="install">make install</userinput></screen>
226
227 <para>Using <parameter>--disable-shared</parameter> means that the
228 <filename>libgcc_eh.a</filename> file isn't created and installed. The
229 Glibc package depends on this library as it uses
230 <parameter>-lgcc_eh</parameter> within its build system. This dependency
231 can be satisfied by creating a symlink to <filename>libgcc.a</filename>,
232 since that file will end up containing the objects normally contained in
233 <filename>libgcc_eh.a</filename>:</para>
234
235<screen><userinput remap="install">ln -vs libgcc.a `$LFS_TGT-gcc -print-libgcc-file-name | sed 's/libgcc/&amp;_eh/'`</userinput></screen>
236
237 </sect2>
238
239 <sect2 role="content">
240 <title/>
241
242 <para>Details on this package are located in
243 <xref linkend="contents-gcc" role="."/></para>
244
245 </sect2>
246
247</sect1>
Note: See TracBrowser for help on using the repository browser.