source: chapter06/glibc.xml@ b32e803

10.0 10.0-rc1 10.1 10.1-rc1 11.0 11.0-rc1 11.0-rc2 11.0-rc3 11.1 11.1-rc1 11.2 11.2-rc1 11.3 11.3-rc1 12.0 12.0-rc1 12.1 12.1-rc1 12.2 12.2-rc1 6.0 6.1 6.1.1 6.3 6.4 6.5 6.6 6.7 6.8 7.0 7.1 7.2 7.3 7.4 7.5 7.5-systemd 7.6 7.6-systemd 7.7 7.7-systemd 7.8 7.8-systemd 7.9 7.9-systemd 8.0 8.1 8.2 8.3 8.4 9.0 9.1 arm bdubbs/gcc13 ml-11.0 multilib renodr/libudev-from-systemd s6-init trunk xry111/arm64 xry111/arm64-12.0 xry111/clfs-ng xry111/lfs-next xry111/loongarch xry111/loongarch-12.0 xry111/loongarch-12.1 xry111/loongarch-12.2 xry111/mips64el xry111/multilib xry111/pip3 xry111/rust-wip-20221008 xry111/update-glibc
Last change on this file since b32e803 was b32e803, checked in by Zack Winkles <winkie@…>, 20 years ago

Committed Alexander's i18n patch

git-svn-id: http://svn.linuxfromscratch.org/LFS/trunk/BOOK@3489 4aa44e1e-78dd-0310-a6d2-fbcd4c07a689

  • Property mode set to 100644
File size: 20.0 KB
Line 
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"?>
9
10<indexterm zone="ch-system-glibc"><primary sortas="a-Glibc">Glibc</primary></indexterm>
11
12<para>The Glibc package contains the main C library. This library provides all
13the basic routines for allocating memory, searching directories, opening and
14closing files, reading and writing them, string handling, pattern matching,
15arithmetic, and so on.</para>
16
17<screen>&buildtime; 12.3 SBU
18&diskspace; 784 MB</screen>
19
20<para>Glibc installation depends on: Bash, Binutils, Coreutils, Diffutils,
21Gawk, GCC, Gettext, Grep, Make, Perl, Sed, Texinfo.</para>
22
23
24
25<sect2>
26<title>Installation of Glibc</title>
27
28<para>The Glibc build system is very well self-contained and will install
29perfectly, even though our compiler specs file and linker are still pointing
30at <filename>/tools</filename>. We cannot adjust the specs and linker before
31the Glibc install, because the Glibc autoconf tests would then give bogus
32results and thus defeat our goal of achieving a clean build.</para>
33
34<para>Before starting to build Glibc, remember to unset any environment
35variables that override the default optimization flags.</para>
36
37<para>The Glibc documentation recommends building Glibc outside of the source
38directory in a dedicated build directory:</para>
39
40<screen><userinput>mkdir ../glibc-build
41cd ../glibc-build</userinput></screen>
42
43<para>Now prepare Glibc for compilation:</para>
44
45<screen><userinput>../glibc-&glibc-version;/configure --prefix=/usr \
46 --disable-profile --enable-add-ons=nptl --with-tls \
47 --libexecdir=/tmp/pt_chown --without-cvs \
48 --with-headers=/tools/glibc-kernheaders</userinput></screen>
49
50<para>The meaning of the new configure options:</para>
51
52<itemizedlist>
53<listitem><para><userinput>--libexecdir=/tmp/pt_chown</userinput>: This changes
54the location of the <filename>pt_chown</filename> program from its default of
55<filename class="directory">/usr/libexec</filename> to
56<filename class="directory">/tmp/pt_chown</filename>. This program isn't required
57on modern systems, so we install it in a place from which we will delete it
58later.</para></listitem>
59</itemizedlist>
60
61<para>Compile the package:</para>
62
63<screen><userinput>make</userinput></screen>
64
65<important><para>The test suite for Glibc in this section is considered
66<emphasis>critical</emphasis>. Our advice is to not skip it under any
67circumstance.</para></important>
68
69<para>Test the results:</para>
70
71<screen><userinput>make check</userinput></screen>
72
73<para>The test suite notes from <xref linkend="ch-tools-glibc"/> are still very much
74appropriate here. Be sure to refer back there should you have any doubts.</para>
75
76<para>Though it is a harmless message, the install stage of Glibc will
77complain about the absence of <filename>/etc/ld.so.conf</filename>. Fix this
78annoying little warning with:</para>
79
80<screen><userinput>touch /etc/ld.so.conf</userinput></screen>
81
82<para>And install the package:</para>
83
84<screen><userinput>make install</userinput></screen>
85
86<para>The locales that can make your system respond in a different language
87weren't installed by the above command. Do it with this:</para>
88
89<screen><userinput>make localedata/install-locales</userinput></screen>
90
91<para>An alternative to running the previous command is to install only those
92locales which you need or want. This can be achieved by using the
93<command>localedef</command> command. Information on this can be found in
94the <filename>INSTALL</filename> file in the Glibc source. However, there are
95a number of locales that are essential for the tests of future packages to
96pass, in particular, the <emphasis>libstdc++</emphasis> tests from GCC. The
97following instructions, instead of the install-locales target above, will
98install the minimum set of locales necessary for the tests to run
99successfully:</para>
100
101<screen><userinput>mkdir -p /usr/lib/locale
102localedef -i de_DE -f ISO-8859-1 de_DE
103localedef -i de_DE@euro -f ISO-8859-15 de_DE@euro
104localedef -i en_HK -f ISO-8859-1 en_HK
105localedef -i en_PH -f ISO-8859-1 en_PH
106localedef -i en_US -f ISO-8859-1 en_US
107localedef -i es_MX -f ISO-8859-1 es_MX
108localedef -i fa_IR -f UTF-8 fa_IR
109localedef -i fr_FR -f ISO-8859-1 fr_FR
110localedef -i fr_FR@euro -f ISO-8859-15 fr_FR@euro
111localedef -i it_IT -f ISO-8859-1 it_IT
112localedef -i ja_JP -f EUC-JP ja_JP</userinput></screen>
113
114<para>In fact, some locales installed by the
115<command>make localedata/install-locales</command>
116command above are not properly
117supported by some applications that are in LFS and BLFS books. Because
118of various problems that arise
119due to application programmers making
120assumptions that break in such locales, LFS <emphasis>should not</emphasis>
121be used in locales that utilize
122multibyte character sets (including UTF-8) or
123right-to-left writing order.
124Numerous unofficial and unstable patches are required to fix these problems,
125and it has been decided not to support such complex locales.
126This applies to the ja_JP and fa_IR locales as well:
127they have been installed only
128for gcc and gettext tests to pass, and e.g. <application>vim</application>
129compiled according to this book doesn't work properly in them.
130Various attempts to circumvent these
131restrictions are documented in internationalization-related hints.</para>
132
133<para>Finally, build the linuxthreads man pages, which are a great reference
134on the threading API (applicable to NPTL as well):</para>
135
136<screen><userinput>make -C ../glibc-&glibc-version;/linuxthreads/man</userinput></screen>
137
138<para>And install these pages:</para>
139
140<screen><userinput>make -C ../glibc-&glibc-version;/linuxthreads/man install</userinput></screen>
141
142</sect2>
143
144
145<sect2 id="conf-glibc"><title>Configuring Glibc</title>
146<indexterm zone="conf-glibc"><primary sortas="e-/etc/nsswitch.conf">/etc/nsswitch.conf</primary></indexterm>
147<indexterm zone="conf-glibc"><primary sortas="e-/etc/localtime">/etc/localtime</primary></indexterm>
148
149<para>We need to create the <filename>/etc/nsswitch.conf</filename> file,
150because, although Glibc provides defaults when this file is missing or corrupt,
151the Glibc defaults don't work well with networking. Also, our time zone needs
152to be set up.</para>
153
154<para>Create a new file <filename>/etc/nsswitch.conf</filename> by running the
155following:</para>
156
157<screen><userinput>cat &gt; /etc/nsswitch.conf &lt;&lt; "EOF"</userinput>
158# Begin /etc/nsswitch.conf
159
160passwd: files
161group: files
162shadow: files
163
164publickey: files
165
166hosts: files dns
167networks: files
168
169protocols: db files
170services: db files
171ethers: db files
172rpc: db files
173
174netgroup: db files
175
176# End /etc/nsswitch.conf
177<userinput>EOF</userinput></screen>
178
179<para>To find out what time zone you're in, run the following script:</para>
180
181<screen><userinput>tzselect</userinput></screen>
182
183<para>When you've answered a few questions about your location, the script will
184output the name of your time zone, something like <emphasis>EST5EDT</emphasis>
185or <emphasis>Canada/Eastern</emphasis>. Then create the
186<filename>/etc/localtime</filename> file by running:</para>
187
188<screen><userinput>cp --remove-destination /usr/share/zoneinfo/Canada/Eastern /etc/localtime</userinput></screen>
189
190<para>The meaning of the option:</para>
191
192<itemizedlist>
193<listitem><para><userinput>--remove-destination</userinput>: This is needed to
194force removal of the already existing symbolic link. The reason why we copy
195instead of symlink is to cover the situation where <filename>/usr</filename> is
196on a separate partition. This could matter, for example, when booted into single
197user mode.</para></listitem>
198</itemizedlist>
199
200<para>Of course, instead of <emphasis>Canada/Eastern</emphasis>, fill in
201the name of the time zone that the <command>tzselect</command> script
202gave you.</para>
203
204</sect2>
205
206
207<sect2 id="conf-ld">
208<title>Configuring Dynamic Loader</title>
209<indexterm zone="conf-ld"><primary sortas="e-/etc/ld.so.conf">/etc/ld.so.conf</primary></indexterm>
210
211<para>By default, the dynamic loader
212(<filename>/lib/ld-linux.so.2</filename>) searches through <filename
213class="directory">/lib</filename> and <filename class="directory">/usr/lib</filename>
214for dynamic libraries that are needed
215by programs when you run them. However, if there are libraries in
216directories other than <filename class="directory">/lib</filename> and
217<filename class="directory">/usr/lib</filename>, you need to add them to
218the <filename>/etc/ld.so.conf</filename> file for the dynamic
219loader to find them. Two directories that are commonly known to contain
220additional libraries are <filename class="directory">/usr/local/lib</filename>
221and <filename class="directory">/opt/lib</filename>, so we add those directories to the
222dynamic loader's search path.</para>
223
224<para>Create a new file <filename>/etc/ld.so.conf</filename> by running the
225following:</para>
226
227<screen><userinput>cat &gt; /etc/ld.so.conf &lt;&lt; "EOF"</userinput>
228# Begin /etc/ld.so.conf
229
230/usr/local/lib
231/opt/lib
232
233# End /etc/ld.so.conf
234<userinput>EOF</userinput></screen>
235
236</sect2>
237
238
239<sect2 id="contents-glibc"><title>Contents of Glibc</title>
240
241<para><emphasis>Installed programs</emphasis>: catchsegv, gencat, getconf,
242getent, glibcbug, iconv, iconvconfig, ldconfig, ldd, lddlibc4, locale,
243localedef, mtrace, nscd, nscd_nischeck, pcprofiledump, pt_chown, rpcgen,
244rpcinfo, sln, sprof, tzselect, xtrace, zdump and zic</para>
245
246<para><emphasis>Installed libraries</emphasis>: ld.so, libBrokenLocale.[a,so],
247libSegFault.so, libanl.[a,so], libbsd-compat.a, libc.[a,so], libc_nonshared.a,
248libcrypt.[a,so], libdl.[a,so], libg.a, libieee.a, libm.[a,so], libmcheck.a,
249libmemusage.so, libnsl.a, libnss_compat.so, libnss_dns.so, libnss_files.so,
250libnss_hesiod.so, libnss_nis.so, libnss_nisplus.so, libpcprofile.so,
251libpthread.[a,so], libresolv.[a,so], librpcsvc.a, librt.[a,so], libthread_db.so
252and libutil.[a,so]</para>
253
254</sect2>
255
256
257<sect2><title>Short descriptions</title>
258
259<indexterm zone="ch-system-glibc catchsegv"><primary sortas="b-catchsegv">catchsegv</primary></indexterm>
260<para id="catchsegv"><command>catchsegv</command> can be used to create a stack trace
261when a program terminates with a segmentation fault.</para>
262
263<indexterm zone="ch-system-glibc gencat"><primary sortas="b-gencat">gencat</primary></indexterm>
264<para id="gencat"><command>gencat</command> generates message catalogues.</para>
265
266<indexterm zone="ch-system-glibc getconf"><primary sortas="b-getconf">getconf</primary></indexterm>
267<para id="getconf"><command>getconf</command> displays the system configuration values
268for file system specific variables.</para>
269
270<indexterm zone="ch-system-glibc getent"><primary sortas="b-getent">getent</primary></indexterm>
271<para id="getent"><command>getent</command> gets entries from an administrative
272database.</para>
273
274<indexterm zone="ch-system-glibc glibcbug"><primary sortas="b-glibcbug">glibcbug</primary></indexterm>
275<para id="glibcbug"><command>glibcbug</command> creates a bug report and mails it to the
276bug email address.</para>
277
278<indexterm zone="ch-system-glibc iconv"><primary sortas="b-iconv">iconv</primary></indexterm>
279<para id="iconv"><command>iconv</command> performs character set conversion.</para>
280
281<indexterm zone="ch-system-glibc iconvconfig"><primary sortas="b-iconvconfig">iconvconfig</primary></indexterm>
282<para id="iconvconfig"><command>iconvconfig</command> creates fastloading iconv module
283configuration file.</para>
284
285<indexterm zone="ch-system-glibc ldconfig"><primary sortas="b-ldconfig">ldconfig</primary></indexterm>
286<para id="ldconfig"><command>ldconfig</command> configures the dynamic linker runtime
287bindings.</para>
288
289<indexterm zone="ch-system-glibc ldd"><primary sortas="b-ldd">ldd</primary></indexterm>
290<para id="ldd"><command>ldd</command> reports which shared libraries are required
291by each given program or shared library.</para>
292
293<indexterm zone="ch-system-glibc lddlibc4"><primary sortas="b-lddlibc4">lddlibc4</primary></indexterm>
294<para id="lddlibc4"><command>lddlibc4</command> assists ldd with object files.</para>
295
296<indexterm zone="ch-system-glibc locale"><primary sortas="b-locale">locale</primary></indexterm>
297<para id="locale"><command>locale</command> is a Perl program that tells the compiler
298to enable or disable the use of POSIX locales for built-in operations.</para>
299
300<indexterm zone="ch-system-glibc localedef"><primary sortas="b-localedef">localedef</primary></indexterm>
301<para id="localedef"><command>localedef</command> compiles locale specifications.</para>
302
303<indexterm zone="ch-system-glibc mtrace"><primary sortas="b-mtrace">mtrace</primary></indexterm>
304<para id="mtrace"><command>mtrace</command>...</para>
305
306<indexterm zone="ch-system-glibc nscd"><primary sortas="b-nscd">nscd</primary></indexterm>
307<para id="nscd"><command>nscd</command> is a name service cache daemon providing a
308cache for the most common name service requests.</para>
309
310<indexterm zone="ch-system-glibc nscd_nischeck"><primary sortas="b-nscd_nischeck">nscd_nischeck</primary></indexterm>
311<para id="nscd_nischeck"><command>nscd_nischeck</command> checks whether or not secure mode
312is necessary for NIS+ lookup.</para>
313
314<indexterm zone="ch-system-glibc pcprofiledump"><primary sortas="b-pcprofiledump">pcprofiledump</primary></indexterm>
315<para id="pcprofiledump"><command>pcprofiledump</command> dumps information generated by
316PC profiling.</para>
317
318<indexterm zone="ch-system-glibc pt_chown"><primary sortas="b-pt_chown">pt_chown</primary></indexterm>
319<para id="pt_chown"><command>pt_chown</command> is a helper program for grantpt to set
320the owner, group and access permissions of a slave pseudo terminal.</para>
321
322<indexterm zone="ch-system-glibc rpcgen"><primary sortas="b-rpcgen">rpcgen</primary></indexterm>
323<para id="rpcgen"><command>rpcgen</command> generates C code to implement the
324RPC protocol.</para>
325
326<indexterm zone="ch-system-glibc rpcinfo"><primary sortas="b-rpcinfo">rpcinfo</primary></indexterm>
327<para id="rpcinfo"><command>rpcinfo</command> makes an RPC call to an RPC server.</para>
328
329<indexterm zone="ch-system-glibc sln"><primary sortas="b-sln">sln</primary></indexterm>
330<para id="sln"><command>sln</command> is used to make symbolic links. The program
331is statically linked, so it is useful for making symbolic links to dynamic
332libraries if the dynamic linking system for some reason is nonfunctional.</para>
333
334<indexterm zone="ch-system-glibc sprof"><primary sortas="b-sprof">sprof</primary></indexterm>
335<para id="sprof"><command>sprof</command> reads and displays shared object profiling
336data.</para>
337
338<indexterm zone="ch-system-glibc tzselect"><primary sortas="b-tzselect">tzselect</primary></indexterm>
339<para id="tzselect"><command>tzselect</command> asks the user about the location of the
340system and reports the corresponding time zone description.</para>
341
342<indexterm zone="ch-system-glibc xtrace"><primary sortas="b-xtrace">xtrace</primary></indexterm>
343<para id="xtrace"><command>xtrace</command> traces the execution of a program by
344printing the currently executed function.</para>
345
346<indexterm zone="ch-system-glibc zdump"><primary sortas="b-zdump">zdump</primary></indexterm>
347<para id="zdump"><command>zdump</command> is the time zone dumper.</para>
348
349<indexterm zone="ch-system-glibc zic"><primary sortas="b-zic">zic</primary></indexterm>
350<para id="zic"><command>zic</command> is the time zone compiler.</para>
351
352<indexterm zone="ch-system-glibc ld.so"><primary sortas="c-ld.so">ld.so</primary></indexterm>
353<para id="ld.so"><command>ld.so</command> is the helper program for shared library
354executables.</para>
355
356<indexterm zone="ch-system-glibc libBrokenLocale"><primary sortas="c-libBrokenLocale">libBrokenLocale</primary></indexterm>
357<para id="libBrokenLocale"><command>libBrokenLocale</command> is used by programs, such as
358Mozilla, to solve broken locales.</para>
359
360<indexterm zone="ch-system-glibc libSegFault"><primary sortas="c-libSegFault">libSegFault</primary></indexterm>
361<para id="libSegFault"><command>libSegFault</command> is a segmentation fault signal
362handler. It tries to catch segfaults.</para>
363
364<indexterm zone="ch-system-glibc libanl"><primary sortas="c-libanl">libanl</primary></indexterm>
365<para id="libanl"><command>libanl</command> is an asynchronous name lookup
366library.</para>
367
368<indexterm zone="ch-system-glibc libbsd-compat"><primary sortas="c-libbsd-compat">libbsd-compat</primary></indexterm>
369<para id="libbsd-compat"><command>libbsd-compat</command> provides the portability needed
370in order to run certain BSD programs under Linux.</para>
371
372<indexterm zone="ch-system-glibc libc"><primary sortas="c-libc">libc</primary></indexterm>
373<para id="libc"><command>libc</command> is the main C library -- a collection of
374commonly used functions.</para>
375
376<indexterm zone="ch-system-glibc libcrypt"><primary sortas="c-libcrypt">libcrypt</primary></indexterm>
377<para id="libcrypt"><command>libcrypt</command> is the cryptography library.</para>
378
379<indexterm zone="ch-system-glibc libdl"><primary sortas="c-libdl">libdl</primary></indexterm>
380<para id="libdl"><command>libdl</command> is the dynamic linking interface library.</para>
381
382<indexterm zone="ch-system-glibc libg"><primary sortas="c-libg">libg</primary></indexterm>
383<para id="libg"><command>libg</command> is a runtime library for g++.</para>
384
385<indexterm zone="ch-system-glibc libieee"><primary sortas="c-libieee">libieee</primary></indexterm>
386<para id="libieee"><command>libieee</command> is the IEEE floating point library.</para>
387
388<indexterm zone="ch-system-glibc libm"><primary sortas="c-libm">libm</primary></indexterm>
389<para id="libm"><command>libm</command> is the mathematical library.</para>
390
391<indexterm zone="ch-system-glibc libmcheck"><primary sortas="c-libmcheck">libmcheck</primary></indexterm>
392<para id="libmcheck"><command>libmcheck</command> contains code run at boot.</para>
393
394<indexterm zone="ch-system-glibc libmemusage"><primary sortas="c-libmemusage">libmemusage</primary></indexterm>
395<para id="libmemusage"><command>libmemusage</command> is used by memusage to help collect
396information about the memory usage of a program.</para>
397
398<indexterm zone="ch-system-glibc libnsl"><primary sortas="c-libnsl">libnsl</primary></indexterm>
399<para id="libnsl"><command>libnsl</command> is the network services library.</para>
400
401<indexterm zone="ch-system-glibc libnss"><primary sortas="c-libnss*">libnss*</primary></indexterm>
402<para id="libnss"><command>libnss*</command> are the Name Service Switch libraries,
403containing functions for resolving host names, user names, group names,
404aliases, services, protocols,and the like.</para>
405
406<indexterm zone="ch-system-glibc libpcprofile"><primary sortas="c-libpcprofile">libpcprofile</primary></indexterm>
407<para id="libpcprofile"><command>libpcprofile</command> contains profiling functions used
408to track the amount of CPU time spent in which source code lines.</para>
409
410<indexterm zone="ch-system-glibc libpthread"><primary sortas="c-libpthread">libpthread</primary></indexterm>
411<para id="libpthread"><command>libpthread</command> is the POSIX threads library.</para>
412
413<indexterm zone="ch-system-glibc libresolv"><primary sortas="c-libresolv">libresolv</primary></indexterm>
414<para id="libresolv"><command>libresolv</command> contains functions for creating,
415sending, and interpreting packets to the Internet domain name servers.</para>
416
417<indexterm zone="ch-system-glibc librpcsvc"><primary sortas="c-librpcsvc">librpcsvc</primary></indexterm>
418<para id="librpcsvc"><command>librpcsvc</command>contains functions providing
419miscellaneous RPC services.</para>
420
421<indexterm zone="ch-system-glibc librt"><primary sortas="c-librt">librt</primary></indexterm>
422<para id="librt"><command>librt</command> contains functions providing most of the
423interfaces specified by the POSIX.1b Realtime Extension.</para>
424
425<indexterm zone="ch-system-glibc libthread_db"><primary sortas="c-libthread_db">libthread_db</primary></indexterm>
426<para id="libthread_db"><command>libthread_db</command> contains functions useful for
427building debuggers for multi-threaded programs.</para>
428
429<indexterm zone="ch-system-glibc libutil"><primary sortas="c-libutil">libutil</primary></indexterm>
430<para id="libutil"><command>libutil</command> contains code for "standard" functions
431used in many different Unix utilities.</para>
432
433</sect2>
434
435
436
437</sect1>
Note: See TracBrowser for help on using the repository browser.