| 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
 | 
|---|
| 58 | cd ../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>
 | 
|---|