source: chapter05/gcc-pass1.xml@ 182d5d3

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 6.4 6.5 6.6 6.7 6.8 7.0 7.1 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 182d5d3 was 182d5d3, checked in by Bruce Dubbs <bdubbs@…>, 16 years ago

Text changes in several places in Chapters 5 and 6.

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

  • Property mode set to 100644
File size: 6.1 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/2003/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 GCC</title>
45
46 <para>GCC now requires the GMP and MPFR packages. As these packages may
47 not be included in your host distribution, they will be built with
48 GCC.</para>
49
50<screen><userinput remap="pre">tar -jxf ../mpfr-&mpfr-version;.tar.bz2
51mv mpfr-&mpfr-version; mpfr
52tar -jxf ../gmp-&gmp-version;.tar.bz2
53mv gmp-&gmp-version; gmp</userinput></screen>
54
55 <para>The GCC documentation recommends building GCC outside of the
56 source directory in a dedicated build directory:</para>
57
58<screen><userinput remap="pre">mkdir -v ../gcc-build
59cd ../gcc-build</userinput></screen>
60
61 <para>Prepare GCC for compilation:</para>
62
63<screen><userinput remap="configure">CC="gcc -B/usr/bin/" ../gcc-&gcc-version;/configure --prefix=/tools \
64 --with-local-prefix=/tools --disable-nls --disable-shared --disable-libssp \
65 --enable-languages=c</userinput></screen>
66
67 <variablelist>
68 <title>The meaning of the configure options:</title>
69
70 <varlistentry>
71 <term><envar>CC="gcc -B/usr/bin/"</envar></term>
72 <listitem>
73 <para>This forces <command>gcc</command> to prefer the linker from
74 the host in <filename class="directory">/usr/bin</filename>. This
75 is necessary on some hosts where the new <command>ld</command>
76 built in the previous section is not compatible with the host's
77 <command>gcc</command>.</para>
78 </listitem>
79 </varlistentry>
80
81 <varlistentry>
82 <term><parameter>--with-local-prefix=/tools</parameter></term>
83 <listitem>
84 <para>The purpose of this switch is to remove <filename
85 class="directory">/usr/local/include</filename> from
86 <command>gcc</command>'s include search path. This is not
87 absolutely essential, however, it helps to minimize the
88 influence of the host system.</para>
89 </listitem>
90 </varlistentry>
91
92 <varlistentry>
93 <term><parameter>--disable-shared</parameter></term>
94 <listitem>
95 <para>This switch forces GCC to link its internal libraries
96 statically. We do this to avoid possible issues with the host
97 system.</para>
98 </listitem>
99 </varlistentry>
100
101 <varlistentry>
102 <term><parameter>--disable-libssp</parameter></term>
103 <listitem>
104 <para>This switch prevents a conflict with older versions of
105 glibc which can cause the build to fail.</para>
106 </listitem>
107 </varlistentry>
108
109 <varlistentry>
110 <term><parameter>--enable-languages=c</parameter></term>
111 <listitem>
112 <para>This option ensures that only the C compiler is built.
113 This is the only language needed now.</para>
114 </listitem>
115 </varlistentry>
116
117 </variablelist>
118
119 <para>The following command will compile GCC not once, but several times. It
120 uses the programs compiled in a first round to compile itself a second time,
121 and then again a third time. It then compares these second and third compiles
122 to make sure it can reproduce itself flawlessly. This is called
123 <quote>bootstrapping</quote>. Building GCC in this way ensures that it was
124 compiled correctly and is now the default configuration for the released
125 package. Continue with compiling by running:</para>
126
127<screen><userinput remap="make">make</userinput></screen>
128
129 <para>Compilation is now complete. At this point, the test suite would
130 normally be run, but, as mentioned before, the test suite framework is
131 not in place yet. The benefits of running the tests at this point
132 are minimal since the programs from this first pass will soon be
133 replaced.</para>
134
135 <para>Install the package:</para>
136
137<screen><userinput remap="install">make install</userinput></screen>
138
139 <para>Using <parameter>--disable-shared</parameter> means that the
140 <filename>libgcc_eh.a</filename> file isn't created and installed. The
141 Glibc package depends on this library as it uses
142 <parameter>-lgcc_eh</parameter> within its build system. We can satisfy
143 that dependency by creating a symlink to <filename>libgcc.a</filename>,
144 since that file will end up containing the objects normally contained in
145 <filename>libgcc_eh.a</filename>.</para>
146
147<screen><userinput remap="install">ln -vs libgcc.a `gcc -print-libgcc-file-name | \
148 sed 's/libgcc/&amp;_eh/'`</userinput></screen>
149
150 <para>As a finishing touch, create a symlink. Many programs and scripts
151 run <command>cc</command> instead of <command>gcc</command>, which is
152 used to keep programs generic and therefore usable on all kinds of UNIX
153 systems where the GNU C compiler is not always installed. Running
154 <command>cc</command> leaves the system administrator free to decide
155 which C compiler to install:</para>
156
157<screen><userinput remap="install">ln -vs gcc /tools/bin/cc</userinput></screen>
158
159 </sect2>
160
161 <sect2 role="content">
162 <title/>
163
164 <para>Details on this package are located in
165 <xref linkend="contents-gcc" role="."/></para>
166
167 </sect2>
168
169</sect1>
Note: See TracBrowser for help on using the repository browser.