source: chapter06/gcc-pass2.xml@ 6304533

xry111/clfs-ng
Last change on this file since 6304533 was 6304533, checked in by Xi Ruoyao <xry111@…>, 21 months ago

Merge remote-tracking branch 'origin/trunk' into xry111/clfs-ng

  • Property mode set to 100644
File size: 7.0 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-pass2" role="wrap" xreflabel="gcc-pass2">
9 <?dbhtml filename="gcc-pass2.html"?>
10
11 <sect1info condition="script">
12 <productname>gcc-pass2</productname>
13 <productnumber>&gcc-version;</productnumber>
14 <address>&gcc-url;</address>
15 </sect1info>
16
17 <title>GCC-&gcc-version; - Pass 2</title>
18
19 <indexterm zone="ch-tools-gcc-pass2">
20 <primary sortas="a-GCC">GCC</primary>
21 <secondary>tools, pass 2</secondary>
22 </indexterm>
23
24 <sect2 role="package">
25 <title/>
26
27 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
28 href="../chapter08/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-tmpp2-sbu;</seg>
37 <seg>&gcc-tmpp2-du;</seg>
38 </seglistitem>
39 </segmentedlist>
40
41 </sect2>
42
43 <sect2 role="installation">
44 <title>Installation of GCC</title>
45
46 <para>First fix a problem with the latest version of glibc:</para>
47
48 <screen><userinput remap="pre">patch -Np1 -i ../&gcc-upstream-fixes-patch;</userinput></screen>
49
50 <para>As in the first build of GCC, the GMP, MPFR, and MPC packages are
51 required. Unpack the tarballs and move them into the required directory
52 names:</para>
53
54<screen><userinput remap="pre">tar -xf ../mpfr-&mpfr-version;.tar.xz
55mv -v mpfr-&mpfr-version; mpfr
56tar -xf ../gmp-&gmp-version;.tar.xz
57mv -v gmp-&gmp-version; gmp
58tar -xf ../mpc-&mpc-version;.tar.gz
59mv -v mpc-&mpc-version; mpc</userinput></screen>
60
61 <para>For x86_64 target, set the default directory name for
62 64-bit libraries to <quote>lib</quote>. The command is unnecessary,
63 but harmless for 32-bit x86. If you are building for another target,
64 you may need to adjust the command for your target.</para>
65
66<screen><userinput remap="pre">sed -e '/m64=/s/lib64/lib/' \
67 -i.orig gcc/config/i386/t-linux64</userinput></screen>
68
69 <para>Override the building rule of libgcc and libstdc++ headers, to
70 allow building these libraries with POSIX threads support:</para>
71
72<screen><userinput remap="pre">sed '/thread_header =/s/@.*@/gthr-posix.h/' \
73 -i libgcc/Makefile.in libstdc++-v3/include/Makefile.in</userinput></screen>
74
75 <para>Create a separate build directory again:</para>
76
77<screen><userinput remap="pre">mkdir -v build
78cd build</userinput></screen>
79
80 <para>Before starting to build GCC, remember to unset any environment
81 variables that override the default optimization flags.</para>
82
83 <para>Now prepare GCC for compilation:</para>
84
85<screen><userinput remap="configure">../configure \
86 --build=$(../config.guess) \
87 --host=$LFS_TGT \
88 --target=$LFS_TGT \
89 LDFLAGS_FOR_TARGET=-L$PWD/$LFS_TGT/libgcc \
90 --prefix=/usr \
91 --with-build-sysroot=$LFS \
92 --enable-initfini-array \
93 --disable-nls \
94 --disable-multilib \
95 --disable-decimal-float \
96 --disable-libatomic \
97 --disable-libgomp \
98 --disable-libquadmath \
99 --disable-libssp \
100 --disable-libvtv \
101 --enable-languages=c,c++</userinput></screen>
102
103 <variablelist>
104 <title>The meaning of the new configure options:</title><!-- WIP -->
105
106 <varlistentry>
107 <term><parameter>--with-build-sysroot=$LFS</parameter></term>
108 <listitem>
109 <para>Normally, using <parameter>--host</parameter> ensures that
110 a cross-compiler is used for building GCC, and that compiler knows
111 that it has to look for headers and libraries in <filename
112 class="directory">$LFS</filename>. But the build system of GCC uses
113 other tools, which are not aware of this location. This switch is
114 needed to have them find the needed files in <filename
115 class="directory">$LFS</filename>, and not on the host.</para>
116 </listitem>
117 </varlistentry>
118
119 <varlistentry>
120 <term><parameter>--target=$LFS_TGT</parameter></term>
121 <listitem>
122 <para>As we are cross-compiling GCC, it's impossible to build
123 target libraries (<filename class="libraryfile">libgcc</filename>
124 and <filename class="libraryfile">libstdc++</filename>) with the
125 compiled GCC binaries because these binaries won't run on the
126 host distro. GCC building system will attempt to use the
127 C and C++ compilers on the host distro as a workaround by default.
128 It's not supported to build GCC target libraries with a different
129 version of GCC, so using host compilers may cause building
130 failure. This parameter ensures to build the libraries with GCC
131 pass 1 and prevent the issue.</para>
132 </listitem>
133 </varlistentry>
134
135 <varlistentry>
136 <term><parameter>LDFLAGS_FOR_TARGET=...</parameter></term>
137 <listitem>
138 <para>Allow <filename class="libraryfile">libstdc++</filename> to
139 use shared <filename class="libraryfile">libgcc</filename> being
140 built in this pass, instead of the static version built in GCC
141 pass 1. This is needed for supporting C++ exception
142 handling.</para>
143 </listitem>
144 </varlistentry>
145
146 <varlistentry>
147 <term><parameter>--enable-initfini-array</parameter></term>
148 <listitem>
149 <para>This option is automatically enabled when building a native
150 compiler with a native compiler on x86. But here, we build with
151 a cross compiler, so we need to explicitly set this option.</para>
152 </listitem>
153 </varlistentry>
154
155 </variablelist>
156
157 <para>Compile the package:</para>
158
159<screen><userinput remap="make">make</userinput></screen>
160
161 <para>Install the package:</para>
162
163<screen><userinput remap="install">make DESTDIR=$LFS install</userinput></screen>
164
165 <para>As a finishing touch, create a utility symlink. Many programs and scripts
166 run <command>cc</command> instead of <command>gcc</command>, which is
167 used to keep programs generic and therefore usable on all kinds of UNIX
168 systems where the GNU C compiler is not always installed. Running
169 <command>cc</command> leaves the system administrator free to decide
170 which C compiler to install:</para>
171
172<screen><userinput remap="install">ln -sv gcc $LFS/usr/bin/cc</userinput></screen>
173
174 </sect2>
175
176 <sect2 role="content">
177 <title/>
178
179 <para>Details on this package are located in
180 <xref linkend="contents-gcc" role="."/></para>
181
182 </sect2>
183
184</sect1>
Note: See TracBrowser for help on using the repository browser.