source: chapter05/libstdc++.xml@ c84195d

multilib
Last change on this file since c84195d was c84195d, checked in by Thomas Trepl (Moody) <thomas@…>, 20 months ago

Automatic merge of trunk into multilib

  • Property mode set to 100644
File size: 5.4 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-libstdcpp" role="wrap">
9 <?dbhtml filename="gcc-libstdc++.html"?>
10
11 <sect1info condition="script">
12 <productname>gcc-libstdc++</productname>
13 <productnumber>&gcc-version;</productnumber>
14 <address>&gcc-url;</address>
15 </sect1info>
16
17 <title>Libstdc++ from GCC-&gcc-version;</title>
18
19 <indexterm zone="ch-tools-libstdcpp">
20 <primary sortas="a-GCC">GCC</primary>
21 <secondary>tools, libstdc++ pass 1</secondary>
22 </indexterm>
23
24 <sect2 role="package">
25 <title/>
26
27 <para>Libstdc++ is the standard C++ library. It is needed
28 to compile C++ code
29 (part of GCC is written in C++), but we had to defer its installation
30 when we built <xref linkend="ch-tools-gcc-pass1"/>
31 because it depends on glibc, which was not yet available in the target
32 directory.
33 </para>
34
35 <segmentedlist>
36 <segtitle>&buildtime;</segtitle>
37 <segtitle>&diskspace;</segtitle>
38
39 <seglistitem>
40 <seg>&libstdcpp-tmpp1-sbu;</seg>
41 <seg>&libstdcpp-tmpp1-du;</seg>
42 </seglistitem>
43 </segmentedlist>
44
45 </sect2>
46
47 <sect2 role="installation">
48 <title>Installation of Target Libstdc++</title>
49
50 <note>
51 <para><application>Libstdc++</application> is part of the GCC sources.
52 You should first unpack the GCC tarball and change to the
53 <filename>gcc-&gcc-version;</filename> directory.</para>
54 </note>
55
56 <para>Create a separate build directory for libstdc++ and enter it:</para>
57
58<screen><userinput remap="pre">mkdir -v build
59cd build</userinput></screen>
60
61 <para>Prepare libstdc++ for compilation:</para>
62
63<screen arch="ml_32,ml_x32,ml_all"><userinput remap="configure">../libstdc++-v3/configure \
64 --host=$LFS_TGT \
65 --build=$(../config.guess) \
66 --prefix=/usr \
67 --enable-multilib \
68 --disable-nls \
69 --disable-libstdcxx-pch \
70 --with-gxx-include-dir=/tools/$LFS_TGT/include/c++/&gcc-version;</userinput></screen>
71<screen arch="default"><userinput remap="configure">../libstdc++-v3/configure \
72 --host=$LFS_TGT \
73 --build=$(../config.guess) \
74 --prefix=/usr \
75 --disable-multilib \
76 --disable-nls \
77 --disable-libstdcxx-pch \
78 --with-gxx-include-dir=/tools/$LFS_TGT/include/c++/&gcc-version;</userinput></screen>
79
80 <variablelist>
81 <title>The meaning of the configure options:</title>
82
83 <varlistentry>
84 <term><parameter>--host=...</parameter></term>
85 <listitem>
86 <para>Specifies that the cross compiler we have just built
87 should be used instead of the one in
88 <filename>/usr/bin</filename>.</para>
89 </listitem>
90 </varlistentry>
91
92 <varlistentry arch="ml_32,ml_x32,ml_all">
93 <term><parameter>--enable-multilib</parameter></term>
94 <listitem>
95 <para>Enable building multilib objects.</para>
96 </listitem>
97 </varlistentry>
98
99 <varlistentry>
100 <term><parameter>--disable-libstdcxx-pch</parameter></term>
101 <listitem>
102 <para>This switch prevents the installation of precompiled
103 include files, which are not needed at this stage.</para>
104 </listitem>
105 </varlistentry>
106
107 <varlistentry>
108 <term><parameter>--with-gxx-include-dir=/tools/$LFS_TGT/include/c++/&gcc-version;</parameter></term>
109 <listitem>
110 <para>This specifies the installation directory for include files.
111 Because libstdc++ is the standard C++ library for LFS, this
112 directory should match the location where the C++ compiler
113 (<command>$LFS_TGT-g++</command>) would search for the
114 standard C++ include files. In a normal build, this information
115 is automatically passed to the libstdc++ <command>configure</command>
116 options from the top level directory. In our case, this information
117 must be explicitly given.
118 The C++ compiler will prepend the sysroot path
119 <filename class="directory">$LFS</filename> (specified building
120 GCC pass 1) to the include file search path, so it will actually
121 search in
122 <filename class="directory">$LFS/tools/$LFS_TGT/include/c++/&gcc-version;</filename>.
123 The combination of the <parameter>DESTDIR</parameter>
124 variable (in the <command>make install</command> command below)
125 and this switch ensures to install the headers there.</para>
126 </listitem>
127 </varlistentry>
128
129 </variablelist>
130
131 <para>Compile libstdc++ by running:</para>
132
133<screen><userinput remap="make">make</userinput></screen>
134
135 <para>Install the library:</para>
136
137<screen><userinput remap="install">make DESTDIR=$LFS install</userinput></screen>
138
139 <para>Remove the libtool archive files because they are harmful for
140 cross compilation:</para>
141
142<screen><userinput remap="install">rm -v $LFS/usr/lib/lib{stdc++,stdc++fs,supc++}.la</userinput></screen>
143
144 </sect2>
145
146 <sect2 role="content">
147 <title/>
148
149 <para>Details on this package are located in
150 <xref linkend="contents-gcc" role="."/></para>
151
152 </sect2>
153
154</sect1>
Note: See TracBrowser for help on using the repository browser.