source: chapter06/gcc-pass2.xml@ 3bb463d

11.2 11.2-rc1 11.3 11.3-rc1 12.0 12.0-rc1 12.1 12.1-rc1 bdubbs/gcc13 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 3bb463d was 3bb463d, checked in by Xi Ruoyao <xry111@…>, 2 years ago

gcc-pass2: document *_FOR_TARGET parameters

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