<sect1 id="ch-system-glibc" xreflabel="Glibc"> <title>Installing Glibc-&glibc-version;</title> <?dbhtml filename="glibc.html" dir="chapter06"?> <para>The Glibc package contains the main C library. This library provides all the basic routines for allocating memory, searching directories, opening and closing files, reading and writing them, string handling, pattern matching, arithmetic, and so on.</para> <screen>&buildtime; &glibc-time; &diskspace; &glibc-compsize;</screen> &aa-glibc-down; &aa-glibc-dep; <sect2><title> </title><para> </para></sect2> <sect2> <title>Installation of Glibc</title> <para>The Glibc build system is very well self-contained and will install perfectly, even though our compiler specs file and linker are still pointing at <filename>/tools</filename>. We cannot adjust the specs and linker before the Glibc install, because the Glibc autoconf tests would then give bogus results and thus defeat our goal of achieving a clean build.</para> <para>Before starting to build Glibc, remember to unset any environment variables that override the default optimization flags.</para> <para>The Glibc documentation recommends building Glibc outside of the source directory in a dedicated build directory:</para> <screen><userinput>mkdir ../glibc-build cd ../glibc-build</userinput></screen> <para>Now prepare Glibc for compilation:</para> <screen><userinput>../&glibc-dir;/configure --prefix=/usr \ --disable-profile --enable-add-ons=linuxthreads \ --libexecdir=/usr/lib --with-headers=/usr/include \ --without-cvs</userinput></screen> <para>The meaning of the new configure options:</para> <itemizedlist> <listitem><para><userinput>--libexecdir=/usr/lib</userinput>: This changes the location of the <filename>pt_chown</filename> program from its default of <filename class="directory">/usr/libexec</filename> to <filename class="directory">/usr/lib</filename>. The use of <emphasis>libexec</emphasis> is considered not to be FHS-compliant because the FHS doesn't even mention it.</para></listitem> <listitem><para><userinput>--with-headers=/usr/include</userinput>: This ensures that the kernel headers in <filename>/usr/include</filename> are used for this build. If you don't pass this switch then the headers from <filename>/tools/include</filename> are used which of course is not ideal (although they should be identical). Using this switch has the advantage that you will be informed immediately should you have forgotten to install the kernel headers into <filename>/usr/include</filename>.</para></listitem> </itemizedlist> <para>Compile the package:</para> <screen><userinput>make</userinput></screen> <important><para>The test suite for Glibc in this section is considered <emphasis>critical</emphasis>. Our advice is to not skip it under any circumstance.</para></important> <para>Test the results:</para> <screen><userinput>make check</userinput></screen> <para>The test suite notes from <xref linkend="ch-tools-glibc"/> are still very much appropriate here. Be sure to refer back there should you have any doubts.</para> <para>Though it is a harmless message, the install stage of Glibc will complain about the absence of <filename>/etc/ld.so.conf</filename>. Fix this annoying little warning with:</para> <screen><userinput>touch /etc/ld.so.conf</userinput></screen> <para>And install the package:</para> <screen><userinput>make install</userinput></screen> <para>The locales that can make your system respond in a different language weren't installed by the above command. Do it with this:</para> <screen><userinput>make localedata/install-locales</userinput></screen> <para>An alternative to running the previous command is to install only those locales which you need or want. This can be achieved by using the <command>localedef</command> command. Information on this can be found in the <filename>INSTALL</filename> file in the Glibc source. However, there are a number of locales that are essential for the tests of future packages to pass, in particular, the <emphasis>libstdc++</emphasis> tests from GCC. The following instructions, instead of the install-locales target above, will install the minimum set of locales necessary for the tests to run successfully:</para> <screen><userinput>mkdir -p /usr/lib/locale 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 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</userinput></screen> <para>Finally, build the linuxthreads man pages:</para> <screen><userinput>make -C ../&glibc-dir;/linuxthreads/man</userinput></screen> <para>And install these pages:</para> <screen><userinput>make -C ../&glibc-dir;/linuxthreads/man install</userinput></screen> </sect2> <sect2><title> </title><para> </para></sect2> <sect2><title>Configuring Glibc</title> <para>We need to create the <filename>/etc/nsswitch.conf</filename> file, because, although Glibc provides defaults when this file is missing or corrupt, the Glibc defaults don't work well with networking. Also, our time zone needs to be set up.</para> <para>Create a new file <filename>/etc/nsswitch.conf</filename> by running the following:</para> <screen><userinput>cat > /etc/nsswitch.conf << "EOF"</userinput> # Begin /etc/nsswitch.conf passwd: files group: files shadow: files publickey: files hosts: files dns networks: files protocols: db files services: db files ethers: db files rpc: db files netgroup: db files # End /etc/nsswitch.conf <userinput>EOF</userinput></screen> <para>To find out what time zone you're in, run the following script:</para> <screen><userinput>tzselect</userinput></screen> <para>When you've answered a few questions about your location, the script will output the name of your time zone, something like <emphasis>EST5EDT</emphasis> or <emphasis>Canada/Eastern</emphasis>. Then create the <filename>/etc/localtime</filename> file by running:</para> <screen><userinput>cp --remove-destination /usr/share/zoneinfo/Canada/Eastern /etc/localtime</userinput></screen> <para>The meaning of the option:</para> <itemizedlist> <listitem><para><userinput>--remove-destination</userinput>: This is needed to force removal of the already existing symbolic link. The reason why we copy instead of symlink is to cover the situation where <filename>/usr</filename> is on a separate partition. This could matter, for example, when booted into single user mode.</para></listitem> </itemizedlist> <para>Of course, instead of <emphasis>Canada/Eastern</emphasis>, fill in the name of the time zone that the <command>tzselect</command> script gave you.</para> </sect2> <sect2><title> </title><para> </para></sect2> <sect2> <title>Configuring Dynamic Loader</title> <para>By default, the dynamic loader (<filename>/lib/ld-linux.so.2</filename>) searches through <filename class="directory">/lib</filename> and <filename class="directory">/usr/lib</filename> for dynamic libraries that are needed by programs when you run them. However, if there are libraries in directories other than <filename class="directory">/lib</filename> and <filename class="directory">/usr/lib</filename>, you need to add them to the <filename>/etc/ld.so.conf</filename> file for the dynamic loader to find them. Two directories that are commonly known to contain additional libraries are <filename class="directory">/usr/local/lib</filename> and <filename class="directory">/opt/lib</filename>, so we add those directories to the dynamic loader's search path.</para> <para>Create a new file <filename>/etc/ld.so.conf</filename> by running the following:</para> <screen><userinput>cat > /etc/ld.so.conf << "EOF"</userinput> # Begin /etc/ld.so.conf /usr/local/lib /opt/lib # End /etc/ld.so.conf <userinput>EOF</userinput></screen> </sect2> &aa-glibc-shortdesc; &aa-glibc-desc; </sect1>