1 | <sect1 id="ch06-coreutils">
|
---|
2 | <title>Installing Coreutils-&coreutils-version;</title>
|
---|
3 | <?dbhtml filename="coreutils.html" dir="chapter06"?>
|
---|
4 |
|
---|
5 | <screen>Estimated build time: &coreutils-time;
|
---|
6 | Estimated required disk space: &coreutils-compsize;</screen>
|
---|
7 |
|
---|
8 | &aa-coreutils-shortdesc;
|
---|
9 | &aa-coreutils-dep;
|
---|
10 |
|
---|
11 | <sect2><title> </title><para> </para></sect2>
|
---|
12 |
|
---|
13 | <sect2>
|
---|
14 | <title>Installation of Coreutils</title>
|
---|
15 |
|
---|
16 | <para>Normally the functionality of <userinput>uname</userinput> is somewhat
|
---|
17 | broken, in that the <userinput>-p</userinput> switch always returns "unknown".
|
---|
18 | The following patch fixes this behaviour for Intel architectures:</para>
|
---|
19 |
|
---|
20 | <screen><userinput>patch -Np1 -i ../&coreutils-uname-patch;</userinput></screen>
|
---|
21 |
|
---|
22 | <para>We do not want Coreutils to install its version of the
|
---|
23 | <userinput>hostname</userinput> program, because it is inferior to the version
|
---|
24 | provided by Net-tools. Prevent its installation by applying a patch:</para>
|
---|
25 |
|
---|
26 | <screen><userinput>patch -Np1 -i ../&coreutils-hostname-patch;</userinput></screen>
|
---|
27 |
|
---|
28 | <para>Now prepare Coreutils for compilation:</para>
|
---|
29 |
|
---|
30 | <screen><userinput>./configure --prefix=/usr</userinput></screen>
|
---|
31 |
|
---|
32 | <para>Compile the package:</para>
|
---|
33 |
|
---|
34 | <screen><userinput>make</userinput></screen>
|
---|
35 |
|
---|
36 | <para>The <userinput>su</userinput> program from Coreutils wasn't installed in
|
---|
37 | Chapter 5 because it needed <emphasis>root</emphasis> privilege to do so. We're
|
---|
38 | going to need it in a few moments for the test suite. Therefore we work around
|
---|
39 | the problem by installing it now:</para>
|
---|
40 |
|
---|
41 | <screen><userinput>make install-root</userinput></screen>
|
---|
42 |
|
---|
43 | <para>This package has a test suite available which can perform a number of
|
---|
44 | checks to ensure it built correctly. However, this particular test suite
|
---|
45 | makes some assumptions with regards to the presence of non-root users and
|
---|
46 | groups that don't apply this early into the LFS build. We therefore create
|
---|
47 | a dummy system user and two dummy groups to allow the tests to run
|
---|
48 | properly. Should you choose not to run the test suite, skip down to
|
---|
49 | "Install the package". The following commands will prepare us for the test
|
---|
50 | suite. Create two dummy groups and a dummy user name:</para>
|
---|
51 |
|
---|
52 | <screen><userinput>echo "dummy1:x:1000" >> /etc/group
|
---|
53 | echo "dummy2:x:1001:dummy" >> /etc/group
|
---|
54 | echo "dummy:x:1000:1000:::/bin/bash" >> /etc/passwd</userinput></screen>
|
---|
55 |
|
---|
56 | <para>Some tests are meant to run as <emphasis>root</emphasis>:</para>
|
---|
57 |
|
---|
58 | <screen><userinput>make check-root</userinput></screen>
|
---|
59 |
|
---|
60 | <para>The remainder of the tests are run as the <emphasis>dummy</emphasis>
|
---|
61 | user:</para>
|
---|
62 |
|
---|
63 | <screen><userinput>su dummy -c "make RUN_EXPENSIVE_TESTS=yes check"</userinput></screen>
|
---|
64 |
|
---|
65 | <para>Remove the dummy groups and user name:</para>
|
---|
66 |
|
---|
67 | <screen><userinput>sed -i.bak '/dummy/d' /etc/passwd /etc/group</userinput></screen>
|
---|
68 |
|
---|
69 | <para>Install the package:</para>
|
---|
70 |
|
---|
71 | <screen><userinput>make install</userinput></screen>
|
---|
72 |
|
---|
73 | <para>And move some programs to their proper locations:</para>
|
---|
74 |
|
---|
75 | <screen><userinput>mv /usr/bin/{basename,cat,chgrp,chmod,chown,cp,dd,df} /bin
|
---|
76 | mv /usr/bin/{date,echo,false,head,install,ln,ls} /bin
|
---|
77 | mv /usr/bin/{mkdir,mknod,mv,pwd,rm,rmdir,sync} /bin
|
---|
78 | mv /usr/bin/{sleep,stty,su,test,touch,true,uname} /bin
|
---|
79 | mv /usr/bin/chroot /usr/sbin</userinput></screen>
|
---|
80 |
|
---|
81 | <para>We'll be using the <filename>kill</filename> program from the Procps
|
---|
82 | package (installed as <filename>/bin/kill</filename> later in the chapter).
|
---|
83 | Remove the one installed by Coreutils:</para>
|
---|
84 |
|
---|
85 | <screen><userinput>rm /usr/bin/kill</userinput></screen>
|
---|
86 |
|
---|
87 | <para>Finally, create a few necessary symlinks:</para>
|
---|
88 |
|
---|
89 | <screen><userinput>ln -s test /bin/[
|
---|
90 | ln -s ../../bin/install /usr/bin</userinput></screen>
|
---|
91 |
|
---|
92 | </sect2>
|
---|
93 |
|
---|
94 | </sect1>
|
---|
95 |
|
---|