source: chapter06/glibc-inst.xml@ 90d84f5

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 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 v4_1 v5_0 v5_1 v5_1_1 xry111/arm64 xry111/arm64-12.0 xry111/clfs-ng xry111/lfs-next xry111/loongarch xry111/loongarch-12.0 xry111/loongarch-12.1 xry111/mips64el xry111/pip3 xry111/rust-wip-20221008 xry111/update-glibc
Last change on this file since 90d84f5 was 2c094d6, checked in by Timothy Bauscher <timothy@…>, 22 years ago

Applied Bill Maltby's grammar patch. Changed $LFS to LFS where appropriate. Internal XML cleanup: removed double spacing where appropriate.

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

  • Property mode set to 100644
File size: 3.2 KB
Line 
1<sect2>
2<title>Installation of Glibc</title>
3
4<para>This package requires its patch to be applied before you can
5install it. Make sure it's unpacked before running the installation
6commands.</para>
7
8<para>Before starting to install glibc, you must cd into the
9glibc-&glibc-version; directory and unpack glibc-linuxthreads inside
10the glibc-&glibc-version; directory, not in /usr/src as you normally
11would do.</para>
12
13<para>This package is known to behave badly when you have changed its
14default optimization flags (including the -march and -mcpu options). Glibc
15is best left alone. Therefore, if you have defined any environment variables
16that override default optimizations, such as CFLAGS and CXXFLAGS, we
17recommend unsetting or modifying them when building Glibc. You have
18been warned.</para>
19
20<para>Also, don't pass the --enable-kernel option to the configure
21script. It's known to cause segmentation faults when other packages like
22fileutils, make and tar are linked against it.</para>
23
24<para>Basically, compiling Glibc in any other way than the book suggests
25is putting your system at very high risk.</para>
26
27<para>Install Glibc by running the following commands:</para>
28
29<para><screen><userinput>patch -Np1 -i ../glibc-&glibc-patch-version;.patch &amp;&amp;
30touch /etc/ld.so.conf &amp;&amp;
31mkdir ../glibc-build &amp;&amp;
32cd ../glibc-build &amp;&amp;
33../glibc-&glibc-version;/configure --prefix=/usr --disable-profile \
34&nbsp;&nbsp;&nbsp;&nbsp;--enable-add-ons --libexecdir=/usr/bin &amp;&amp;
35echo "cross-compiling = no" &gt; configparms &amp;&amp;
36make &amp;&amp;
37make install &amp;&amp;
38make localedata/install-locales &amp;&amp;
39exec /static/bin/bash --login</userinput></screen></para>
40
41<para>An alternative to running <userinput>make
42localedata/install-locales</userinput> is to only install those locales
43which you need or want. This can be achieved using the localedef
44command. Information on this can be found in the INSTALL
45file in the glibc-&glibc-version; tree. One thing to note is that the
46<userinput>localedef</userinput> program assumes that the <filename
47class="directory">/usr/lib/locale</filename> directory exists, so you need
48to create it first.</para>
49
50<para>The Linux Threads man pages are not going to be installed at this
51point because it requires a working Perl installation. We'll install Perl
52later on in this chapter, so we'll come back to the Linux Threads man page
53installation after that.</para>
54
55<para>During the configure stage you will see the following warning:</para>
56
57<blockquote><screen>configure: warning:
58*** These auxiliary programs are missing or too old: msgfmt
59*** some features will be disabled.
60*** Check the INSTALL file for required versions.</screen></blockquote>
61
62<para>The missing msgfmt (from the gettext package which we will install
63later in this chapter) won't cause any problems. msgfmt is used to generate
64the binary translation files that are used to make your system talk in a
65different language. Because these translation files have already been
66generated for you, there is no need for msgfmt. You'd only need msgfmt if
67you change the translation source files (the <filename>*.po</filename>
68files in the <filename class="directory">po</filename> subdirectory) which
69would require you to re-generate the binary files.</para>
70
71</sect2>
72
Note: See TracBrowser for help on using the repository browser.