aboutsummaryrefslogtreecommitdiffstats
path: root/chapter06/glibc-exp.xml
blob: 5a3e718528abaa9d55416eb1e645f72d2157931c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
<sect2>
<title>Command explanations</title>

<para><userinput>mknod -m 0666 /dev/null c 1 3:</userinput> Glibc needs a
null device to compile properly. All other devices will be created in the
next section.</para>

<para><userinput>touch /etc/ld.so.conf</userinput> One of the final steps 
of the Glibc installation is running ldconfig to update the dynamic loader 
cache.  If this file doesn't exist, the installation will abort with an error 
that it can't read the file, so we simply create an empty file (the empty file 
will have Glibc default to using /lib and /usr/lib which is fine 
right now).</para>

<para><userinput>sed 's%\$(PERL)%/usr/bin/perl%' 
malloc/Makefile &gt; tmp~:</userinput> This sed command
searches through <filename>malloc/Makefile</filename> and
converts all occurances of <filename>$(PERL)</filename> to
<filename>/usr/bin/perl</filename>.  The output is then written to the
file <filename>tmp~</filename>.  This is done because Glibc can't
autodetect perl since it's not installed yet at the time when we install
Glibc.</para>

<para><userinput>mv -f tmp~ malloc/Makefile:</userinput> The file
<filename>tmp~</filename> is now moved back to
<filename>malloc/Makefile</filename>.  We do this because
when using sed, we can't write straight back to this file so we need to
use a temporary file in between.</para>

<para><userinput>sed 's/root/0' login/Makefile &gt;
tmp~:</userinput> This sed command replaces all occurances of
<filename>root</filename> in
<filename>login/Makefile</filename> with 0.  This is
because as we don't have glibc on the LFS system yet, usernames can't 
be resolved to their user id's.  Therefore, we replace the username 
root with the id 0. </para>

<para><userinput>mv -f tmp~ login/Makefile:</userinput> Asabove, we are using a temporary file (<filename>tmp~</filename>) to store the
edited Makefile and then copying it back over the original.</para>

<para><userinput>--enable-add-ons:</userinput> This enables the add-on that
we install with Glibc: linuxthreads</para>

<para><userinput>sed 's/cross-compiling = yes/cross-compiling = no/'
config.make &gt; config.make~:</userinput> This time, we're replacing
<filename>cross-compiling = yes</filename> with
<filename>cross-compiling = no</filename>.  We do this because we are
only building for our own system.  Cross-compiling is used, for
instance, to build a package for an Apple Power PC on an Intel system.
The reason Glibc thinks we're cross-compiling is that it can't compile a
test program to determine this, so it automatically defaults to a
cross-compiler. The reason for the failed program is because Glibc
hasn't been installed yet.</para>

<para><userinput>mv -f config.make~ config.make:</userinput> Again, we are moving
the temporary file over the original.</para>

<para><userinput>exec /bin/bash:</userinput>This command will
start a new bash shell which will replace the current shell. This is 
done to get rid of the "I have no name!" message in the command 
prompt, which was caused by bash's inability to resolve a userid to 
a username (which in turn was caused by the missing Glibc 
installation).</para>

</sect2>