source: clfs-embedded/BOOK/cross-tools/common/gcc-static.xml@ 003388c

Last change on this file since 003388c was 841271e, checked in by Jim Gifford <clfs@…>, 18 years ago

uClibc updates

  • Property mode set to 100644
File size: 3.8 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.4//EN"
3 "http://www.oasis-open.org/docbook/xml/4.4/docbookx.dtd" [
4 <!ENTITY % general-entities SYSTEM "../../general.ent">
5 %general-entities;
6]>
7
8<sect1 id="ch-cross-tools-gcc-static" role="wrap">
9 <?dbhtml filename="gcc-static.html"?>
10
11 <title>Cross GCC-&gcc-version; - Static</title>
12
13 <indexterm zone="ch-cross-tools-gcc-static">
14 <primary sortas="a-GCC">GCC</primary>
15 <secondary>cross tools, static</secondary>
16 </indexterm>
17
18 <sect2 role="package">
19 <title/>
20
21 <para>The GCC package contains the GNU compiler collection, which includes
22 the C and C++ compilers.</para>
23
24 </sect2>
25
26 <sect2 role="installation">
27 <title>Installation of Cross GCC Compiler with Static libgcc
28 and no Threads</title>
29
30 <para os="p1">To make sure that a couple of tools use the proper syntax,
31 apply the following patch:</para>
32
33<screen os="p2"><userinput>patch -Np1 -i ../&gcc-posix-patch;</userinput></screen>
34
35 <para os="p3">Now since we using uClibc, we need to patch GCC to recognize
36 this fact:</para>
37
38<screen os="p4"><userinput>patch -Np1 -i ../&gcc-uclibc-patch;</userinput></screen>
39
40 <para os="p5">The following patch fixes the searching of multilib dirs for
41 specs file.The patch standardizes the gcc drivers path iteration functions,
42 ensuring multilib directories are searched in the correct order. This fixes
43 various issues, most noticably with libtool on multilib systems:</para>
44
45<screen os="p6"><userinput>patch -Np1 -i ../&gcc-PR20425-patch;</userinput></screen>
46
47 <para os="p7">The following patch ensures that <command>gcc</command> does not
48 search the <filename class="directory">/usr</filename> directory for
49 <filename class="libraryfile">libgcc_s.so</filename> when
50 cross-compiling:</para>
51
52<screen os="p8"><userinput>patch -Np1 -i ../&gcc-cross_search-patch;</userinput></screen>
53
54 <para os="c">The GCC documentation recommends building GCC outside of the source
55 directory in a dedicated build directory:</para>
56
57<screen os="d"><userinput>mkdir -v ../gcc-build
58cd ../gcc-build</userinput></screen>
59
60 <para os="e">Prepare GCC for compilation:</para>
61
62<screen os="ae"><userinput>../gcc-&gcc-version;/configure --prefix=${CLFS}/cross-tools \
63 --host=${CLFS_HOST} --target=${CLFS_TARGET} --disable-multilib \
64 --with-sysroot=${CLFS} --disable-nls --disable-shared \
65 --enable-languages=c</userinput></screen>
66
67 <variablelist os="af">
68 <title>The meaning of the configure options:</title>
69
70 <varlistentry>
71 <term><parameter>--disable-shared</parameter></term>
72 <listitem>
73 <para>Disables the creation of the shared libraries.</para>
74 </listitem>
75 </varlistentry>
76
77 <varlistentry>
78 <term><parameter>--disable-threads</parameter></term>
79 <listitem>
80 <para>This will prevent GCC from looking for the multi-thread
81 include files, since they haven't been created for this architecture
82 yet. GCC will be able to find the multi-thread information after
83 the Glibc headers are created.</para>
84 </listitem>
85 </varlistentry>
86
87 <varlistentry>
88 <term><parameter>--enable-languages=c</parameter></term>
89 <listitem>
90 <para>This option ensures that only the C compiler is built.</para>
91 </listitem>
92 </varlistentry>
93
94 </variablelist>
95
96 <para os="ag">Continue with compiling the package:</para>
97
98<screen os="ah"><userinput>make all-gcc</userinput></screen>
99
100 <para os="ai">Install the package:</para>
101
102<screen os="aj"><userinput>make install-gcc</userinput></screen>
103
104 </sect2>
105
106 <sect2 role="content">
107 <title/>
108
109 <para>Details on this package are located in <xref
110 linkend="contents-gcc" role="."/></para>
111
112 </sect2>
113
114</sect1>
Note: See TracBrowser for help on using the repository browser.