source: chapter05/gcc-pass1.xml@ 6e88633

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.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 6e88633 was 6e88633, checked in by Jeremy Huntwork <jhuntwork@…>, 15 years ago

Initial addition of support for x86_64

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

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