%general-entities; ]> GLIBC-&glibc-version; GLIBC <para>The GLIBC package contains the main C library. This library provides the basic routines for allocating memory, searching directories, opening and closing files, reading and writing files, string handling, pattern matching, arithmetic, and so on.</para> </sect2> <sect2 role="installation"> <title>Installation of GLIBC Some packages outside of CLFS suggest installing GNU libiconv in order to translate data from one encoding to another. The project's home page () says This library provides an iconv() implementation, for use on systems which don't have one, or whose implementation cannot convert from/to Unicode. GLIBC provides an iconv() implementation and can convert from/to Unicode, therefore libiconv is not required on a CLFS system. At the end of the installation, the build system will run a sanity test to make sure everything installed properly. This script will attempt to test for a library that is only used in the test suite and is never installed. Prevent the script from testing for this library with the following command: sed -i 's/\(&& $name ne\) "db1"/ & \1 "nss_test1"/' scripts/test-installation.pl This same script performs its tests by attempting to compile test programs against certain libraries. However it does not specify the ld.so, and our toolchain is still configured to use the one in /tools. The following set of commands will force the script to use the complete path of the new ld.so that was just installed: LINKER=$(readelf -l /tools/bin/bash | sed -n 's@.*interpret.*/tools\(.*\)]$@\1@p') sed -i "s|libs -o|libs -L/usr/lib -Wl,-dynamic-linker=${LINKER} -o|" \ scripts/test-installation.pl unset LINKER The GLIBC build system is self-contained and will install perfectly, even though the compiler specs file and linker are still pointing at /tools. The specs and linker cannot be adjusted before the GLIBC install because the GLIBC Autoconf tests would give false results and defeat the goal of achieving a clean build. Apply the following sed so the tzselect script works properly: sed -i 's/\\$$(pwd)/`pwd`/' timezone/Makefile The GLIBC documentation recommends building GLIBC outside of the source directory in a dedicated build directory: mkdir -v ../glibc-build cd ../glibc-build Prepare GLIBC for compilation: ../glibc-&glibc-version;/configure --prefix=/usr \ --disable-profile --enable-kernel=2.6.32 --libexecdir=/usr/lib/glibc \ --enable-obsolete-rpc The meaning of the new configure option: --libexecdir=/usr/lib/glibc This changes the location of the getconf utility from its default of /usr/libexec to /usr/lib/glibc. Compile the package: make The test suite for GLIBC is considered critical. Do not skip it under any circumstance. Before running the tests, copy a file from the source tree into our build tree to prevent a couple of test failures, then run the tests: cp -v ../glibc-&glibc-version;/iconvdata/gconv-modules iconvdata make -k check 2>&1 | tee glibc-check-log; grep Error glibc-check-log The GLIBC test suite is highly dependent on certain functions of the host system, in particular the kernel. The posix/annexc and conform/run-conformtest tests normally fail and you should see Error 1 (ignored) in the output. Apart from this, the GLIBC test suite is always expected to pass. However, in certain circumstances, some failures are unavoidable. If a test fails because of a missing program (or missing symbolic link), or a segfault, you will see an error code greater than 127 and the details will be in the log. More commonly, tests will fail with Error 2 - for these, the contents of the corresponding .out file, e.g. posix/annexc.out may be informative. Here is a list of the most common issues: The nptl/tst-clock2, nptl/tst-attr3, tst/tst-cputimer1, and rt/tst-cpuclock2 tests have been known to fail. The reason is not completely understood, but indications are that minor timing issues can trigger these failures. The math tests sometimes fail. Certain optimization settings are known to be a factor here. If you have mounted the CLFS partition with the noatime option, the atime test will fail. As mentioned in , do not use the noatime option while building CLFS. When running on older and slower hardware, some tests can fail because of test timeouts being exceeded. Modifying the make check command to set a TIMEOUTFACTOR is reported to help eliminate these errors (e.g. TIMEOUTFACTOR=16 make -k check). posix/tst-getaddrinfo4 will always fail due to not having a network connection when the test is run. Though it is a harmless message, the install stage of GLIBC will complain about the absence of /etc/ld.so.conf. Prevent this warning with: touch /etc/ld.so.conf Install the package, and remove unneeded files from /usr/include/rpcsvc: make install && rm -v /usr/include/rpcsvc/*.x Install the configuration file and runtime directory for nscd cp -v ../glibc-2.19/nscd/nscd.conf /etc/nscd.conf mkdir -pv /var/cache/nscd Install the Systemd support files for nscd: install -v -Dm644 ../glibc-2.19/nscd/nscd.tmpfiles /usr/lib/tmpfiles.d/nscd.conf install -v -Dm644 ../glibc-2.19/nscd/nscd.service /lib/systemd/system/nscd.service Internationalization The locales that can make the system respond in a different language were not installed by the above command. Install them with: make localedata/install-locales To save time, an alternative to running the previous command (which generates and installs every locale listed in the glibc-&glibc-version;/localedata/SUPPORTED file) is to install only those locales that are wanted and needed. This can be achieved by using the localedef command. Information on this command is located in the INSTALL file in the GLIBC source. However, there are a number of locales that are essential in order for the tests of future packages to pass, in particular, the libstdc++ tests from GCC. The following instructions, instead of the install-locales target used above, will install the minimum set of locales necessary for the tests to run successfully: mkdir -pv /usr/lib/locale localedef -i cs_CZ -f UTF-8 cs_CZ.UTF-8 localedef -i de_DE -f ISO-8859-1 de_DE localedef -i de_DE@euro -f ISO-8859-15 de_DE@euro localedef -i en_HK -f ISO-8859-1 en_HK localedef -i en_PH -f ISO-8859-1 en_PH localedef -i en_US -f ISO-8859-1 en_US localedef -i es_MX -f ISO-8859-1 es_MX localedef -i fa_IR -f UTF-8 fa_IR localedef -i fr_FR -f ISO-8859-1 fr_FR localedef -i fr_FR@euro -f ISO-8859-15 fr_FR@euro localedef -i it_IT -f ISO-8859-1 it_IT localedef -i ja_JP -f EUC-JP ja_JP Some locales installed by the make localedata/install-locales command above are not properly supported by some applications that are in CLFS and CBLFS. Because of the various problems that arise due to application programmers making assumptions that break in such locales, CLFS should not be used in locales that utilize multibyte character sets (including UTF-8) or right-to-left writing order. Numerous unofficial and unstable patches are required to fix these problems, and it has been decided by the CLFS developers not to support such complex locales at this time. This applies to the ja_JP and fa_IR locales as well—they have been installed only for GCC and Gettext tests to pass, and the watch program (part of the Procps-ng package) does not work properly in them. Various attempts to circumvent these restrictions are documented in internationalization-related hints. Configuring GLIBC /etc/nsswitch.conf /etc/localtime The /etc/nsswitch.conf file needs to be created because, although GLIBC provides defaults when this file is missing or corrupt, the GLIBC defaults do not work well in a networked environment. The time zone also needs to be configured. Create a new file /etc/nsswitch.conf by running the following: cat > /etc/nsswitch.conf << "EOF" # Begin /etc/nsswitch.conf passwd: files group: files shadow: files hosts: files dns networks: files protocols: files services: files ethers: files rpc: files # End /etc/nsswitch.conf EOF Install timezone data: tar -xf ../tzdata&tzdata-version;.tar.gz ZONEINFO=/usr/share/zoneinfo mkdir -pv $ZONEINFO/{posix,right} for tz in etcetera southamerica northamerica europe africa antarctica \ asia australasia backward pacificnew \ systemv; do zic -L /dev/null -d $ZONEINFO -y "sh yearistype.sh" ${tz} zic -L /dev/null -d $ZONEINFO/posix -y "sh yearistype.sh" ${tz} zic -L leapseconds -d $ZONEINFO/right -y "sh yearistype.sh" ${tz} done cp -v zone.tab iso3166.tab $ZONEINFO zic -d $ZONEINFO -p America/New_York unset ZONEINFO The meaning of the zic commands: zic -L /dev/null ... This creates posix timezones, without any leap seconds. It is conventional to put these in both zoneinfo and zoneinfo/posix. It is necessary to put the POSIX timezones in zoneinfo, otherwise various test-suites will report errors. On an embedded system, where space is tight and you do not intend to ever update the timezones, you could save 1.9MB by not using the posix directory, but some applications or test-suites might give less good results zic -L leapseconds ... This creates right timezones, including leap seconds. On an embedded system, where space is tight and you do not intend to ever update the timezones, or care about the correct time, you could save 1.9MB by omitting the right directory. zic ... -p ... This creates the posixrules file. We use New York because POSIX requires the daylight savings time rules to be in accordance with US rules. To determine the local time zone, run the following script: tzselect After answering a few questions about the location, the script will output the name of the time zone (e.g., EST5EDT or Canada/Eastern). Then create the /etc/localtime file by running: cp -v /usr/share/zoneinfo/[xxx] \ /etc/localtime Replace [xxx] with the name of the time zone that tzselect provided (e.g., Canada/Eastern). Configuring The Dynamic Loader /etc/ld.so.conf By default, the dynamic loader (/lib/ld-linux.so.2) searches through /lib and /usr/lib for dynamic libraries that are needed by programs as they are run. However, if there are libraries in directories other than /lib and /usr/lib, these need to be added to the /etc/ld.so.conf file in order for the dynamic loader to find them. Two directories that are commonly known to contain additional libraries are /usr/local/lib and /opt/lib, so add those directories to the dynamic loader's search path. Create a new file /etc/ld.so.conf by running the following: cat > /etc/ld.so.conf << "EOF" # Begin /etc/ld.so.conf /usr/local/lib /opt/lib # End /etc/ld.so.conf EOF Contents of GLIBC Installed programs Installed libraries Installed directories catchsegv, gencat, getconf, getent, iconv, iconvconfig, ldconfig, ldd, lddlibc4, locale, localedef, makedb, mtrace, nscd, pcprofiledump, pldd, rpcgen, sln, sprof, tzselect, xtrace,zdump, and zic ld.so, libBrokenLocale.[a,so], libSegFault.so, libanl.[a,so], libc.[a,so], libc_nonshared.a, libcidn.[a,so], libcrypt.[a,so], libdl.[a,so], libg.a, libieee.a, libm.[a,so], libmcheck.a, libmemusage.so, libnsl.a, libnss_compat.so, libnss_dns.so, libnss_files.so, libnss_hesiod.so, libnss_nis.so, libnss_nisplus.so, libpcprofile.so, libpthread.[a,so], libpthread_nonshared.a, libresolv.[a,so], librpcsvc.a, librt.[a,so], libthread_db.so, and libutil.[a,so] /usr/include/arpa, /usr/include/bits, /usr/include/gnu, /usr/include/net, /usr/include/netash, /usr/include/netatalk, /usr/include/netax25, /usr/include/neteconet, /usr/include/netinet, /usr/include/netipx, /usr/include/netiucv, /usr/include/netpacket, /usr/include/netrom, /usr/include/netrose, /usr/include/nfs, /usr/include/protocols, /usr/include/rpc, /usr/include/rpcsvc, /usr/include/sys, /usr/lib/gconv, /usr/lib/glibc, /usr/lib/locale, /usr/share/i18n, /usr/share/zoneinfo, /var/cache/ldconfig, and /var/cache/nscd Short Descriptions catchsegv Can be used to create a stack trace when a program terminates with a segmentation fault catchsegv gencat Generates message catalogues gencat getconf Displays the system configuration values for file system specific variables getconf getent Gets entries from an administrative database getent iconv Performs character set conversion iconv iconvconfig Creates fastloading iconv module configuration files iconvconfig ldconfig Configures the dynamic linker runtime bindings ldconfig ldd Reports which shared libraries are required by each given program or shared library ldd lddlibc4 Assists ldd with object files lddlibc4 locale Tells the compiler to enable or disable the use of POSIX locales for built-in operations locale localedef Compiles locale specifications localedef makedb Creates a simple database from textual input makedb mtrace Reads and interprets a memory trace file and displays a summary in human-readable format mtrace nscd A daemon that provides a cache for the most common name service requests nscd pcprofiledump Dumps information generated by PC profiling pcprofiledump pldd Lists dynamic shared objects used by running processes pldd rpcgen Generates C code to implement the Remote Procecure Call (RPC) protocol rpcgen sln A statically linked program that creates symbolic links sln sotruss Traces shared library procedure calls of a specified command sotruss sprof Reads and displays shared object profiling data sprof tzselect Asks the user about the location of the system and reports the corresponding time zone description tzselect xtrace Traces the execution of a program by printing the currently executed function xtrace zdump The time zone dumper zdump zic The time zone compiler zic ld.so The helper program for shared library executables ld.so libBrokenLocale Used by programs, such as Mozilla, to solve broken locales libBrokenLocale libSegFault The segmentation fault signal handler libSegFault libanl An asynchronous name lookup library libanl libc The main C library libc libcidn Used internally by GLIBC for handling internationalized domain names in the getaddrinfo() function libcidn libcrypt The cryptography library libcrypt libdl The dynamic linking interface library libdl libg A runtime library for g++ libg libieee The Institute of Electrical and Electronic Engineers (IEEE) floating point library libieee libm The mathematical library libm libmcheck Contains code run at boot libmcheck libmemusage Used by memusage (included in GLIBC, but not built in a base CLFS system as it has additional dependencies) to help collect information about the memory usage of a program libmemusage libnsl The network services library libnsl libnss The Name Service Switch libraries, containing functions for resolving host names, user names, group names, aliases, services, protocols, etc. libnss libpcprofile Contains profiling functions used to track the amount of CPU time spent in specific source code lines libpcprofile libpthread The POSIX threads library libpthread libresolv Contains functions for creating, sending, and interpreting packets to the Internet domain name servers libresolv librpcsvc Contains functions providing miscellaneous RPC services librpcsvc librt Contains functions providing most of the interfaces specified by the POSIX.1b Realtime Extension librt libthread_db Contains functions useful for building debuggers for multi-threaded programs libthread_db libutil Contains code for standard functions used in many different Unix utilities libutil