source: chapter05/gcc-pass1.xml@ c49647b1

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 c49647b1 was c49647b1, checked in by Randy McMurchy <randy@…>, 16 years ago

Modified the Chapter 5 instructions so that instead of building the GMP and MPFR packages separately for GCC Pass2, they are built by GCC internally

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

  • Property mode set to 100644
File size: 5.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/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 \
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>--enable-languages=c</parameter></term>
103 <listitem>
104 <para>This option ensures that only the C compiler is built.</para>
105 </listitem>
106 </varlistentry>
107
108 </variablelist>
109
110 <para>The following command will compile GCC not once, but several times. It
111 uses the programs compiled in a first round to compile itself a second time,
112 and then again a third time. It then compares these second and third compiles
113 to make sure it can reproduce itself flawlessly. This is called
114 <quote>bootstrapping</quote>. Building GCC in this way ensures that it was
115 compiled correctly and is now the default configuration for the released
116 package. Continue with compiling by running:</para>
117
118<screen><userinput remap="make">make</userinput></screen>
119
120 <para>Compilation is now complete. At this point, the test suite would
121 normally be run, but, as mentioned before, the test suite framework is
122 not in place yet. The benefits of running the tests at this point
123 are minimal since the programs from this first pass will soon be
124 replaced.</para>
125
126 <para>Install the package:</para>
127
128<screen><userinput remap="install">make install</userinput></screen>
129
130 <para>Using <parameter>--disable-shared</parameter> means that the
131 <filename>libgcc_eh.a</filename> file isn't created and installed. The
132 Glibc package depends on this library as it uses
133 <parameter>-lgcc_eh</parameter> within its build system. We can satisfy
134 that dependency by creating a symlink to <filename>libgcc.a</filename>,
135 since that file will end up containing the objects normally contained in
136 <filename>libgcc_eh.a</filename>.</para>
137
138<screen><userinput remap="install">ln -vs libgcc.a `gcc -print-libgcc-file-name | \
139 sed 's/libgcc/&amp;_eh/'`</userinput></screen>
140
141 <para>As a finishing touch, create a symlink. Many programs and scripts
142 run <command>cc</command> instead of <command>gcc</command>, which is
143 used to keep programs generic and therefore usable on all kinds of UNIX
144 systems where the GNU C compiler is not always installed. Running
145 <command>cc</command> leaves the system administrator free to decide
146 which C compiler to install:</para>
147
148<screen><userinput remap="install">ln -vs gcc /tools/bin/cc</userinput></screen>
149
150 </sect2>
151
152 <sect2 role="content">
153 <title/>
154
155 <para>Details on this package are located in
156 <xref linkend="contents-gcc" role="."/></para>
157
158 </sect2>
159
160</sect1>
Note: See TracBrowser for help on using the repository browser.