* Merged newxml into HEAD
[linux_from_scratch.git] / BOOK / chapter06 / glibc.xml
blob59ecff6f9d80ce7debb8dcedb9f0cff57e5b5718
1 <?xml version="1.0" encoding="ISO-8859-1"?>
2 <!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.3//EN" "http://www.oasis-open.org/docbook/xml/4.3/docbookx.dtd" [
3   <!ENTITY % general-entities SYSTEM "../general.ent">
4   %general-entities;
5 ]>
6 <sect1 id="ch-system-glibc" xreflabel="Glibc">
7 <title>Glibc-&glibc-version;</title>
8 <?dbhtml filename="glibc.html"?>
10 <indexterm zone="ch-system-glibc"><primary sortas="a-Glibc">Glibc</primary></indexterm>
12 <para>The Glibc package contains the main C library. This library provides all
13 the basic routines for allocating memory, searching directories, opening and
14 closing files, reading and writing them, string handling, pattern matching,
15 arithmetic, and so on.</para>
17 <screen>&buildtime; 12.3 SBU
18 &diskspace; 784 MB</screen>
20 <para>Glibc installation depends on: Bash, Binutils, Coreutils, Diffutils,
21 Gawk, GCC, Gettext, Grep, Make, Perl, Sed, Texinfo.</para>
25 <sect2>
26 <title>Installation of Glibc</title>
28 <para>The Glibc build system is very well self-contained and will install
29 perfectly, even though our compiler specs file and linker are still pointing
30 at <filename>/tools</filename>. We cannot adjust the specs and linker before
31 the Glibc install, because the Glibc autoconf tests would then give bogus
32 results and thus defeat our goal of achieving a clean build.</para>
34 <para>Before starting to build Glibc, remember to unset any environment
35 variables that override the default optimization flags.</para>
37 <para>The Glibc documentation recommends building Glibc outside of the source
38 directory in a dedicated build directory:</para>
40 <screen><userinput>mkdir ../glibc-build
41 cd ../glibc-build</userinput></screen>
43 <para>Now prepare Glibc for compilation:</para>
45 <screen><userinput>../glibc-&glibc-version;-20031202/configure --prefix=/usr \
46     --disable-profile --enable-add-ons=linuxthreads \
47     --libexecdir=/usr/lib --with-headers=/usr/include \
48     --without-cvs</userinput></screen>
50 <para>The meaning of the new configure options:</para>
52 <itemizedlist>
53 <listitem><para><userinput>--libexecdir=/usr/lib</userinput>: This changes the
54 location of the <filename>pt_chown</filename> program from its default of 
55 <filename class="directory">/usr/libexec</filename> to
56 <filename class="directory">/usr/lib</filename>. The use of
57 <emphasis>libexec</emphasis> is considered not to be FHS-compliant because the
58 FHS doesn't even mention it.</para></listitem>
60 <listitem><para><userinput>--with-headers=/usr/include</userinput>: This
61 ensures that the kernel headers in <filename>/usr/include</filename> are used
62 for this build. If you don't pass this switch then the headers from
63 <filename>/tools/include</filename> are used which of course is not ideal
64 (although they should be identical). Using this switch has the advantage
65 that you will be informed immediately should you have forgotten to install the
66 kernel headers into <filename>/usr/include</filename>.</para></listitem>
67 </itemizedlist>
69 <para>Compile the package:</para>
71 <screen><userinput>make</userinput></screen>
73 <important><para>The test suite for Glibc in this section is considered
74 <emphasis>critical</emphasis>. Our advice is to not skip it under any
75 circumstance.</para></important>
77 <para>Test the results:</para>
79 <screen><userinput>make check</userinput></screen>
81 <para>The test suite notes from <xref linkend="ch-tools-glibc"/> are still very much
82 appropriate here. Be sure to refer back there should you have any doubts.</para>
84 <para>Though it is a harmless message, the install stage of Glibc will
85 complain about the absence of <filename>/etc/ld.so.conf</filename>. Fix this
86 annoying little warning with:</para>
88 <screen><userinput>touch /etc/ld.so.conf</userinput></screen>
90 <para>And install the package:</para>
92 <screen><userinput>make install</userinput></screen>
94 <para>The locales that can make your system respond in a different language
95 weren't installed by the above command. Do it with this:</para>
97 <screen><userinput>make localedata/install-locales</userinput></screen>
99 <para>An alternative to running the previous command is to install only those
100 locales which you need or want. This can be achieved by using the
101 <command>localedef</command> command. Information on this can be found in
102 the <filename>INSTALL</filename> file in the Glibc source. However, there are
103 a number of locales that are essential for the tests of future packages to
104 pass, in particular, the <emphasis>libstdc++</emphasis> tests from GCC. The
105 following instructions, instead of the install-locales target above, will
106 install the minimum set of locales necessary for the tests to run
107 successfully:</para>
109 <screen><userinput>mkdir -p /usr/lib/locale
110 localedef -i de_DE -f ISO-8859-1 de_DE
111 localedef -i de_DE@euro -f ISO-8859-15 de_DE@euro
112 localedef -i en_HK -f ISO-8859-1 en_HK
113 localedef -i en_PH -f ISO-8859-1 en_PH
114 localedef -i en_US -f ISO-8859-1 en_US
115 localedef -i es_MX -f ISO-8859-1 es_MX
116 localedef -i fa_IR -f UTF-8 fa_IR
117 localedef -i fr_FR -f ISO-8859-1 fr_FR
118 localedef -i fr_FR@euro -f ISO-8859-15 fr_FR@euro
119 localedef -i it_IT -f ISO-8859-1 it_IT
120 localedef -i ja_JP -f EUC-JP ja_JP</userinput></screen>
122 <para>Finally, build the linuxthreads man pages:</para>
124 <screen><userinput>make -C ../glibc-&glibc-version;-20031202/linuxthreads/man</userinput></screen>
126 <para>And install these pages:</para>
128 <screen><userinput>make -C ../glibc-&glibc-version;-20031202/linuxthreads/man install</userinput></screen>
130 </sect2>
133 <sect2 id="conf-glibc"><title>Configuring Glibc</title>
134 <indexterm zone="conf-glibc"><primary sortas="e-/etc/nsswitch.conf">/etc/nsswitch.conf</primary></indexterm>
135 <indexterm zone="conf-glibc"><primary sortas="e-/etc/localtime">/etc/localtime</primary></indexterm>
137 <para>We need to create the <filename>/etc/nsswitch.conf</filename> file,
138 because, although Glibc provides defaults when this file is missing or corrupt,
139 the Glibc defaults don't work well with networking. Also, our time zone needs
140 to be set up.</para>
142 <para>Create a new file <filename>/etc/nsswitch.conf</filename> by running the
143 following:</para>
145 <screen><userinput>cat &gt; /etc/nsswitch.conf &lt;&lt; "EOF"</userinput>
146 # Begin /etc/nsswitch.conf
148 passwd: files
149 group: files
150 shadow: files
152 publickey: files
154 hosts: files dns
155 networks: files
157 protocols: db files
158 services: db files
159 ethers: db files
160 rpc: db files
162 netgroup: db files
164 # End /etc/nsswitch.conf
165 <userinput>EOF</userinput></screen>
167 <para>To find out what time zone you're in, run the following script:</para>
169 <screen><userinput>tzselect</userinput></screen>
171 <para>When you've answered a few questions about your location, the script will
172 output the name of your time zone, something like <emphasis>EST5EDT</emphasis>
173 or <emphasis>Canada/Eastern</emphasis>. Then create the
174 <filename>/etc/localtime</filename> file by running:</para>
176 <screen><userinput>cp --remove-destination /usr/share/zoneinfo/Canada/Eastern /etc/localtime</userinput></screen>
178 <para>The meaning of the option:</para>
180 <itemizedlist>
181 <listitem><para><userinput>--remove-destination</userinput>: This is needed to
182 force removal of the already existing symbolic link. The reason why we copy
183 instead of symlink is to cover the situation where <filename>/usr</filename> is
184 on a separate partition. This could matter, for example, when booted into single
185 user mode.</para></listitem>
186 </itemizedlist>
188 <para>Of course, instead of <emphasis>Canada/Eastern</emphasis>, fill in
189 the name of the time zone that the <command>tzselect</command> script
190 gave you.</para>
192 </sect2>
195 <sect2 id="conf-ld">
196 <title>Configuring Dynamic Loader</title>
197 <indexterm zone="conf-ld"><primary sortas="e-/etc/ld.so.conf">/etc/ld.so.conf</primary></indexterm>
199 <para>By default, the dynamic loader
200 (<filename>/lib/ld-linux.so.2</filename>) searches through <filename 
201 class="directory">/lib</filename> and <filename class="directory">/usr/lib</filename> 
202 for dynamic libraries that are needed
203 by programs when you run them. However, if there are libraries in
204 directories other than <filename class="directory">/lib</filename> and
205 <filename class="directory">/usr/lib</filename>, you need to add them to
206 the <filename>/etc/ld.so.conf</filename> file for the dynamic
207 loader to find them. Two directories that are commonly known to contain
208 additional libraries are <filename class="directory">/usr/local/lib</filename> 
209 and <filename class="directory">/opt/lib</filename>, so we add those directories to the
210 dynamic loader's search path.</para>
212 <para>Create a new file <filename>/etc/ld.so.conf</filename> by running the
213 following:</para>
215 <screen><userinput>cat &gt; /etc/ld.so.conf &lt;&lt; "EOF"</userinput>
216 # Begin /etc/ld.so.conf
218 /usr/local/lib
219 /opt/lib
221 # End /etc/ld.so.conf
222 <userinput>EOF</userinput></screen>
224 </sect2>
227 <sect2 id="contents-glibc"><title>Contents of Glibc</title>
229 <para><emphasis>Installed programs</emphasis>: catchsegv, gencat, getconf,
230 getent, glibcbug, iconv, iconvconfig, ldconfig, ldd, lddlibc4, locale,
231 localedef, mtrace, nscd, nscd_nischeck, pcprofiledump, pt_chown, rpcgen,
232 rpcinfo, sln, sprof, tzselect, xtrace, zdump and zic</para>
234 <para><emphasis>Installed libraries</emphasis>: ld.so, libBrokenLocale.[a,so],
235 libSegFault.so, libanl.[a,so], libbsd-compat.a, libc.[a,so], libc_nonshared.a,
236 libcrypt.[a,so], libdl.[a,so], libg.a, libieee.a, libm.[a,so], libmcheck.a,
237 libmemusage.so, libnsl.a, libnss_compat.so, libnss_dns.so, libnss_files.so,
238 libnss_hesiod.so, libnss_nis.so, libnss_nisplus.so, libpcprofile.so,
239 libpthread.[a,so], libresolv.[a,so], librpcsvc.a, librt.[a,so], libthread_db.so
240 and libutil.[a,so]</para>
242 </sect2>
245 <sect2><title>Short descriptions</title>
247 <indexterm zone="ch-system-glibc catchsegv"><primary sortas="b-catchsegv">catchsegv</primary></indexterm>
248 <para id="catchsegv"><command>catchsegv</command> can be used to create a stack trace
249 when a program terminates with a segmentation fault.</para>
251 <indexterm zone="ch-system-glibc gencat"><primary sortas="b-gencat">gencat</primary></indexterm>
252 <para id="gencat"><command>gencat</command> generates message catalogues.</para>
254 <indexterm zone="ch-system-glibc getconf"><primary sortas="b-getconf">getconf</primary></indexterm>
255 <para id="getconf"><command>getconf</command> displays the system configuration values
256 for file system specific variables.</para>
258 <indexterm zone="ch-system-glibc getent"><primary sortas="b-getent">getent</primary></indexterm>
259 <para id="getent"><command>getent</command> gets entries from an administrative
260 database.</para>
262 <indexterm zone="ch-system-glibc glibcbug"><primary sortas="b-glibcbug">glibcbug</primary></indexterm>
263 <para id="glibcbug"><command>glibcbug</command> creates a bug report and mails it to the
264 bug email address.</para>
266 <indexterm zone="ch-system-glibc iconv"><primary sortas="b-iconv">iconv</primary></indexterm>
267 <para id="iconv"><command>iconv</command> performs character set conversion.</para>
269 <indexterm zone="ch-system-glibc iconvconfig"><primary sortas="b-iconvconfig">iconvconfig</primary></indexterm>
270 <para id="iconvconfig"><command>iconvconfig</command> creates fastloading iconv module
271 configuration file.</para>
273 <indexterm zone="ch-system-glibc ldconfig"><primary sortas="b-ldconfig">ldconfig</primary></indexterm>
274 <para id="ldconfig"><command>ldconfig</command> configures the dynamic linker runtime
275 bindings.</para>
277 <indexterm zone="ch-system-glibc ldd"><primary sortas="b-ldd">ldd</primary></indexterm>
278 <para id="ldd"><command>ldd</command> reports which shared libraries are required
279 by each given program or shared library.</para>
281 <indexterm zone="ch-system-glibc lddlibc4"><primary sortas="b-lddlibc4">lddlibc4</primary></indexterm>
282 <para id="lddlibc4"><command>lddlibc4</command> assists ldd with object files.</para>
284 <indexterm zone="ch-system-glibc locale"><primary sortas="b-locale">locale</primary></indexterm>
285 <para id="locale"><command>locale</command> is a Perl program that tells the compiler
286 to enable or disable the use of POSIX locales for built-in operations.</para>
288 <indexterm zone="ch-system-glibc localedef"><primary sortas="b-localedef">localedef</primary></indexterm>
289 <para id="localedef"><command>localedef</command> compiles locale specifications.</para>
291 <indexterm zone="ch-system-glibc mtrace"><primary sortas="b-mtrace">mtrace</primary></indexterm>
292 <para id="mtrace"><command>mtrace</command>...</para>
294 <indexterm zone="ch-system-glibc nscd"><primary sortas="b-nscd">nscd</primary></indexterm>
295 <para id="nscd"><command>nscd</command> is a name service cache daemon providing a
296 cache for the most common name service requests.</para>
298 <indexterm zone="ch-system-glibc nscd_nischeck"><primary sortas="b-nscd_nischeck">nscd_nischeck</primary></indexterm>
299 <para id="nscd_nischeck"><command>nscd_nischeck</command> checks whether or not secure mode
300 is necessary for NIS+ lookup.</para>
302 <indexterm zone="ch-system-glibc pcprofiledump"><primary sortas="b-pcprofiledump">pcprofiledump</primary></indexterm>
303 <para id="pcprofiledump"><command>pcprofiledump</command> dumps information generated by
304 PC profiling.</para>
306 <indexterm zone="ch-system-glibc pt_chown"><primary sortas="b-pt_chown">pt_chown</primary></indexterm>
307 <para id="pt_chown"><command>pt_chown</command> is a helper program for grantpt to set
308 the owner, group and access permissions of a slave pseudo terminal.</para>
310 <indexterm zone="ch-system-glibc rpcgen"><primary sortas="b-rpcgen">rpcgen</primary></indexterm>
311 <para id="rpcgen"><command>rpcgen</command> generates C code to implement the
312 RPC protocol.</para>
314 <indexterm zone="ch-system-glibc rpcinfo"><primary sortas="b-rpcinfo">rpcinfo</primary></indexterm>
315 <para id="rpcinfo"><command>rpcinfo</command> makes an RPC call to an RPC server.</para>
317 <indexterm zone="ch-system-glibc sln"><primary sortas="b-sln">sln</primary></indexterm>
318 <para id="sln"><command>sln</command> is used to make symbolic links. The program
319 is statically linked, so it is useful for making symbolic links to dynamic
320 libraries if the dynamic linking system for some reason is nonfunctional.</para>
322 <indexterm zone="ch-system-glibc sprof"><primary sortas="b-sprof">sprof</primary></indexterm>
323 <para id="sprof"><command>sprof</command> reads and displays shared object profiling
324 data.</para>
326 <indexterm zone="ch-system-glibc tzselect"><primary sortas="b-tzselect">tzselect</primary></indexterm>
327 <para id="tzselect"><command>tzselect</command> asks the user about the location of the
328 system and reports the corresponding time zone description.</para>
330 <indexterm zone="ch-system-glibc xtrace"><primary sortas="b-xtrace">xtrace</primary></indexterm>
331 <para id="xtrace"><command>xtrace</command> traces the execution of a program by
332 printing the currently executed function.</para>
334 <indexterm zone="ch-system-glibc zdump"><primary sortas="b-zdump">zdump</primary></indexterm>
335 <para id="zdump"><command>zdump</command> is the time zone dumper.</para>
337 <indexterm zone="ch-system-glibc zic"><primary sortas="b-zic">zic</primary></indexterm>
338 <para id="zic"><command>zic</command> is the time zone compiler.</para>
340 <indexterm zone="ch-system-glibc ld.so"><primary sortas="c-ld.so">ld.so</primary></indexterm>
341 <para id="ld.so"><command>ld.so</command> is the helper program for shared library
342 executables.</para>
344 <indexterm zone="ch-system-glibc libBrokenLocale"><primary sortas="c-libBrokenLocale">libBrokenLocale</primary></indexterm>
345 <para id="libBrokenLocale"><command>libBrokenLocale</command> is used by programs, such as
346 Mozilla, to solve broken locales.</para>
348 <indexterm zone="ch-system-glibc libSegFault"><primary sortas="c-libSegFault">libSegFault</primary></indexterm>
349 <para id="libSegFault"><command>libSegFault</command> is a segmentation fault signal
350 handler. It tries to catch segfaults.</para>
352 <indexterm zone="ch-system-glibc libanl"><primary sortas="c-libanl">libanl</primary></indexterm>
353 <para id="libanl"><command>libanl</command> is an asynchronous name lookup
354 library.</para>
356 <indexterm zone="ch-system-glibc libbsd-compat"><primary sortas="c-libbsd-compat">libbsd-compat</primary></indexterm>
357 <para id="libbsd-compat"><command>libbsd-compat</command> provides the portability needed
358 in order to run certain BSD programs under Linux.</para>
360 <indexterm zone="ch-system-glibc libc"><primary sortas="c-libc">libc</primary></indexterm>
361 <para id="libc"><command>libc</command> is the main C library -- a collection of
362 commonly used functions.</para>
364 <indexterm zone="ch-system-glibc libcrypt"><primary sortas="c-libcrypt">libcrypt</primary></indexterm>
365 <para id="libcrypt"><command>libcrypt</command> is the cryptography library.</para>
367 <indexterm zone="ch-system-glibc libdl"><primary sortas="c-libdl">libdl</primary></indexterm>
368 <para id="libdl"><command>libdl</command> is the dynamic linking interface library.</para>
370 <indexterm zone="ch-system-glibc libg"><primary sortas="c-libg">libg</primary></indexterm>
371 <para id="libg"><command>libg</command> is a runtime library for g++.</para>
373 <indexterm zone="ch-system-glibc libieee"><primary sortas="c-libieee">libieee</primary></indexterm>
374 <para id="libieee"><command>libieee</command> is the IEEE floating point library.</para>
376 <indexterm zone="ch-system-glibc libm"><primary sortas="c-libm">libm</primary></indexterm>
377 <para id="libm"><command>libm</command> is the mathematical library.</para>
379 <indexterm zone="ch-system-glibc libmcheck"><primary sortas="c-libmcheck">libmcheck</primary></indexterm>
380 <para id="libmcheck"><command>libmcheck</command> contains code run at boot.</para>
382 <indexterm zone="ch-system-glibc libmemusage"><primary sortas="c-libmemusage">libmemusage</primary></indexterm>
383 <para id="libmemusage"><command>libmemusage</command> is used by memusage to help collect
384 information about the memory usage of a program.</para>
386 <indexterm zone="ch-system-glibc libnsl"><primary sortas="c-libnsl">libnsl</primary></indexterm>
387 <para id="libnsl"><command>libnsl</command> is the network services library.</para>
389 <indexterm zone="ch-system-glibc libnss"><primary sortas="c-libnss*">libnss*</primary></indexterm>
390 <para id="libnss"><command>libnss*</command> are the Name Service Switch libraries,
391 containing functions for resolving host names, user names, group names,
392 aliases, services, protocols,and the like.</para>
394 <indexterm zone="ch-system-glibc libpcprofile"><primary sortas="c-libpcprofile">libpcprofile</primary></indexterm>
395 <para id="libpcprofile"><command>libpcprofile</command> contains profiling functions used
396 to track the amount of CPU time spent in which source code lines.</para>
398 <indexterm zone="ch-system-glibc libpthread"><primary sortas="c-libpthread">libpthread</primary></indexterm>
399 <para id="libpthread"><command>libpthread</command> is the POSIX threads library.</para>
401 <indexterm zone="ch-system-glibc libresolv"><primary sortas="c-libresolv">libresolv</primary></indexterm>
402 <para id="libresolv"><command>libresolv</command> contains functions for creating,
403 sending, and interpreting packets to the Internet domain name servers.</para>
405 <indexterm zone="ch-system-glibc librpcsvc"><primary sortas="c-librpcsvc">librpcsvc</primary></indexterm>
406 <para id="librpcsvc"><command>librpcsvc</command>contains functions providing
407 miscellaneous RPC services.</para>
409 <indexterm zone="ch-system-glibc librt"><primary sortas="c-librt">librt</primary></indexterm>
410 <para id="librt"><command>librt</command> contains functions providing most of the
411 interfaces specified by the POSIX.1b Realtime Extension.</para>
413 <indexterm zone="ch-system-glibc libthread_db"><primary sortas="c-libthread_db">libthread_db</primary></indexterm>
414 <para id="libthread_db"><command>libthread_db</command> contains functions useful for
415 building debuggers for multi-threaded programs.</para>
417 <indexterm zone="ch-system-glibc libutil"><primary sortas="c-libutil">libutil</primary></indexterm>
418 <para id="libutil"><command>libutil</command> contains code for "standard" functions
419 used in many different Unix utilities.</para>
421 </sect2>
425 </sect1>