source: chapter05/libstdc++.xml@ c24dafb

multilib
Last change on this file since c24dafb was c24dafb, checked in by Thomas Trepl (Moody) <thomas@…>, 2 years ago

Adjust parameter documentation

  • Property mode set to 100644
File size: 5.5 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"
64 arch="ml_32">mlist=m64,m32</userinput><userinput remap="configure"
65 arch="ml_x32">mlist=m64,mx32</userinput><userinput remap="configure"
66 arch="ml_all">mlist=m64,m32,mx32</userinput>
67<userinput remap="configure">../libstdc++-v3/configure \
68 --host=$LFS_TGT \
69 --build=$(../config.guess) \
70 --prefix=/usr \
71 --enable-multilib \
72 --with-multilib-list=$mlist \
73 --disable-nls \
74 --disable-libstdcxx-pch \
75 --with-gxx-include-dir=/tools/$LFS_TGT/include/c++/&gcc-version;</userinput></screen>
76<screen arch="default"><userinput remap="configure">../libstdc++-v3/configure \
77 --host=$LFS_TGT \
78 --build=$(../config.guess) \
79 --prefix=/usr \
80 --disable-multilib \
81 --disable-nls \
82 --disable-libstdcxx-pch \
83 --with-gxx-include-dir=/tools/$LFS_TGT/include/c++/&gcc-version;</userinput></screen>
84
85 <variablelist>
86 <title>The meaning of the configure options:</title>
87
88 <varlistentry>
89 <term><parameter>--host=...</parameter></term>
90 <listitem>
91 <para>Specifies that the cross compiler we have just built
92 should be used instead of the one in
93 <filename>/usr/bin</filename>.</para>
94 </listitem>
95 </varlistentry>
96
97 <varlistentry arch="ml_32,ml_x32,ml_all">
98 <term><parameter>--enable-multilib</parameter>, <parameter>--with-multilib-list=...</parameter></term>
99 <listitem>
100 <para>Enable building multilib objects for the selected archs.</para>
101 </listitem>
102 </varlistentry>
103
104 <varlistentry>
105 <term><parameter>--disable-libstdcxx-pch</parameter></term>
106 <listitem>
107 <para>This switch prevents the installation of precompiled
108 include files, which are not needed at this stage.</para>
109 </listitem>
110 </varlistentry>
111
112 <varlistentry>
113 <term><parameter>--with-gxx-include-dir=/tools/$LFS_TGT/include/c++/&gcc-version;</parameter></term>
114 <listitem>
115 <para>This specifies the installation directory for include files.
116 Because libstdc++ is the standard C++ library for LFS, this
117 directory should match the location where the C++ compiler
118 (<command>$LFS_TGT-g++</command>) would search for the
119 standard C++ include files. In a normal build, this information
120 is automatically passed to the libstdc++ <command>configure</command>
121 options from the top level directory. In our case, this information
122 must be explicitly given.
123 The C++ compiler will prepend the sysroot path
124 <filename class="directory">$LFS</filename> (specified building
125 GCC pass 1) to the include file search path, so it will actually
126 search in
127 <filename class="directory">$LFS/tools/$LFS_TGT/include/c++/&gcc-version;</filename>.
128 The combination of the <parameter>DESTDIR</parameter>
129 variable (in the <command>make install</command> command below)
130 and this switch ensures to install the headers there.</para>
131 </listitem>
132 </varlistentry>
133
134 </variablelist>
135
136 <para>Compile libstdc++ by running:</para>
137
138<screen><userinput remap="make">make</userinput></screen>
139
140 <para>Install the library:</para>
141
142<screen><userinput remap="install">make DESTDIR=$LFS install</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.