source: chapter06/glibc-inst.xml@ 6143d13

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 6143d13 was 6143d13, checked in by Gerard Beekmans <gerard@…>, 21 years ago

upgraded to glibc-2.3.1, added 2nd glibc install

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

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