source: chapter06/gcc.xml@ 6a0e6f3

Last change on this file since 6a0e6f3 was 6a0e6f3, checked in by Matthew Burgess <matthew@…>, 19 years ago
  • Remove the spurious <info> tags that I thought were necessary but evidently aren't

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

  • Property mode set to 100644
File size: 7.3 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE section [
3 <!ENTITY % general-entities SYSTEM "../general.ent">
4 %general-entities;
5]>
6<section xmlns="http://docbook.org/docbook-ng"
7 xmlns:xlink="http://www.w3.org/1999/xlink"
8 xml:id="ch-system-gcc" xreflabel="GCC" role="wrap">
9<title>GCC-&gcc-version;</title>
10<?dbhtml filename="gcc.html"?>
11
12<indexterm zone="ch-system-gcc"><primary sortas="a-GCC">GCC</primary></indexterm>
13
14<section role="package"><title/>
15<para>The GCC package contains the GNU compiler collection, which includes
16the C and C++ compilers.</para>
17
18<segmentedlist>
19<segtitle>&buildtime;</segtitle>
20<segtitle>&diskspace;</segtitle>
21<seglistitem><seg>11.7 SBU</seg><seg>294 MB</seg></seglistitem>
22</segmentedlist>
23
24<segmentedlist>
25<segtitle>GCC installation depends on</segtitle>
26<seglistitem><seg>Bash, Binutils, Coreutils, Diffutils, Findutils,
27Gawk, Gettext, Glibc, Grep, Make, Perl, Sed, Texinfo</seg></seglistitem>
28</segmentedlist>
29</section>
30
31<section role="installation">
32<title>Installation of GCC</title>
33
34<para>This package is known to behave badly when you have changed its
35default optimization flags (including the <parameter>-march</parameter> and <parameter>-mcpu</parameter> options).
36Therefore, if you have defined any environment variables that override
37default optimizations, such as CFLAGS and CXXFLAGS, we recommend un-setting
38or modifying them when building GCC.</para>
39
40<para>Unpack the GCC-core <emphasis>and</emphasis> the GCC-g++ tarball -- they
41will unfold into the same directory. You should likewise extract the
42GCC-testsuite package. The full GCC package contains even more
43compilers. Instructions for building these can be found at
44<uri xlink:href="&blfs-root;view/stable/general/gcc.html"/>.</para>
45
46<para>First apply only the No-Fixincludes patch (and <emphasis>not</emphasis>
47the Specs patch) also used in the previous chapter:</para>
48
49<screen><userinput>patch -Np1 -i ../gcc-&gcc-version;-no_fixincludes-1.patch</userinput></screen>
50
51<para>GCC fails to compile some packages outside of a base Linux From Scratch
52install (e.g., Mozilla and kdegraphics) when used in conjunction with newer
53versions of binutils. Apply the following patch to fix this issue:</para>
54
55<screen><userinput>patch -Np1 -i ../gcc-&gcc-version;-linkonce-1.patch</userinput></screen>
56
57<para>Now apply a sed substitution that will suppress the installation of
58<filename class="libraryfile">libiberty.a</filename>. We want to use the version of
59<filename class="libraryfile">libiberty.a</filename> provided by Binutils:</para>
60
61<screen><userinput>sed -i 's/install_to_$(INSTALL_DEST) //' libiberty/Makefile.in</userinput></screen>
62
63<para>The GCC documentation recommends building GCC outside of the source
64directory in a dedicated build directory:</para>
65
66<screen><userinput>mkdir ../gcc-build
67cd ../gcc-build</userinput></screen>
68
69<para>Now prepare GCC for compilation:</para>
70
71<screen><userinput>../gcc-&gcc-version;/configure --prefix=/usr \
72 --libexecdir=/usr/lib --enable-shared --enable-threads=posix \
73 --enable-__cxa_atexit --enable-clocale=gnu --enable-languages=c,c++</userinput></screen>
74
75<para>Compile the package:</para>
76
77<screen><userinput>make</userinput></screen>
78
79<important><para>The test suite for GCC in this section is considered
80<emphasis>critical</emphasis>. Our advice is to not skip it under any
81circumstance.</para></important>
82
83<para>Test the results, but don't stop at errors (you'll remember the few
84known ones):</para>
85
86<screen><userinput>make -k check</userinput></screen>
87
88<para>The test suite notes from <xref linkend="ch-tools-gcc-pass2"/> are still very
89much appropriate here. Be sure to refer back there should you have any
90doubts.</para>
91
92<para>Now install the package:</para>
93
94<screen><userinput>make install</userinput></screen>
95
96<para>Some packages expect the C PreProcessor to be installed in the
97<filename class="directory">/lib</filename> directory.
98To support those packages, create this symlink:</para>
99
100<screen><userinput>ln -s ../usr/bin/cpp /lib</userinput></screen>
101
102<para>Many packages use the name <command>cc</command> to call the C
103compiler. To satisfy those packages, create a symlink:</para>
104
105<screen><userinput>ln -s gcc /usr/bin/cc</userinput></screen>
106
107<note><para>At this point it is strongly recommended to repeat the sanity check
108we performed earlier in this chapter. Refer back to
109<xref linkend="ch-system-readjusting"/> and repeat the check. If the results
110are wrong, then most likely you erroneously applied the GCC Specs patch from
111<xref linkend="chapter-temporary-tools"/>.</para></note>
112
113</section>
114
115
116<section xml:id="contents-gcc" role="content"><title>Contents of GCC</title>
117
118<segmentedlist>
119<segtitle>Installed programs</segtitle>
120<segtitle>Installed libraries</segtitle>
121<seglistitem><seg>c++, cc (link to gcc),
122cc1, cc1plus, collect2, cpp, g++, gcc, gccbug, and gcov</seg>
123<seg>libgcc.a, libgcc_eh.a, libgcc_s.so, libstdc++.[a,so] and libsupc++.a</seg></seglistitem>
124</segmentedlist>
125
126<variablelist><title>Short descriptions</title>
127
128<varlistentry xml:id="cpp">
129<term><command>cpp</command></term>
130<listitem>
131<indexterm zone="ch-system-gcc cpp"><primary sortas="b-cpp">cpp</primary></indexterm>
132<para>is the C preprocessor. It is used by the compiler to have the #include and
133#define and such statements expanded in the source files.</para>
134</listitem>
135</varlistentry>
136
137<varlistentry xml:id="g">
138<term><command>g++</command></term>
139<listitem>
140<indexterm zone="ch-system-gcc g"><primary sortas="b-g++">g++</primary></indexterm>
141<para>is the C++ compiler.</para>
142</listitem>
143</varlistentry>
144
145<varlistentry xml:id="gcc">
146<term><command>gcc</command></term>
147<listitem>
148<indexterm zone="ch-system-gcc gcc"><primary sortas="b-gcc">gcc</primary></indexterm>
149<para>is the C compiler. It is used to translate
150the source code of a program into assembly code.</para>
151</listitem>
152</varlistentry>
153
154<varlistentry xml:id="gccbug">
155<term><command>gccbug</command></term>
156<listitem>
157<indexterm zone="ch-system-gcc gccbug"><primary sortas="b-gccbug">gccbug</primary></indexterm>
158<para>is a shell script used to help create good bug reports.</para>
159</listitem>
160</varlistentry>
161
162<varlistentry xml:id="gcov">
163<term><command>gcov</command></term>
164<listitem>
165<indexterm zone="ch-system-gcc gcov"><primary sortas="b-gcov">gcov</primary></indexterm>
166<para>is a coverage testing tool. It is used to
167analyze programs to find out where optimizations will have the most effect.</para>
168</listitem>
169</varlistentry>
170
171<varlistentry xml:id="libgcc">
172<term><filename class="libraryfile">libgcc*</filename></term>
173<listitem>
174<indexterm zone="ch-system-gcc libgcc"><primary sortas="c-libgcc*">libgcc*</primary></indexterm>
175<para>contains run-time support for <command>gcc</command>.</para>
176</listitem>
177</varlistentry>
178
179<varlistentry xml:id="libstdc">
180<term><filename class="libraryfile">libstdc++</filename></term>
181<listitem>
182<indexterm zone="ch-system-gcc libstdc"><primary sortas="c-libstdc++">libstdc++</primary></indexterm>
183<para>is the standard C++ library. It contains many frequently-used functions.</para>
184</listitem>
185</varlistentry>
186
187<varlistentry xml:id="libsupc">
188<term><filename class="libraryfile">libsupc++</filename></term>
189<listitem>
190<indexterm zone="ch-system-gcc libsupc"><primary sortas="c-libsupc++">libsupc++</primary></indexterm>
191<para>provides supporting routines for the c++ programming language.</para>
192</listitem>
193</varlistentry>
194</variablelist>
195
196</section>
197
198</section>
Note: See TracBrowser for help on using the repository browser.