source: chapter06/gcc-pass2.xml@ 8ac7bce6

arm
Last change on this file since 8ac7bce6 was 8ac7bce6, checked in by William Harrington <kb0iic@…>, 2 years ago

gcc-pass2: document *_FOR_TARGET parameters

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