From 73aedd1d35747ff2fad4ddf514dca810721a612a Mon Sep 17 00:00:00 2001 From: Alex Gronenwoud Date: Sat, 1 Nov 2003 22:31:50 +0000 Subject: Merging caption and installation sections for all packages in chapters 5 and 6. git-svn-id: http://svn.linuxfromscratch.org/LFS/trunk/BOOK@3052 4aa44e1e-78dd-0310-a6d2-fbcd4c07a689 --- chapter06/autoconf-inst.xml | 24 --------- chapter06/autoconf.xml | 26 +++++++++- chapter06/automake-inst.xml | 28 ----------- chapter06/automake.xml | 31 +++++++++++- chapter06/bash-inst.xml | 34 ------------- chapter06/bash.xml | 37 +++++++++++++- chapter06/binutils-inst.xml | 72 -------------------------- chapter06/binutils.xml | 74 ++++++++++++++++++++++++++- chapter06/bison-inst.xml | 30 ----------- chapter06/bison.xml | 31 +++++++++++- chapter06/bootscripts-inst.xml | 25 --------- chapter06/bootscripts.xml | 26 +++++++++- chapter06/bzip2-inst.xml | 37 -------------- chapter06/bzip2.xml | 40 ++++++++++++++- chapter06/coreutils-inst.xml | 78 ---------------------------- chapter06/coreutils.xml | 79 ++++++++++++++++++++++++++++- chapter06/diffutils-inst.xml | 19 ------- chapter06/diffutils.xml | 21 +++++++- chapter06/e2fsprogs-inst.xml | 55 -------------------- chapter06/e2fsprogs.xml | 57 ++++++++++++++++++++- chapter06/ed-inst.xml | 47 ----------------- chapter06/ed.xml | 49 +++++++++++++++++- chapter06/file-inst.xml | 19 ------- chapter06/file.xml | 20 +++++++- chapter06/findutils-inst.xml | 30 ----------- chapter06/findutils.xml | 32 +++++++++++- chapter06/flex-inst.xml | 45 ----------------- chapter06/flex.xml | 47 ++++++++++++++++- chapter06/gawk-inst.xml | 51 ------------------- chapter06/gawk.xml | 52 ++++++++++++++++++- chapter06/gcc-2953-inst.xml | 51 ------------------- chapter06/gcc-2953.xml | 52 ++++++++++++++++++- chapter06/gcc-inst.xml | 78 ---------------------------- chapter06/gcc.xml | 80 ++++++++++++++++++++++++++++- chapter06/gettext-inst.xml | 25 --------- chapter06/gettext.xml | 27 +++++++++- chapter06/glibc-inst.xml | 110 ---------------------------------------- chapter06/glibc.xml | 112 ++++++++++++++++++++++++++++++++++++++++- chapter06/grep-inst.xml | 26 ---------- chapter06/grep.xml | 28 ++++++++++- chapter06/groff-inst.xml | 31 ------------ chapter06/groff.xml | 32 +++++++++++- chapter06/grub-inst.xml | 41 --------------- chapter06/grub.xml | 43 +++++++++++++++- chapter06/gzip-inst.xml | 34 ------------- chapter06/gzip.xml | 37 +++++++++++++- chapter06/inetutils-inst.xml | 51 ------------------- chapter06/inetutils.xml | 53 ++++++++++++++++++- chapter06/kbd-inst.xml | 25 --------- chapter06/kbd.xml | 26 +++++++++- chapter06/kernel-inst.xml | 61 ---------------------- chapter06/kernel.xml | 63 ++++++++++++++++++++++- chapter06/less-inst.xml | 27 ---------- chapter06/less.xml | 28 ++++++++++- chapter06/lfs-utils-inst.xml | 24 --------- chapter06/lfs-utils.xml | 26 +++++++++- chapter06/libtool-inst.xml | 24 --------- chapter06/libtool.xml | 27 +++++++++- chapter06/m4-inst.xml | 25 --------- chapter06/m4.xml | 26 +++++++++- chapter06/make-inst.xml | 25 --------- chapter06/make.xml | 27 +++++++++- chapter06/makedev-inst.xml | 59 ---------------------- chapter06/makedev.xml | 60 +++++++++++++++++++++- chapter06/man-inst.xml | 62 ----------------------- chapter06/man.xml | 63 ++++++++++++++++++++++- chapter06/manpages-inst.xml | 11 ---- chapter06/manpages.xml | 13 ++++- chapter06/modutils-inst.xml | 19 ------- chapter06/modutils.xml | 21 +++++++- chapter06/ncurses-inst.xml | 48 ------------------ chapter06/ncurses.xml | 49 +++++++++++++++++- chapter06/nettools-inst.xml | 38 -------------- chapter06/nettools.xml | 39 +++++++++++++- chapter06/patch-inst.xml | 22 -------- chapter06/patch.xml | 23 ++++++++- chapter06/perl-inst.xml | 36 ------------- chapter06/perl.xml | 37 +++++++++++++- chapter06/procinfo-inst.xml | 22 -------- chapter06/procinfo.xml | 24 ++++++++- chapter06/procps-inst.xml | 24 --------- chapter06/procps.xml | 26 +++++++++- chapter06/psmisc-inst.xml | 37 -------------- chapter06/psmisc.xml | 39 +++++++++++++- chapter06/sed-inst.xml | 25 --------- chapter06/sed.xml | 27 +++++++++- chapter06/shadowpwd-inst.xml | 105 -------------------------------------- chapter06/shadowpwd.xml | 108 ++++++++++++++++++++++++++++++++++++++- chapter06/sysklogd-inst.xml | 15 ------ chapter06/sysklogd.xml | 18 ++++++- chapter06/sysvinit-inst.xml | 29 ----------- chapter06/sysvinit.xml | 32 +++++++++++- chapter06/tar-inst.xml | 26 ---------- chapter06/tar.xml | 28 ++++++++++- chapter06/texinfo-inst.xml | 37 -------------- chapter06/texinfo.xml | 39 +++++++++++++- chapter06/utillinux-inst.xml | 43 ---------------- chapter06/utillinux.xml | 45 ++++++++++++++++- chapter06/vim-inst.xml | 37 -------------- chapter06/vim.xml | 40 ++++++++++++++- chapter06/zlib-inst.xml | 64 ----------------------- chapter06/zlib.xml | 66 +++++++++++++++++++++++- 102 files changed, 2048 insertions(+), 2069 deletions(-) delete mode 100644 chapter06/autoconf-inst.xml delete mode 100644 chapter06/automake-inst.xml delete mode 100644 chapter06/bash-inst.xml delete mode 100644 chapter06/binutils-inst.xml delete mode 100644 chapter06/bison-inst.xml delete mode 100644 chapter06/bootscripts-inst.xml delete mode 100644 chapter06/bzip2-inst.xml delete mode 100644 chapter06/coreutils-inst.xml delete mode 100644 chapter06/diffutils-inst.xml delete mode 100644 chapter06/e2fsprogs-inst.xml delete mode 100644 chapter06/ed-inst.xml delete mode 100644 chapter06/file-inst.xml delete mode 100644 chapter06/findutils-inst.xml delete mode 100644 chapter06/flex-inst.xml delete mode 100644 chapter06/gawk-inst.xml delete mode 100644 chapter06/gcc-2953-inst.xml delete mode 100644 chapter06/gcc-inst.xml delete mode 100644 chapter06/gettext-inst.xml delete mode 100644 chapter06/glibc-inst.xml delete mode 100644 chapter06/grep-inst.xml delete mode 100644 chapter06/groff-inst.xml delete mode 100644 chapter06/grub-inst.xml delete mode 100644 chapter06/gzip-inst.xml delete mode 100644 chapter06/inetutils-inst.xml delete mode 100644 chapter06/kbd-inst.xml delete mode 100644 chapter06/kernel-inst.xml delete mode 100644 chapter06/less-inst.xml delete mode 100644 chapter06/lfs-utils-inst.xml delete mode 100644 chapter06/libtool-inst.xml delete mode 100644 chapter06/m4-inst.xml delete mode 100644 chapter06/make-inst.xml delete mode 100644 chapter06/makedev-inst.xml delete mode 100644 chapter06/man-inst.xml delete mode 100644 chapter06/manpages-inst.xml delete mode 100644 chapter06/modutils-inst.xml delete mode 100644 chapter06/ncurses-inst.xml delete mode 100644 chapter06/nettools-inst.xml delete mode 100644 chapter06/patch-inst.xml delete mode 100644 chapter06/perl-inst.xml delete mode 100644 chapter06/procinfo-inst.xml delete mode 100644 chapter06/procps-inst.xml delete mode 100644 chapter06/psmisc-inst.xml delete mode 100644 chapter06/sed-inst.xml delete mode 100644 chapter06/shadowpwd-inst.xml delete mode 100644 chapter06/sysklogd-inst.xml delete mode 100644 chapter06/sysvinit-inst.xml delete mode 100644 chapter06/tar-inst.xml delete mode 100644 chapter06/texinfo-inst.xml delete mode 100644 chapter06/utillinux-inst.xml delete mode 100644 chapter06/vim-inst.xml delete mode 100644 chapter06/zlib-inst.xml (limited to 'chapter06') diff --git a/chapter06/autoconf-inst.xml b/chapter06/autoconf-inst.xml deleted file mode 100644 index a0d7ac9e4..000000000 --- a/chapter06/autoconf-inst.xml +++ /dev/null @@ -1,24 +0,0 @@ -   - -Installation of Autoconf - -Prepare Autoconf for compilation: - -./configure --prefix=/usr - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so: - -make check - -And install the package: - -make install - - - diff --git a/chapter06/autoconf.xml b/chapter06/autoconf.xml index 0331a04c9..0d43410fa 100644 --- a/chapter06/autoconf.xml +++ b/chapter06/autoconf.xml @@ -7,6 +7,30 @@ Estimated required disk space: &autoconf-compsize; &aa-autoconf-shortdesc; &aa-autoconf-dep; -&c6-autoconf-inst; + +   + +Installation of Autoconf + +Prepare Autoconf for compilation: + +./configure --prefix=/usr + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so: + +make check + +And install the package: + +make install + + + diff --git a/chapter06/automake-inst.xml b/chapter06/automake-inst.xml deleted file mode 100644 index 97e0452b8..000000000 --- a/chapter06/automake-inst.xml +++ /dev/null @@ -1,28 +0,0 @@ -   - - -Installation of Automake - -Prepare Automake for compilation: - -./configure --prefix=/usr - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so: - -make check - -Install the package: - -make install - -And create a necessary symbolic link: - -ln -s automake-1.7 /usr/share/automake - - diff --git a/chapter06/automake.xml b/chapter06/automake.xml index fb821c3b0..e28116cba 100644 --- a/chapter06/automake.xml +++ b/chapter06/automake.xml @@ -7,6 +7,35 @@ Estimated required disk space: &automake-compsize; &aa-automake-shortdesc; &aa-automake-dep; -&c6-automake-inst; + +   + + +Installation of Automake + +Prepare Automake for compilation: + +./configure --prefix=/usr + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so: + +make check + +Install the package: + +make install + +And create a necessary symbolic link: + +ln -s automake-1.7 /usr/share/automake + + + diff --git a/chapter06/bash-inst.xml b/chapter06/bash-inst.xml deleted file mode 100644 index 6f1a94e7d..000000000 --- a/chapter06/bash-inst.xml +++ /dev/null @@ -1,34 +0,0 @@ -   - - -Installation of Bash - -Bash has a number of bugs in it that cause it to not behave the -way it is expected at times. Fix this behaviour with the following -patch: - -patch -Np1 -i ../&bash-patch; - -Prepare Bash for compilation: - -./configure --prefix=/usr --bindir=/bin - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so: - -make tests - -Install the package: - -make install - -And reload the newly compiled bash program: - -exec /bin/bash --login +h - - diff --git a/chapter06/bash.xml b/chapter06/bash.xml index 4ebebe535..c2703142a 100644 --- a/chapter06/bash.xml +++ b/chapter06/bash.xml @@ -7,6 +7,41 @@ Estimated required disk space: &bash-compsize; &aa-bash-shortdesc; &aa-bash-dep; -&c6-bash-inst; + +   + + +Installation of Bash + +Bash has a number of bugs in it that cause it to not behave the +way it is expected at times. Fix this behaviour with the following +patch: + +patch -Np1 -i ../&bash-patch; + +Prepare Bash for compilation: + +./configure --prefix=/usr --bindir=/bin + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so: + +make tests + +Install the package: + +make install + +And reload the newly compiled bash program: + +exec /bin/bash --login +h + + + diff --git a/chapter06/binutils-inst.xml b/chapter06/binutils-inst.xml deleted file mode 100644 index 81312fe4c..000000000 --- a/chapter06/binutils-inst.xml +++ /dev/null @@ -1,72 +0,0 @@ -   - -Installation of Binutils - -Now is an appropriate time to verify that your pseudo terminals (PTYs) are -working properly inside the chroot environment. We will again quickly check that -everything is set up correctly by performing a simple test: - -expect -c "spawn ls" - -If you receive the message: - -
The system has no more ptys. Ask your system administrator to create more.
- -Your chroot environment is not set up for proper PTY operation. In this -case there is no point in running the test suites for Binutils and GCC until you -are able to resolve the issue. Please refer back to -and and perform the recommended steps to fix the -problem. - -The test suite for Binutils in this section is considered -critical. Our advice is to not skip it under any -circumstances. - -This package is known to behave badly when you have changed its -default optimization flags (including the -march and -mcpu options). -Therefore, if you have defined any environment variables that override -default optimizations, such as CFLAGS and CXXFLAGS, we recommend unsetting -or modifying them when building Binutils. - -The Binutils documentation recommends building Binutils outside of the -source directory in a dedicated build directory: - -mkdir ../binutils-build -cd ../binutils-build - -Now prepare Binutils for compilation: - -../binutils-&binutils-version;/configure \ -    --prefix=/usr --enable-shared - -Compile the package: - -make tooldir=/usr - -Normally, the tooldir (the directory where the -executables end up) is set to $(exec_prefix)/$(target_alias), which expands -into, for example, /usr/i686-pc-linux-gnu. Since we only -build for our own system, we don't need this target specific directory in -/usr. That setup would be used if the system was used to -cross-compile (for example compiling a package on an Intel machine that -generates code that can be executed on PowerPC machines). - -Test the results: - -make check - -The test suite notes from are still -very much appropriate here. Be sure to refer back there should you have any -doubts. - -Install the package: - -make tooldir=/usr install - -Install the libiberty header file that is needed by -some packages: - -cp ../binutils-&binutils-version;/include/libiberty.h /usr/include - -
- diff --git a/chapter06/binutils.xml b/chapter06/binutils.xml index 2acece44f..872fff1ab 100644 --- a/chapter06/binutils.xml +++ b/chapter06/binutils.xml @@ -7,6 +7,78 @@ Estimated required disk space: &binutils-compsize; &aa-binutils-shortdesc; &aa-binutils-dep; -&c6-binutils-inst; + +   + +Installation of Binutils + +Now is an appropriate time to verify that your pseudo terminals (PTYs) are +working properly inside the chroot environment. We will again quickly check that +everything is set up correctly by performing a simple test: + +expect -c "spawn ls" + +If you receive the message: + +
The system has no more ptys. Ask your system administrator to create more.
+ +Your chroot environment is not set up for proper PTY operation. In this +case there is no point in running the test suites for Binutils and GCC until you +are able to resolve the issue. Please refer back to +and and perform the recommended steps to fix the +problem. + +The test suite for Binutils in this section is considered +critical. Our advice is to not skip it under any +circumstances. + +This package is known to behave badly when you have changed its +default optimization flags (including the -march and -mcpu options). +Therefore, if you have defined any environment variables that override +default optimizations, such as CFLAGS and CXXFLAGS, we recommend unsetting +or modifying them when building Binutils. + +The Binutils documentation recommends building Binutils outside of the +source directory in a dedicated build directory: + +mkdir ../binutils-build +cd ../binutils-build + +Now prepare Binutils for compilation: + +../binutils-&binutils-version;/configure \ +    --prefix=/usr --enable-shared + +Compile the package: + +make tooldir=/usr + +Normally, the tooldir (the directory where the +executables end up) is set to $(exec_prefix)/$(target_alias), which expands +into, for example, /usr/i686-pc-linux-gnu. Since we only +build for our own system, we don't need this target specific directory in +/usr. That setup would be used if the system was used to +cross-compile (for example compiling a package on an Intel machine that +generates code that can be executed on PowerPC machines). + +Test the results: + +make check + +The test suite notes from are still +very much appropriate here. Be sure to refer back there should you have any +doubts. + +Install the package: + +make tooldir=/usr install + +Install the libiberty header file that is needed by +some packages: + +cp ../binutils-&binutils-version;/include/libiberty.h /usr/include + +
+ diff --git a/chapter06/bison-inst.xml b/chapter06/bison-inst.xml deleted file mode 100644 index 7240736b1..000000000 --- a/chapter06/bison-inst.xml +++ /dev/null @@ -1,30 +0,0 @@ -   - - -Installation of Bison - -First we use a patch to bison, backported from CVS, which fixes a minor -compilation problem with some packages: - -patch -Np1 -i ../&bison-patch; - -Prepare Bison for compilation: - -./configure --prefix=/usr - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so (and takes a long time): - -make check - -And install the package: - -make install - - - diff --git a/chapter06/bison.xml b/chapter06/bison.xml index 3e469dcc9..e8c2fbf9d 100644 --- a/chapter06/bison.xml +++ b/chapter06/bison.xml @@ -7,7 +7,36 @@ Estimated required disk space: &bison-compsize; &aa-bison-shortdesc; &aa-bison-dep; -&c6-bison-inst; + +   + + +Installation of Bison + +First we use a patch to bison, backported from CVS, which fixes a minor +compilation problem with some packages: + +patch -Np1 -i ../&bison-patch; + +Prepare Bison for compilation: + +./configure --prefix=/usr + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so (and takes a long time): + +make check + +And install the package: + +make install + + diff --git a/chapter06/bootscripts-inst.xml b/chapter06/bootscripts-inst.xml deleted file mode 100644 index ef1e60968..000000000 --- a/chapter06/bootscripts-inst.xml +++ /dev/null @@ -1,25 +0,0 @@ -   - - -Installation of LFS-Bootscripts - -We will be using SysV style init scripts. We have chosen this style -because it is widely used and we feel comfortable with it. If you would prefer -to try something else, Marc Heerdink has written a hint about BSD style init -scripts, to be found at . And if you'd -like something more radical, search the LFS mailing lists for depinit. - -If you decide to use BSD style, or some other style scripts, you can -skip the next chapter when you arrive at it and move on to -. - -Install the boot scripts: - -cp -a rc.d sysconfig /etc - -Give root ownership of the scripts: - -chown -R root:root /etc/rc.d /etc/sysconfig - - - diff --git a/chapter06/bootscripts.xml b/chapter06/bootscripts.xml index 94a44f52f..6c3a21963 100644 --- a/chapter06/bootscripts.xml +++ b/chapter06/bootscripts.xml @@ -7,7 +7,31 @@ Estimated required disk space: &bootscripts-compsize; &aa-bootscripts-shortdesc; &aa-bootscripts-dep; -&c6-bootscripts-inst; + +   + + +Installation of LFS-Bootscripts + +We will be using SysV style init scripts. We have chosen this style +because it is widely used and we feel comfortable with it. If you would prefer +to try something else, Marc Heerdink has written a hint about BSD style init +scripts, to be found at . And if you'd +like something more radical, search the LFS mailing lists for depinit. + +If you decide to use BSD style, or some other style scripts, you can +skip the next chapter when you arrive at it and move on to +. + +Install the boot scripts: + +cp -a rc.d sysconfig /etc + +Give root ownership of the scripts: + +chown -R root:root /etc/rc.d /etc/sysconfig + + diff --git a/chapter06/bzip2-inst.xml b/chapter06/bzip2-inst.xml deleted file mode 100644 index 87d8c361f..000000000 --- a/chapter06/bzip2-inst.xml +++ /dev/null @@ -1,37 +0,0 @@ -   - - -Installation of Bzip2 - -Prepare Bzip2 for compilation with: - -make -f Makefile-libbz2_so -make clean - -The -f flag will cause Bzip2 to be built -using a different Makefile file, in this case the -Makefile-libbz2_so file, which creates a dynamic -libbz2.so library and links the bzip2 utilities -against it. - -Compile the package: - -make - -Install it: - -make install - -And install the shared bzip2 binary into the -/bin directory, then make some -necessary symbolic links, and clean up. - -cp bzip2-shared /bin/bzip2 -cp -a libbz2.so* /lib -ln -s ../../lib/libbz2.so.1.0 /usr/lib/libbz2.so -rm /usr/bin/{bunzip2,bzcat,bzip2} -mv /usr/bin/{bzip2recover,bzless,bzmore} /bin -ln -s bzip2 /bin/bunzip2 -ln -s bzip2 /bin/bzcat - - diff --git a/chapter06/bzip2.xml b/chapter06/bzip2.xml index 0a1bb3540..bc032f049 100644 --- a/chapter06/bzip2.xml +++ b/chapter06/bzip2.xml @@ -7,6 +7,44 @@ Estimated required disk space: &bzip2-compsize; &aa-bzip2-shortdesc; &aa-bzip2-dep; -&c6-bzip2-inst; + +   + + +Installation of Bzip2 + +Prepare Bzip2 for compilation with: + +make -f Makefile-libbz2_so +make clean + +The -f flag will cause Bzip2 to be built +using a different Makefile file, in this case the +Makefile-libbz2_so file, which creates a dynamic +libbz2.so library and links the bzip2 utilities +against it. + +Compile the package: + +make + +Install it: + +make install + +And install the shared bzip2 binary into the +/bin directory, then make some +necessary symbolic links, and clean up. + +cp bzip2-shared /bin/bzip2 +cp -a libbz2.so* /lib +ln -s ../../lib/libbz2.so.1.0 /usr/lib/libbz2.so +rm /usr/bin/{bunzip2,bzcat,bzip2} +mv /usr/bin/{bzip2recover,bzless,bzmore} /bin +ln -s bzip2 /bin/bunzip2 +ln -s bzip2 /bin/bzcat + + + diff --git a/chapter06/coreutils-inst.xml b/chapter06/coreutils-inst.xml deleted file mode 100644 index ad17757ee..000000000 --- a/chapter06/coreutils-inst.xml +++ /dev/null @@ -1,78 +0,0 @@ -   - - -Installation of Coreutils - -Normally the functionality of uname is somewhat -broken, in that the -p switch always returns "unknown". -The following patch fixes this behaviour for Intel architectures: - -patch -Np1 -i ../&coreutils-uname-patch; - -We do not want Coreutils to install its version of the -hostname program, because it is inferior to the version -provided by Net-tools. Prevent its installation by applying a patch: - -patch -Np1 -i ../&coreutils-hostname-patch; - -Now prepare Coreutils for compilation: - -./configure --prefix=/usr - -Compile the package: - -make - -The su program from Coreutils wasn't installed in -Chapter 5 because it needed root privilege to do so. We're -going to need it in a few moments for the test suite. Therefore we work around -the problem by installing it now: - -make install-root - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. However, this particular test suite -makes some assumptions with regards to the presence of non-root users and -groups that don't apply this early into the LFS build. We therefore create -a dummy system user and two dummy groups to allow the tests to run -properly. Should you choose not to run the test suite, skip down to -"Install the package". The following commands will prepare us for the test -suite. Create two dummy groups and a dummy user name: - -echo "dummy1:x:1000" >> /etc/group -echo "dummy2:x:1001:dummy" >> /etc/group -echo "dummy:x:1000:1000:::/bin/bash" >> /etc/passwd - -Some tests are meant to run as root: - -make check-root - -The remainder of the tests are run as the dummy -user: - -su dummy -c "make RUN_EXPENSIVE_TESTS=yes check" - -Remove the dummy groups and user name: - -sed -i.bak '/dummy/d' /etc/passwd /etc/group - -Install the package: - -make install - -And move some programs to their proper locations: - -mv /usr/bin/{basename,cat,chgrp,chmod,chown,cp,dd,df} /bin -mv /usr/bin/{dir,dircolors,du,date,echo,false,head} /bin -mv /usr/bin/{install,ln,ls,mkdir,mkfifo,mknod,mv,pwd} /bin -mv /usr/bin/{rm,rmdir,shred,sync,sleep,stty,su,test} /bin -mv /usr/bin/{touch,true,uname,vdir} /bin -mv /usr/bin/chroot /usr/sbin - -Finally, create a few necessary symlinks: - -ln -s test /bin/[ -ln -s ../../bin/install /usr/bin - - - diff --git a/chapter06/coreutils.xml b/chapter06/coreutils.xml index 1ee2c812d..7eeaa69a3 100644 --- a/chapter06/coreutils.xml +++ b/chapter06/coreutils.xml @@ -7,7 +7,84 @@ Estimated required disk space: &coreutils-compsize; &aa-coreutils-shortdesc; &aa-coreutils-dep; -&c6-coreutils-inst; + +   + + +Installation of Coreutils + +Normally the functionality of uname is somewhat +broken, in that the -p switch always returns "unknown". +The following patch fixes this behaviour for Intel architectures: + +patch -Np1 -i ../&coreutils-uname-patch; + +We do not want Coreutils to install its version of the +hostname program, because it is inferior to the version +provided by Net-tools. Prevent its installation by applying a patch: + +patch -Np1 -i ../&coreutils-hostname-patch; + +Now prepare Coreutils for compilation: + +./configure --prefix=/usr + +Compile the package: + +make + +The su program from Coreutils wasn't installed in +Chapter 5 because it needed root privilege to do so. We're +going to need it in a few moments for the test suite. Therefore we work around +the problem by installing it now: + +make install-root + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. However, this particular test suite +makes some assumptions with regards to the presence of non-root users and +groups that don't apply this early into the LFS build. We therefore create +a dummy system user and two dummy groups to allow the tests to run +properly. Should you choose not to run the test suite, skip down to +"Install the package". The following commands will prepare us for the test +suite. Create two dummy groups and a dummy user name: + +echo "dummy1:x:1000" >> /etc/group +echo "dummy2:x:1001:dummy" >> /etc/group +echo "dummy:x:1000:1000:::/bin/bash" >> /etc/passwd + +Some tests are meant to run as root: + +make check-root + +The remainder of the tests are run as the dummy +user: + +su dummy -c "make RUN_EXPENSIVE_TESTS=yes check" + +Remove the dummy groups and user name: + +sed -i.bak '/dummy/d' /etc/passwd /etc/group + +Install the package: + +make install + +And move some programs to their proper locations: + +mv /usr/bin/{basename,cat,chgrp,chmod,chown,cp,dd,df} /bin +mv /usr/bin/{dir,dircolors,du,date,echo,false,head} /bin +mv /usr/bin/{install,ln,ls,mkdir,mkfifo,mknod,mv,pwd} /bin +mv /usr/bin/{rm,rmdir,shred,sync,sleep,stty,su,test} /bin +mv /usr/bin/{touch,true,uname,vdir} /bin +mv /usr/bin/chroot /usr/sbin + +Finally, create a few necessary symlinks: + +ln -s test /bin/[ +ln -s ../../bin/install /usr/bin + + diff --git a/chapter06/diffutils-inst.xml b/chapter06/diffutils-inst.xml deleted file mode 100644 index fc5805f28..000000000 --- a/chapter06/diffutils-inst.xml +++ /dev/null @@ -1,19 +0,0 @@ -   - - -Installation of Diffutils - -Prepare Diffutils for compilation: - -./configure --prefix=/usr - -Compile the package: - -make - -And install it: - -make install - - - diff --git a/chapter06/diffutils.xml b/chapter06/diffutils.xml index 57c834a41..321081944 100644 --- a/chapter06/diffutils.xml +++ b/chapter06/diffutils.xml @@ -7,6 +7,25 @@ Estimated required disk space: &diffutils-compsize; &aa-diffutils-shortdesc; &aa-diffutils-dep; -&c6-diffutils-inst; + +   + + +Installation of Diffutils + +Prepare Diffutils for compilation: + +./configure --prefix=/usr + +Compile the package: + +make + +And install it: + +make install + + + diff --git a/chapter06/e2fsprogs-inst.xml b/chapter06/e2fsprogs-inst.xml deleted file mode 100644 index c5124729d..000000000 --- a/chapter06/e2fsprogs-inst.xml +++ /dev/null @@ -1,55 +0,0 @@ -   - - -Installation of E2fsprogs - -It is recommended to build E2fsprogs outside of the -source tree: - -mkdir ../e2fsprogs-build -cd ../e2fsprogs-build - -Prepare E2fsprogs for compilation: - -../e2fsprogs-&e2fsprogs-version;/configure --prefix=/usr --with-root-prefix="" \ -    --enable-elf-shlibs - -The meaning of the configure options: - - ---with-root-prefix="": Certain -programs (such as the e2fsck program) are considered essential programs. -When, for example, /usr isn't -mounted, these essential program have to be available. They belong in -directories like /lib and -/sbin. If this option isn't passed -to E2fsprogs's configure, the programs are placed in the -/usr directory, which is not what we -want. - ---enable-elf-shlibs: This creates -the shared libraries which some programs in this package make use -of. - - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so: - -make check - -Install most of the package: - -make install - -And install also the shared libraries: - -make install-libs - - - - diff --git a/chapter06/e2fsprogs.xml b/chapter06/e2fsprogs.xml index 412e99fe6..d9ff51cb9 100644 --- a/chapter06/e2fsprogs.xml +++ b/chapter06/e2fsprogs.xml @@ -7,6 +7,61 @@ Estimated required disk space: &e2fsprogs-compsize; &aa-e2fsprogs-shortdesc; &aa-e2fsprogs-dep; -&c6-e2fsprogs-inst; + +   + + +Installation of E2fsprogs + +It is recommended to build E2fsprogs outside of the +source tree: + +mkdir ../e2fsprogs-build +cd ../e2fsprogs-build + +Prepare E2fsprogs for compilation: + +../e2fsprogs-&e2fsprogs-version;/configure --prefix=/usr --with-root-prefix="" \ +    --enable-elf-shlibs + +The meaning of the configure options: + + +--with-root-prefix="": Certain +programs (such as the e2fsck program) are considered essential programs. +When, for example, /usr isn't +mounted, these essential program have to be available. They belong in +directories like /lib and +/sbin. If this option isn't passed +to E2fsprogs's configure, the programs are placed in the +/usr directory, which is not what we +want. + +--enable-elf-shlibs: This creates +the shared libraries which some programs in this package make use +of. + + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so: + +make check + +Install most of the package: + +make install + +And install also the shared libraries: + +make install-libs + + + + diff --git a/chapter06/ed-inst.xml b/chapter06/ed-inst.xml deleted file mode 100644 index bc0e6cfa9..000000000 --- a/chapter06/ed-inst.xml +++ /dev/null @@ -1,47 +0,0 @@ -   - - -Installation of Ed - -Ed isn't something which many people use. It's installed here -because it can be used by the patch program if you encounter an ed-based patch -file. This happens rarely because diff-based patches are preferred these -days. - -Ed normally uses the mktemp function to create temporary files in -/tmp, but this function contains a -vulnerability (see the section on Temporary Files in ). The -following patch makes Ed use mkstemp instead, which is the recommended way to -create temporary files. - -Apply the patch: - -patch -Np1 -i ../&ed-patch; - -Now prepare Ed for compilation: - -./configure --prefix=/usr - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so: - -make check - -Install the package: - -make install - -And move the programs to the /bin directory, so -they can be used in the event that the /usr partition is -unavailable. - -mv /usr/bin/{ed,red} /bin - - - diff --git a/chapter06/ed.xml b/chapter06/ed.xml index e5a0c3100..078f0a45a 100644 --- a/chapter06/ed.xml +++ b/chapter06/ed.xml @@ -7,8 +7,53 @@ Estimated required disk space: &ed-compsize; &aa-ed-shortdesc; &aa-ed-dep; -&c6-ed-inst; - +   + + +Installation of Ed + +Ed isn't something which many people use. It's installed here +because it can be used by the patch program if you encounter an ed-based patch +file. This happens rarely because diff-based patches are preferred these +days. + +Ed normally uses the mktemp function to create temporary files in +/tmp, but this function contains a +vulnerability (see the section on Temporary Files in ). The +following patch makes Ed use mkstemp instead, which is the recommended way to +create temporary files. + +Apply the patch: + +patch -Np1 -i ../&ed-patch; + +Now prepare Ed for compilation: + +./configure --prefix=/usr + +Compile the package: +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so: + +make check + +Install the package: + +make install + +And move the programs to the /bin directory, so +they can be used in the event that the /usr partition is +unavailable. + +mv /usr/bin/{ed,red} /bin + + + + diff --git a/chapter06/file-inst.xml b/chapter06/file-inst.xml deleted file mode 100644 index 10d578295..000000000 --- a/chapter06/file-inst.xml +++ /dev/null @@ -1,19 +0,0 @@ -   - - -Installation of File - -Prepare File for compilation: - -./configure --prefix=/usr - -Compile the package: - -make - -And install it: - -make install - - - diff --git a/chapter06/file.xml b/chapter06/file.xml index db2ada676..d21b96286 100644 --- a/chapter06/file.xml +++ b/chapter06/file.xml @@ -7,7 +7,25 @@ Estimated required disk space: &file-compsize; &aa-file-shortdesc; &aa-file-dep; -&c6-file-inst; + +   + + +Installation of File + +Prepare File for compilation: + +./configure --prefix=/usr + +Compile the package: + +make + +And install it: + +make install + + diff --git a/chapter06/findutils-inst.xml b/chapter06/findutils-inst.xml deleted file mode 100644 index e2aa65266..000000000 --- a/chapter06/findutils-inst.xml +++ /dev/null @@ -1,30 +0,0 @@ -   - - -Installing Findutils - -Prepare Findutils for compilation: - -./configure --prefix=/usr --libexecdir=/usr/bin - -By default, the location of the updatedb database is in -/usr/var. To make the location of -/var/lib/misc/locatedb file FHS compliant, pass the ---localstatedir=/var/lib/misc option to -configure. - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so: - -make check - -And install the package: - -make install - - diff --git a/chapter06/findutils.xml b/chapter06/findutils.xml index 6918deb5e..5d527b2ee 100644 --- a/chapter06/findutils.xml +++ b/chapter06/findutils.xml @@ -7,7 +7,37 @@ Estimated required disk space: &findutils-compsize; &aa-findutils-shortdesc; &aa-findutils-dep; -&c6-findutils-inst; + +   + + +Installing Findutils + +Prepare Findutils for compilation: + +./configure --prefix=/usr --libexecdir=/usr/bin + +By default, the location of the updatedb database is in +/usr/var. To make the location of +/var/lib/misc/locatedb file FHS compliant, pass the +--localstatedir=/var/lib/misc option to +configure. + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so: + +make check + +And install the package: + +make install + + diff --git a/chapter06/flex-inst.xml b/chapter06/flex-inst.xml deleted file mode 100644 index 2681eb7ce..000000000 --- a/chapter06/flex-inst.xml +++ /dev/null @@ -1,45 +0,0 @@ -   - - -Installation of Flex - -Prepare Flex for compilation: - -./configure --prefix=/usr - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so: - -make bigcheck - -And install the package: - -make install - -There are some packages that expect to find the Lex library in -/usr/lib. Create a symlink to account for this: - -ln -s libfl.a /usr/lib/libl.a - -A few programs don't know about flex yet and try -to run its predecessor lex. To support those programs, -create a shell script named lex that calls -flex in Lex emulation mode: - -cat > /usr/bin/lex << "EOF" -#!/bin/sh -# Begin /usr/bin/lex - -exec /usr/bin/flex -l "$@" - -# End /usr/bin/lex -EOF -chmod 755 /usr/bin/lex - - - diff --git a/chapter06/flex.xml b/chapter06/flex.xml index bf7ddd59f..d202df991 100644 --- a/chapter06/flex.xml +++ b/chapter06/flex.xml @@ -7,6 +7,51 @@ Estimated required disk space: &flex-compsize; &aa-flex-shortdesc; &aa-flex-dep; -&c6-flex-inst; + +   + + +Installation of Flex + +Prepare Flex for compilation: + +./configure --prefix=/usr + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so: + +make bigcheck + +And install the package: + +make install + +There are some packages that expect to find the Lex library in +/usr/lib. Create a symlink to account for this: + +ln -s libfl.a /usr/lib/libl.a + +A few programs don't know about flex yet and try +to run its predecessor lex. To support those programs, +create a shell script named lex that calls +flex in Lex emulation mode: + +cat > /usr/bin/lex << "EOF" +#!/bin/sh +# Begin /usr/bin/lex + +exec /usr/bin/flex -l "$@" + +# End /usr/bin/lex +EOF +chmod 755 /usr/bin/lex + + + diff --git a/chapter06/gawk-inst.xml b/chapter06/gawk-inst.xml deleted file mode 100644 index d5b5dd9d7..000000000 --- a/chapter06/gawk-inst.xml +++ /dev/null @@ -1,51 +0,0 @@ -   - - -Installation of Gawk - -First apply a patch to fix the following issues: - - -Gawk's default location for some of its executables is -$prefix/libexec/awk. This location doesn't comply -with the FHS, which never even mentions a directory called -libexec. The patch makes it possible to pass a ---libexecdir switch to the configure script, so that we -can use a more appropriate location for the grcat and -pwcat binaries: -/usr/bin. - -Gawk's default data directory is -$prefix/share/awk. But package-specific -directories should be named using the package name and version number -(for example: gawk-7.7.2.) and not simply the package -name, as there may be different versions of a package installed on the system. -The patch changes the name of the data directory to the correct -$prefix/share/gawk-&gawk-version;. - -The patch also ensures that this data directory, including its -contents, is removed on a make uninstall. - - -patch -Np1 -i ../&gawk-patch; - -Now prepare Gawk for compilation: - -./configure --prefix=/usr --libexecdir=/usr/bin - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so: - -make check - -And install the package: - -make install - - - diff --git a/chapter06/gawk.xml b/chapter06/gawk.xml index 15d58ccf9..e1989f21c 100644 --- a/chapter06/gawk.xml +++ b/chapter06/gawk.xml @@ -7,7 +7,57 @@ Estimated required disk space: &gawk-compsize; &aa-gawk-shortdesc; &aa-gawk-dep; -&c6-gawk-inst; + +   + + +Installation of Gawk + +First apply a patch to fix the following issues: + + +Gawk's default location for some of its executables is +$prefix/libexec/awk. This location doesn't comply +with the FHS, which never even mentions a directory called +libexec. The patch makes it possible to pass a +--libexecdir switch to the configure script, so that we +can use a more appropriate location for the grcat and +pwcat binaries: +/usr/bin. + +Gawk's default data directory is +$prefix/share/awk. But package-specific +directories should be named using the package name and version number +(for example: gawk-7.7.2.) and not simply the package +name, as there may be different versions of a package installed on the system. +The patch changes the name of the data directory to the correct +$prefix/share/gawk-&gawk-version;. + +The patch also ensures that this data directory, including its +contents, is removed on a make uninstall. + + +patch -Np1 -i ../&gawk-patch; + +Now prepare Gawk for compilation: + +./configure --prefix=/usr --libexecdir=/usr/bin + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so: + +make check + +And install the package: + +make install + + diff --git a/chapter06/gcc-2953-inst.xml b/chapter06/gcc-2953-inst.xml deleted file mode 100644 index 782f708bc..000000000 --- a/chapter06/gcc-2953-inst.xml +++ /dev/null @@ -1,51 +0,0 @@ -   - - -Installation of GCC - -This package is known to behave badly when you have changed its -default optimization flags (including the -march and -mcpu options). -Therefore, if you have defined any environment variables that override -default optimizations, such as CFLAGS and CXXFLAGS, we recommend unsetting -or modifying them when building GCC. - -This is an older release of GCC which we are going to install for the -purpose of compiling the Linux kernel in . This -version is recommended -by the kernel developers when you need absolute stability. Later versions of -GCC have not received as much testing for Linux kernel compilation. Using a -later version is likely to work, however, we recommend adhering to the kernel -developer's advice and using the version here to compile your kernel. - -We don't install the C++ compiler or libraries here. However, there -may be reasons why you would want to install them. More information can be found -at . - -We'll install this older release of GCC into the non-standard prefix of -/opt so as to avoid interfering with -the system GCC already installed in /usr - . - -Apply the patches and make a small adjustment: - -patch -Np1 -i ../&gcc-2953-patch; -patch -Np1 -i ../&gcc-2953-no-fixinc-patch; -patch -Np1 -i ../&gcc-2953-returntype-fix-patch; -echo timestamp > gcc/cstamp-h.in - -The GCC documentation recommends building GCC outside of the source -directory in a dedicated build directory: - -mkdir ../gcc-2-build -cd ../gcc-2-build - -Compile and install gcc: - -../gcc-2.95.3/configure --prefix=/opt/gcc-2.95.3 \ -    --enable-shared --enable-languages=c \ -    --enable-threads=posix -make bootstrap -make install - - - diff --git a/chapter06/gcc-2953.xml b/chapter06/gcc-2953.xml index 0afac9ae7..f0f196ada 100644 --- a/chapter06/gcc-2953.xml +++ b/chapter06/gcc-2953.xml @@ -5,7 +5,57 @@ Estimated build time: &gcc-2953-time; Estimated required disk space: &gcc-2953-compsize; -&c6-gcc-2953-inst; + +   + + +Installation of GCC + +This package is known to behave badly when you have changed its +default optimization flags (including the -march and -mcpu options). +Therefore, if you have defined any environment variables that override +default optimizations, such as CFLAGS and CXXFLAGS, we recommend unsetting +or modifying them when building GCC. + +This is an older release of GCC which we are going to install for the +purpose of compiling the Linux kernel in . This +version is recommended +by the kernel developers when you need absolute stability. Later versions of +GCC have not received as much testing for Linux kernel compilation. Using a +later version is likely to work, however, we recommend adhering to the kernel +developer's advice and using the version here to compile your kernel. + +We don't install the C++ compiler or libraries here. However, there +may be reasons why you would want to install them. More information can be found +at . + +We'll install this older release of GCC into the non-standard prefix of +/opt so as to avoid interfering with +the system GCC already installed in /usr + . + +Apply the patches and make a small adjustment: + +patch -Np1 -i ../&gcc-2953-patch; +patch -Np1 -i ../&gcc-2953-no-fixinc-patch; +patch -Np1 -i ../&gcc-2953-returntype-fix-patch; +echo timestamp > gcc/cstamp-h.in + +The GCC documentation recommends building GCC outside of the source +directory in a dedicated build directory: + +mkdir ../gcc-2-build +cd ../gcc-2-build + +Compile and install gcc: + +../gcc-2.95.3/configure --prefix=/opt/gcc-2.95.3 \ +    --enable-shared --enable-languages=c \ +    --enable-threads=posix +make bootstrap +make install + + diff --git a/chapter06/gcc-inst.xml b/chapter06/gcc-inst.xml deleted file mode 100644 index 835df60b6..000000000 --- a/chapter06/gcc-inst.xml +++ /dev/null @@ -1,78 +0,0 @@ -   - - -Installation of GCC - -The test suite for GCC in this section is considered -critical. Our advice is to not skip it under any -circumstance. - -This package is known to behave badly when you have changed its -default optimization flags (including the -march and -mcpu options). -Therefore, if you have defined any environment variables that override -default optimizations, such as CFLAGS and CXXFLAGS, we recommend unsetting -or modifying them when building GCC. - -This time we will build both the C and the C++ compiler, so you'll have -to unpack the GCC-core and the GCC-g++ tarball -- they -will unfold into the same directory. You should likewise extract the -GCC-testsuite package. The full GCC package contains even more -compilers. Instructions for building these can be found at -. - -patch -Np1 -i ../&gcc-nofixincludes-patch; -patch -Np1 -i ../&gcc-suppress-libiberty-patch; - -The second patch here suppresses the installation of libiberty from GCC, -as we will use the one provided by binutils instead. Be careful -not to apply the GCC specs patch from Chapter 5 -here. - -The GCC documentation recommends building GCC outside of the source -directory in a dedicated build directory: - -mkdir ../gcc-build -cd ../gcc-build - -Now prepare GCC for compilation: - -../gcc-&gcc-version;/configure --prefix=/usr \ -    --enable-shared --enable-threads=posix \ -    --enable-__cxa_atexit --enable-clocale=gnu \ -    --enable-languages=c,c++ - -Compile the package: - -make - -Test the results, but don't stop at errors (you'll remember the few -known ones): - -make -k check - -The test suite notes from are still very -much appropriate here. Be sure to refer back there should you have any -doubts. - -And install the package: - -make install - -Some packages expect the C PreProcessor to be installed in the -/lib directory. -To honor those packages, create this symlink: - -ln -s ../usr/bin/cpp /lib - -Many packages use the name cc to call the C -compiler. To satisfy those packages, create a symlink: - -ln -s gcc /usr/bin/cc - -At this point it is strongly recommended to repeat the sanity check -we performed earlier in this chapter. Refer back to - and repeat the check. If the results -are wrong, then most likely you erroneously applied the GCC Specs patch from -Chapter 5. - - diff --git a/chapter06/gcc.xml b/chapter06/gcc.xml index dd141c817..54a105db1 100644 --- a/chapter06/gcc.xml +++ b/chapter06/gcc.xml @@ -7,7 +7,85 @@ Estimated required disk space: &gcc-compsize; &aa-gcc-shortdesc; &aa-gcc-dep; -&c6-gcc-inst; + +   + + +Installation of GCC + +The test suite for GCC in this section is considered +critical. Our advice is to not skip it under any +circumstance. + +This package is known to behave badly when you have changed its +default optimization flags (including the -march and -mcpu options). +Therefore, if you have defined any environment variables that override +default optimizations, such as CFLAGS and CXXFLAGS, we recommend unsetting +or modifying them when building GCC. + +This time we will build both the C and the C++ compiler, so you'll have +to unpack the GCC-core and the GCC-g++ tarball -- they +will unfold into the same directory. You should likewise extract the +GCC-testsuite package. The full GCC package contains even more +compilers. Instructions for building these can be found at +. + +patch -Np1 -i ../&gcc-nofixincludes-patch; +patch -Np1 -i ../&gcc-suppress-libiberty-patch; + +The second patch here suppresses the installation of libiberty from GCC, +as we will use the one provided by binutils instead. Be careful +not to apply the GCC specs patch from Chapter 5 +here. + +The GCC documentation recommends building GCC outside of the source +directory in a dedicated build directory: + +mkdir ../gcc-build +cd ../gcc-build + +Now prepare GCC for compilation: + +../gcc-&gcc-version;/configure --prefix=/usr \ +    --enable-shared --enable-threads=posix \ +    --enable-__cxa_atexit --enable-clocale=gnu \ +    --enable-languages=c,c++ + +Compile the package: + +make + +Test the results, but don't stop at errors (you'll remember the few +known ones): + +make -k check + +The test suite notes from are still very +much appropriate here. Be sure to refer back there should you have any +doubts. + +And install the package: + +make install + +Some packages expect the C PreProcessor to be installed in the +/lib directory. +To honor those packages, create this symlink: + +ln -s ../usr/bin/cpp /lib + +Many packages use the name cc to call the C +compiler. To satisfy those packages, create a symlink: + +ln -s gcc /usr/bin/cc + +At this point it is strongly recommended to repeat the sanity check +we performed earlier in this chapter. Refer back to + and repeat the check. If the results +are wrong, then most likely you erroneously applied the GCC Specs patch from +Chapter 5. + + diff --git a/chapter06/gettext-inst.xml b/chapter06/gettext-inst.xml deleted file mode 100644 index 47c1fcc1c..000000000 --- a/chapter06/gettext-inst.xml +++ /dev/null @@ -1,25 +0,0 @@ -   - - -Installation of Gettext - -Prepare Gettext for compilation: - -./configure --prefix=/usr - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so (and takes a very long time): - -make check - -And install the package: - -make install - - - diff --git a/chapter06/gettext.xml b/chapter06/gettext.xml index 1c240346d..63d473121 100644 --- a/chapter06/gettext.xml +++ b/chapter06/gettext.xml @@ -7,6 +7,31 @@ Estimated required disk space: &gettext-compsize; &aa-gettext-shortdesc; &aa-gettext-dep; -&c6-gettext-inst; + +   + + +Installation of Gettext + +Prepare Gettext for compilation: + +./configure --prefix=/usr + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so (and takes a very long time): + +make check + +And install the package: + +make install + + + diff --git a/chapter06/glibc-inst.xml b/chapter06/glibc-inst.xml deleted file mode 100644 index a10cc9347..000000000 --- a/chapter06/glibc-inst.xml +++ /dev/null @@ -1,110 +0,0 @@ -   - - -Glibc installation - -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 /tools. 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. - -The test suite for Glibc in this section is considered -critical. Our advice is to not skip it under any -circumstance. - -Before starting to build Glibc, remember to unpack the Glibc-linuxthreads -again inside the glibc-&glibc-version; directory, and to -unset any environment variables that override the default optimization -flags. - -Though it is a harmless message, the install stage of Glibc will -complain about the absence of /etc/ld.so.conf. Fix this -annoying little warning with: - -touch /etc/ld.so.conf - -Then apply the same patch we used previously: - -patch -Np1 -i ../&glibc-sscanf-patch; - -The Glibc documentation recommends building Glibc outside of the source -directory in a dedicated build directory: - -mkdir ../glibc-build -cd ../glibc-build - -Now prepare Glibc for compilation: - -../glibc-&glibc-version;/configure --prefix=/usr \ -    --disable-profile --enable-add-ons \ -    --libexecdir=/usr/bin --with-headers=/usr/include - -The meaning of the new configure options: - - ---libexecdir=/usr/bin: This will -cause the pt_chown program to be installed in the -/usr/bin directory. - ---with-headers=/usr/include: This -ensures that the kernel headers in /usr/include are used -for this build. If you don't pass this switch then the headers from -/tools/include 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 /usr/include. - - -Compile the package: - -make - -Test the results: - -make check - -The test suite notes from are still very much -appropriate here. Be sure to refer back there should you have any doubts. - -And install the package: - -make install - -The locales that can make your system respond in a different language -weren't installed by the above command. Do it with this: - -make localedata/install-locales - -An alternative to running the previous command is to install only those -locales which you need or want. This can be achieved using the -localedef command. Information on this can be found in -the INSTALL file in the -glibc-&glibc-version; tree. However, there are a number -of locales that are essential for the tests of future packages to pass -correctly. The following instructions, in place of the install-locales -command above, will install the minimum set of locales necessary for the -tests to run successfully: - -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 - -Finally, build the linuxthreads man pages: - -make -C ../&glibc-dir;/linuxthreads/man - -And install these pages: - -make -C ../&glibc-dir;/linuxthreads/man install - - - diff --git a/chapter06/glibc.xml b/chapter06/glibc.xml index 5567defe8..0ee7f3f5b 100644 --- a/chapter06/glibc.xml +++ b/chapter06/glibc.xml @@ -7,8 +7,116 @@ Estimated required disk space: &glibc-compsize; &aa-glibc-shortdesc; &aa-glibc-dep; -&c6-glibc-inst; -&c6-cf-glibc; + +   + + +Glibc installation + +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 /tools. 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. + +The test suite for Glibc in this section is considered +critical. Our advice is to not skip it under any +circumstance. + +Before starting to build Glibc, remember to unpack the Glibc-linuxthreads +again inside the glibc-&glibc-version; directory, and to +unset any environment variables that override the default optimization +flags. + +Though it is a harmless message, the install stage of Glibc will +complain about the absence of /etc/ld.so.conf. Fix this +annoying little warning with: + +touch /etc/ld.so.conf + +Then apply the same patch we used previously: + +patch -Np1 -i ../&glibc-sscanf-patch; + +The Glibc documentation recommends building Glibc outside of the source +directory in a dedicated build directory: + +mkdir ../glibc-build +cd ../glibc-build + +Now prepare Glibc for compilation: + +../glibc-&glibc-version;/configure --prefix=/usr \ +    --disable-profile --enable-add-ons \ +    --libexecdir=/usr/bin --with-headers=/usr/include + +The meaning of the new configure options: + + +--libexecdir=/usr/bin: This will +cause the pt_chown program to be installed in the +/usr/bin directory. + +--with-headers=/usr/include: This +ensures that the kernel headers in /usr/include are used +for this build. If you don't pass this switch then the headers from +/tools/include 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 /usr/include. + + +Compile the package: + +make + +Test the results: + +make check + +The test suite notes from are still very much +appropriate here. Be sure to refer back there should you have any doubts. + +And install the package: + +make install + +The locales that can make your system respond in a different language +weren't installed by the above command. Do it with this: + +make localedata/install-locales + +An alternative to running the previous command is to install only those +locales which you need or want. This can be achieved using the +localedef command. Information on this can be found in +the INSTALL file in the +glibc-&glibc-version; tree. However, there are a number +of locales that are essential for the tests of future packages to pass +correctly. The following instructions, in place of the install-locales +command above, will install the minimum set of locales necessary for the +tests to run successfully: + +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 + +Finally, build the linuxthreads man pages: + +make -C ../&glibc-dir;/linuxthreads/man + +And install these pages: + +make -C ../&glibc-dir;/linuxthreads/man install + + diff --git a/chapter06/grep-inst.xml b/chapter06/grep-inst.xml deleted file mode 100644 index 5957f5e99..000000000 --- a/chapter06/grep-inst.xml +++ /dev/null @@ -1,26 +0,0 @@ -   - - -Installation of Grep - -Prepare Grep for compilation: - -./configure --prefix=/usr --bindir=/bin \ -    --with-included-regex - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so: - -make check - -And install the package: - -make install - - - diff --git a/chapter06/grep.xml b/chapter06/grep.xml index d764ecd27..a68e7a271 100644 --- a/chapter06/grep.xml +++ b/chapter06/grep.xml @@ -7,6 +7,32 @@ Estimated required disk space: &grep-compsize; &aa-grep-shortdesc; &aa-grep-dep; -&c6-grep-inst; + +   + + +Installation of Grep + +Prepare Grep for compilation: + +./configure --prefix=/usr --bindir=/bin \ +    --with-included-regex + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so: + +make check + +And install the package: + +make install + + + diff --git a/chapter06/groff-inst.xml b/chapter06/groff-inst.xml deleted file mode 100644 index 7b2afb1a3..000000000 --- a/chapter06/groff-inst.xml +++ /dev/null @@ -1,31 +0,0 @@ -   - - -Installation of Groff - -Groff expects the environment variable PAGE to contain the default paper -size. For those in the United States, the command below is appropriate. If you -live elsewhere, you may want to change PAGE=letter to -PAGE=A4. - -Prepare Groff for compilation: - -PAGE=letter ./configure --prefix=/usr - -Compile the package: - -make - -And install it: - -make install - -Some documentation programs, such as xman, -will not work work properly without the following symlinks: - -ln -s soelim /usr/bin/zsoelim -ln -s eqn /usr/bin/geqn -ln -s tbl /usr/bin/gtbl - - - diff --git a/chapter06/groff.xml b/chapter06/groff.xml index 6699b0c81..4c3531fd9 100644 --- a/chapter06/groff.xml +++ b/chapter06/groff.xml @@ -7,7 +7,37 @@ Estimated required disk space: &groff-compsize; &aa-groff-shortdesc; &aa-groff-dep; -&c6-groff-inst; + +   + + +Installation of Groff + +Groff expects the environment variable PAGE to contain the default paper +size. For those in the United States, the command below is appropriate. If you +live elsewhere, you may want to change PAGE=letter to +PAGE=A4. + +Prepare Groff for compilation: + +PAGE=letter ./configure --prefix=/usr + +Compile the package: + +make + +And install it: + +make install + +Some documentation programs, such as xman, +will not work work properly without the following symlinks: + +ln -s soelim /usr/bin/zsoelim +ln -s eqn /usr/bin/geqn +ln -s tbl /usr/bin/gtbl + + diff --git a/chapter06/grub-inst.xml b/chapter06/grub-inst.xml deleted file mode 100644 index 748de1fbc..000000000 --- a/chapter06/grub-inst.xml +++ /dev/null @@ -1,41 +0,0 @@ -   - - -Installation of Grub - -This package is known to behave badly when you have changed its default -optimization flags (including the -march and -mcpu options). Therefore, if you -have defined any environment variables that override default optimizations, -such as CFLAGS and CXXFLAGS, we recommend unsetting them when building -Grub. - -Grub needs a patch to fix a compilation problem with GCC-&gcc-version; - -patch -Np1 -i ../&grub-patch; - -Prepare Grub for compilation: - -./configure --prefix=/usr - -Compile the package: - -make - -And install it: - -make install -mkdir /boot/grub -cp /usr/share/grub/i386-pc/stage{1,2} /boot/grub - -Replace i386-pc with whatever -directory is appropriate for your hardware. - -The i386-pc directory also -contains a number of *stage1_5 files, different ones -for different filesystems. Have a look at the ones available and copy the -appropriate ones to the /boot/grub -directory. Most people will copy the e2fs_stage1_5 -and/or reiserfs_stage1_5 files. - - - diff --git a/chapter06/grub.xml b/chapter06/grub.xml index 1eadcb226..431715f8d 100644 --- a/chapter06/grub.xml +++ b/chapter06/grub.xml @@ -7,6 +7,47 @@ Estimated required disk space: &grub-compsize; &aa-grub-shortdesc; &aa-grub-dep; -&c6-grub-inst; + +   + + +Installation of Grub + +This package is known to behave badly when you have changed its default +optimization flags (including the -march and -mcpu options). Therefore, if you +have defined any environment variables that override default optimizations, +such as CFLAGS and CXXFLAGS, we recommend unsetting them when building +Grub. + +Grub needs a patch to fix a compilation problem with GCC-&gcc-version; + +patch -Np1 -i ../&grub-patch; + +Prepare Grub for compilation: + +./configure --prefix=/usr + +Compile the package: + +make + +And install it: + +make install +mkdir /boot/grub +cp /usr/share/grub/i386-pc/stage{1,2} /boot/grub + +Replace i386-pc with whatever +directory is appropriate for your hardware. + +The i386-pc directory also +contains a number of *stage1_5 files, different ones +for different filesystems. Have a look at the ones available and copy the +appropriate ones to the /boot/grub +directory. Most people will copy the e2fs_stage1_5 +and/or reiserfs_stage1_5 files. + + + diff --git a/chapter06/gzip-inst.xml b/chapter06/gzip-inst.xml deleted file mode 100644 index 55ace4eeb..000000000 --- a/chapter06/gzip-inst.xml +++ /dev/null @@ -1,34 +0,0 @@ -   - - -Installation of Gzip - -Prepare Gzip for compilation: - -./configure --prefix=/usr - -The gzexe program has the location of the gzip binary hard-wired into -it. Because we later change the location of this binary, the following -command will place the new location into the gzexe binary. - -cp gzexe.in{,.backup} -sed 's%"BINDIR"%/bin%' gzexe.in.backup > gzexe.in - -Compile the package: - -make - -Install the package: - -make install - -And move the programs to the /bin directory: - -mv /usr/bin/gzip /bin -rm /usr/bin/{gunzip,zcat} -ln -s gzip /bin/gunzip -ln -s gzip /bin/zcat -ln -s gunzip /bin/uncompress - - diff --git a/chapter06/gzip.xml b/chapter06/gzip.xml index 616614f1f..c5a65e9b0 100644 --- a/chapter06/gzip.xml +++ b/chapter06/gzip.xml @@ -7,6 +7,41 @@ Estimated required disk space: &gzip-compsize; &aa-gzip-shortdesc; &aa-gzip-dep; -&c6-gzip-inst; + +   + + +Installation of Gzip + +Prepare Gzip for compilation: + +./configure --prefix=/usr + +The gzexe program has the location of the gzip binary hard-wired into +it. Because we later change the location of this binary, the following +command will place the new location into the gzexe binary. + +cp gzexe.in{,.backup} +sed 's%"BINDIR"%/bin%' gzexe.in.backup > gzexe.in + +Compile the package: + +make + +Install the package: + +make install + +And move the programs to the /bin directory: + +mv /usr/bin/gzip /bin +rm /usr/bin/{gunzip,zcat} +ln -s gzip /bin/gunzip +ln -s gzip /bin/zcat +ln -s gunzip /bin/uncompress + + + diff --git a/chapter06/inetutils-inst.xml b/chapter06/inetutils-inst.xml deleted file mode 100644 index 0b08d6d34..000000000 --- a/chapter06/inetutils-inst.xml +++ /dev/null @@ -1,51 +0,0 @@ -   - - -Installation of Inetutils - -Prepare Inetutils for compilation: - -./configure --prefix=/usr --disable-syslogd \ -    --libexecdir=/usr/sbin --disable-logger \ -    --sysconfdir=/etc --localstatedir=/var \ -    --disable-whois --disable-servers - -The meaning of the configure options: - - ---disable-syslogd: This option -prevents inetutils from installing the System Log Daemon, which is -installed with the Sysklogd package. - ---disable-logger: This option -prevents inetutils from installing the logger program, which is used by -scripts to pass messages to the System Log Daemon. We do not install it -because Util-linux installs a better version later. - ---disable-whois: This option disables -the building of the inetutils whois client, which is woefully out of date. -Instructions for a better whois client are in the BLFS book. - ---disable-servers: This disables the -installation of the various network servers included as part of the Inetutils -package. These servers are deemed not appropriate in a basic LFS system. Some -are insecure by nature and are only considered safe on trusted networks. More -information can be found at -. Note that better -replacements are available for many of these servers. - - -Compile the package: - -make - -Install it: - -make install - -And move the ping program to its proper place: - -mv /usr/bin/ping /bin - - - diff --git a/chapter06/inetutils.xml b/chapter06/inetutils.xml index b269ec090..fd448abdb 100644 --- a/chapter06/inetutils.xml +++ b/chapter06/inetutils.xml @@ -7,6 +7,57 @@ Estimated required disk space: &inetutils-compsize; &aa-inetutils-shortdesc; &aa-inetutils-dep; -&c6-inetutils-inst; + +   + + +Installation of Inetutils + +Prepare Inetutils for compilation: + +./configure --prefix=/usr --disable-syslogd \ +    --libexecdir=/usr/sbin --disable-logger \ +    --sysconfdir=/etc --localstatedir=/var \ +    --disable-whois --disable-servers + +The meaning of the configure options: + + +--disable-syslogd: This option +prevents inetutils from installing the System Log Daemon, which is +installed with the Sysklogd package. + +--disable-logger: This option +prevents inetutils from installing the logger program, which is used by +scripts to pass messages to the System Log Daemon. We do not install it +because Util-linux installs a better version later. + +--disable-whois: This option disables +the building of the inetutils whois client, which is woefully out of date. +Instructions for a better whois client are in the BLFS book. + +--disable-servers: This disables the +installation of the various network servers included as part of the Inetutils +package. These servers are deemed not appropriate in a basic LFS system. Some +are insecure by nature and are only considered safe on trusted networks. More +information can be found at +. Note that better +replacements are available for many of these servers. + + +Compile the package: + +make + +Install it: + +make install + +And move the ping program to its proper place: + +mv /usr/bin/ping /bin + + + diff --git a/chapter06/kbd-inst.xml b/chapter06/kbd-inst.xml deleted file mode 100644 index 39f9b5cb4..000000000 --- a/chapter06/kbd-inst.xml +++ /dev/null @@ -1,25 +0,0 @@ -   - - -Installation of Kbd - -By default some of Kbd's utilities (setlogcons, -setvesablank and getunimap) are -not installed . The patch enables the compilation of these utilities: - -patch -Np1 -i ../&kbd-patch; - -Now prepare Kbd for compilation: - -./configure - -Compile the package: - -make - -And install it: - -make install - - - diff --git a/chapter06/kbd.xml b/chapter06/kbd.xml index 5e9fc3830..33eb1d71c 100644 --- a/chapter06/kbd.xml +++ b/chapter06/kbd.xml @@ -7,7 +7,31 @@ Estimated required disk space: &kbd-compsize; &aa-kbd-shortdesc; &aa-kbd-dep; -&c6-kbd-inst; + +   + + +Installation of Kbd + +By default some of Kbd's utilities (setlogcons, +setvesablank and getunimap) are +not installed . The patch enables the compilation of these utilities: + +patch -Np1 -i ../&kbd-patch; + +Now prepare Kbd for compilation: + +./configure + +Compile the package: + +make + +And install it: + +make install + + diff --git a/chapter06/kernel-inst.xml b/chapter06/kernel-inst.xml deleted file mode 100644 index b3b6f41cd..000000000 --- a/chapter06/kernel-inst.xml +++ /dev/null @@ -1,61 +0,0 @@ -   - - -Installation of the kernel headers - -We won't be compiling a new kernel yet -- we'll do that when we have -finished the installation of all the packages. But as some packages need the -kernel header files, we're going to unpack the kernel archive now, set it up -and copy the header files so they can be found by these packages. - -It is important to note that the files in the kernel source directory -are not owned by root. Whenever you unpack a package as -user root (like we do here inside chroot), the files end -up having the user and group IDs of whatever they were on the packager's -computer. This is usually not a -problem for any other package you install because you remove the source -tree after the installation. But the Linux kernel source tree is often kept -around for a long time, so there's a chance that whatever user ID the packager -used will be assigned to somebody on your machine and then that person would -have write access to the kernel source. - -In light of this, you might want to run chown -R 0:0 -on the linux-&kernel-version; directory -to ensure all files are owned by user root. - -Prepare for header installation: - -make mrproper - -This ensures that the kernel tree is absolutely clean. The kernel team -recommends that this command be issued prior to each kernel -compilation. You shouldn't rely on the source tree being clean after -untarring. - -Create the include/linux/version.h file: - -make include/linux/version.h - -Create the platform-specific include/asm -symlink: - -make symlinks - -Install the platform specific-header files: - -cp -HR include/asm /usr/include -cp -R include/asm-generic /usr/include - -Install the cross-platform kernel header files: - -cp -R include/linux /usr/include - -There are a few kernel header files which make use of the -autoconf.h header file. Since we do not yet configure the -kernel, we need to create this file ourselves in order to avoid compilation -failures. Create an empty autoconf.h file: - -touch /usr/include/linux/autoconf.h - - - diff --git a/chapter06/kernel.xml b/chapter06/kernel.xml index f16c107ad..f154f00c5 100644 --- a/chapter06/kernel.xml +++ b/chapter06/kernel.xml @@ -7,8 +7,67 @@ Estimated required disk space: &kernel-compsize-headers; &aa-kernel-shortdesc; &aa-kernel-dep; -&c6-kernel-inst; -&c6-kernel-exp-headers; + +   + + +Installation of the kernel headers + +We won't be compiling a new kernel yet -- we'll do that when we have +finished the installation of all the packages. But as some packages need the +kernel header files, we're going to unpack the kernel archive now, set it up +and copy the header files so they can be found by these packages. + +It is important to note that the files in the kernel source directory +are not owned by root. Whenever you unpack a package as +user root (like we do here inside chroot), the files end +up having the user and group IDs of whatever they were on the packager's +computer. This is usually not a +problem for any other package you install because you remove the source +tree after the installation. But the Linux kernel source tree is often kept +around for a long time, so there's a chance that whatever user ID the packager +used will be assigned to somebody on your machine and then that person would +have write access to the kernel source. + +In light of this, you might want to run chown -R 0:0 +on the linux-&kernel-version; directory +to ensure all files are owned by user root. + +Prepare for header installation: + +make mrproper + +This ensures that the kernel tree is absolutely clean. The kernel team +recommends that this command be issued prior to each kernel +compilation. You shouldn't rely on the source tree being clean after +untarring. + +Create the include/linux/version.h file: + +make include/linux/version.h + +Create the platform-specific include/asm +symlink: + +make symlinks + +Install the platform specific-header files: + +cp -HR include/asm /usr/include +cp -R include/asm-generic /usr/include + +Install the cross-platform kernel header files: + +cp -R include/linux /usr/include + +There are a few kernel header files which make use of the +autoconf.h header file. Since we do not yet configure the +kernel, we need to create this file ourselves in order to avoid compilation +failures. Create an empty autoconf.h file: + +touch /usr/include/linux/autoconf.h + + diff --git a/chapter06/less-inst.xml b/chapter06/less-inst.xml deleted file mode 100644 index 13e23a1a2..000000000 --- a/chapter06/less-inst.xml +++ /dev/null @@ -1,27 +0,0 @@ -   - - -Installation of Less - -Prepare Less for compilation: - -./configure --prefix=/usr --bindir=/bin --sysconfdir=/etc - -The meaning of the configure option: - - ---sysconfdir=/etc: This option tells the -programs created by the package to look in /etc for their -configuration files. - - -Compile the package: - -make - -And install it: - -make install - - - diff --git a/chapter06/less.xml b/chapter06/less.xml index e65ad3072..0508af478 100644 --- a/chapter06/less.xml +++ b/chapter06/less.xml @@ -7,7 +7,33 @@ Estimated required disk space: &less-compsize; &aa-less-shortdesc; &aa-less-dep; -&c6-less-inst; + +   + + +Installation of Less + +Prepare Less for compilation: + +./configure --prefix=/usr --bindir=/bin --sysconfdir=/etc + +The meaning of the configure option: + + +--sysconfdir=/etc: This option tells the +programs created by the package to look in /etc for their +configuration files. + + +Compile the package: + +make + +And install it: + +make install + + diff --git a/chapter06/lfs-utils-inst.xml b/chapter06/lfs-utils-inst.xml deleted file mode 100644 index 2961ec330..000000000 --- a/chapter06/lfs-utils-inst.xml +++ /dev/null @@ -1,24 +0,0 @@ -   - - -Installation of Lfs-Utils - -Compile the package: - -make - -And install it: - -make install - -Now copy two supporting files included in the Lfs-Utils tarball to -their destination: - -cp etc/{services,protocols} /etc - -The /etc/services file is used to resolve service -numbers to human-readable names, and the /etc/protocols -does the same for protocol numbers. - - - diff --git a/chapter06/lfs-utils.xml b/chapter06/lfs-utils.xml index 1436e58f5..5119b4804 100644 --- a/chapter06/lfs-utils.xml +++ b/chapter06/lfs-utils.xml @@ -7,6 +7,30 @@ Estimated required disk space: &lfs-utils-compsize; &aa-lfs-utils-shortdesc; &aa-lfs-utils-dep; -&c6-lfs-utils-inst; + +   + + +Installation of Lfs-Utils + +Compile the package: + +make + +And install it: + +make install + +Now copy two supporting files included in the Lfs-Utils tarball to +their destination: + +cp etc/{services,protocols} /etc + +The /etc/services file is used to resolve service +numbers to human-readable names, and the /etc/protocols +does the same for protocol numbers. + + + diff --git a/chapter06/libtool-inst.xml b/chapter06/libtool-inst.xml deleted file mode 100644 index 352c5200c..000000000 --- a/chapter06/libtool-inst.xml +++ /dev/null @@ -1,24 +0,0 @@ -   - - -Installation of Libtool - -Prepare Libtool for compilation: - -./configure --prefix=/usr - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so: - -make check - -And install the package: - -make install - - diff --git a/chapter06/libtool.xml b/chapter06/libtool.xml index a7dfbbf50..9e9f9457f 100644 --- a/chapter06/libtool.xml +++ b/chapter06/libtool.xml @@ -7,6 +7,31 @@ Estimated required disk space: &libtool-compsize; &aa-libtool-shortdesc; &aa-libtool-dep; -&c6-libtool-inst; + +   + + +Installation of Libtool + +Prepare Libtool for compilation: + +./configure --prefix=/usr + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so: + +make check + +And install the package: + +make install + + + diff --git a/chapter06/m4-inst.xml b/chapter06/m4-inst.xml deleted file mode 100644 index 57e137bf8..000000000 --- a/chapter06/m4-inst.xml +++ /dev/null @@ -1,25 +0,0 @@ -   - - -Installation of M4 - -Prepare M4 for compilation: - -./configure --prefix=/usr - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so: - -make check - -And install the package: - -make install - - - diff --git a/chapter06/m4.xml b/chapter06/m4.xml index b68c90333..b52647f10 100644 --- a/chapter06/m4.xml +++ b/chapter06/m4.xml @@ -7,7 +7,31 @@ Estimated required disk space: &m4-compsize; &aa-m4-shortdesc; &aa-m4-dep; -&c6-m4-inst; + +   + + +Installation of M4 + +Prepare M4 for compilation: + +./configure --prefix=/usr + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so: + +make check + +And install the package: + +make install + + diff --git a/chapter06/make-inst.xml b/chapter06/make-inst.xml deleted file mode 100644 index c5a33444d..000000000 --- a/chapter06/make-inst.xml +++ /dev/null @@ -1,25 +0,0 @@ -   - - -Installation of Make - -Prepare Make for compilation: - -./configure --prefix=/usr - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so: - -make check - -And install the package: - -make install - - - diff --git a/chapter06/make.xml b/chapter06/make.xml index 0f477d832..f24d53ee3 100644 --- a/chapter06/make.xml +++ b/chapter06/make.xml @@ -7,6 +7,31 @@ Estimated required disk space: &make-compsize; &aa-make-shortdesc; &aa-make-dep; -&c6-make-inst; + +   + + +Installation of Make + +Prepare Make for compilation: + +./configure --prefix=/usr + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so: + +make check + +And install the package: + +make install + + + diff --git a/chapter06/makedev-inst.xml b/chapter06/makedev-inst.xml deleted file mode 100644 index 15308031b..000000000 --- a/chapter06/makedev-inst.xml +++ /dev/null @@ -1,59 +0,0 @@ -   - - -Creating devices - -Note that unpacking the MAKEDEV-&makedev-version;.bz2 -file doesn't create a directory for you to cd into, as -the file contains only a shell script. - -Install the MAKEDEV script: - -bzcat MAKEDEV-&makedev-version;.bz2 > /dev/MAKEDEV -chmod 754 /dev/MAKEDEV - -Run the script to create the device files: - -cd /dev -./MAKEDEV -v generic-nopty - -The meaning of the arguments: - - --v: This tells the script to run in -verbose mode. - -generic-nopty: This instructs -MAKEDEV to create a generic selection of commonly used -device special files, except for the ptyXX and ttyXX range of files. We don't -need those files because we are going to use Unix98 PTYs via the -devpts file system. - - -If it turns out that some special device zzz that -you need is missing, try running ./MAKEDEV -v zzz. -Alternatively, you may create devices via the mknod -program. Please refer to its man and info pages if you need more -information. - -Additionally, if you were unable to mount the devpts filesystem earlier in -the "Mounting the proc and devpts file systems" section, now is the time to -try the alternatives. If your kernel supports the devfs file system, run the -following command to mount devfs: - -mount -t devfs devfs /dev - -This will mount the devfs file system over the top of the new static -/dev structure. This poses no problems, as the device nodes -created are still present, they are just hidden by the new devfs -filesystem. - -If this still doesn't work, the only option left is to use the MAKEDEV -script to create the ptyXX and ttyXX range of files that would otherwise not be -needed. Ensure you are still in the /dev directory then run -./MAKEDEV -v pty. The downside of this is, we are -creating an extra 512 device special files which will not be needed when we -finally boot into the finished LFS system. - - - diff --git a/chapter06/makedev.xml b/chapter06/makedev.xml index e7005e574..acb766683 100644 --- a/chapter06/makedev.xml +++ b/chapter06/makedev.xml @@ -7,7 +7,65 @@ Estimated required disk space: &makedev-compsize; &aa-makedev-shortdesc; &aa-makedev-dep; -&c6-makedev-inst; + +   + + +Creating devices + +Note that unpacking the MAKEDEV-&makedev-version;.bz2 +file doesn't create a directory for you to cd into, as +the file contains only a shell script. + +Install the MAKEDEV script: + +bzcat MAKEDEV-&makedev-version;.bz2 > /dev/MAKEDEV +chmod 754 /dev/MAKEDEV + +Run the script to create the device files: + +cd /dev +./MAKEDEV -v generic-nopty + +The meaning of the arguments: + + +-v: This tells the script to run in +verbose mode. + +generic-nopty: This instructs +MAKEDEV to create a generic selection of commonly used +device special files, except for the ptyXX and ttyXX range of files. We don't +need those files because we are going to use Unix98 PTYs via the +devpts file system. + + +If it turns out that some special device zzz that +you need is missing, try running ./MAKEDEV -v zzz. +Alternatively, you may create devices via the mknod +program. Please refer to its man and info pages if you need more +information. + +Additionally, if you were unable to mount the devpts filesystem earlier in +the "Mounting the proc and devpts file systems" section, now is the time to +try the alternatives. If your kernel supports the devfs file system, run the +following command to mount devfs: + +mount -t devfs devfs /dev + +This will mount the devfs file system over the top of the new static +/dev structure. This poses no problems, as the device nodes +created are still present, they are just hidden by the new devfs +filesystem. + +If this still doesn't work, the only option left is to use the MAKEDEV +script to create the ptyXX and ttyXX range of files that would otherwise not be +needed. Ensure you are still in the /dev directory then run +./MAKEDEV -v pty. The downside of this is, we are +creating an extra 512 device special files which will not be needed when we +finally boot into the finished LFS system. + + diff --git a/chapter06/man-inst.xml b/chapter06/man-inst.xml deleted file mode 100644 index 1d3b84a62..000000000 --- a/chapter06/man-inst.xml +++ /dev/null @@ -1,62 +0,0 @@ -   - - -Installation of Man - -We'll make three adjustments to the sources of Man. - -The first patch comments out the "MANPATH /usr/man" line in the -man.conf file to prevent redundant results when using - programs such as whatis: - -patch -Np1 -i ../&man-manpath-patch; - -The second patch adds the -R option to the -PAGER variable so that escape sequences are -handled properly: - -patch -Np1 -i ../&man-pager-patch; - -The third and last patch prevents a problem when man pages not formatted -with more than 80 columns are used in conjunction with recent releases of -groff: - -patch -Np1 -i ../&man-80cols-patch; - -Now prepare Man for compilation: - -./configure -default -confdir=/etc - -The meaning of the configure options: - - --default: This tells the configure script -to select a sensible set of default options. For example: only English man -pages, no message catalogs, man not suid, handle compressed man pages, compress -cat pages, create cat pages whenever the appropriate directory exists, follow -FHS by putting cat pages under /var/cache/man provided that that directory -exists. - --confdir=/etc: This tells the -man program to look for the man.conf -configuration file in the /etc directory. - - -Compile the package: - -make - -And install it: - -make install - -If you wish to disable SGR escape sequences, you should -edit the man.conf file and add the -c argument -to nroff. - -You may want to also take a look at the BLFS page at - which deals with -formatting and compression issues for man pages. - - - diff --git a/chapter06/man.xml b/chapter06/man.xml index 9c0cd7978..833ff0e8e 100644 --- a/chapter06/man.xml +++ b/chapter06/man.xml @@ -7,7 +7,68 @@ Estimated required disk space: &man-compsize; &aa-man-shortdesc; &aa-man-dep; -&c6-man-inst; + +   + + +Installation of Man + +We'll make three adjustments to the sources of Man. + +The first patch comments out the "MANPATH /usr/man" line in the +man.conf file to prevent redundant results when using + programs such as whatis: + +patch -Np1 -i ../&man-manpath-patch; + +The second patch adds the -R option to the +PAGER variable so that escape sequences are +handled properly: + +patch -Np1 -i ../&man-pager-patch; + +The third and last patch prevents a problem when man pages not formatted +with more than 80 columns are used in conjunction with recent releases of +groff: + +patch -Np1 -i ../&man-80cols-patch; + +Now prepare Man for compilation: + +./configure -default -confdir=/etc + +The meaning of the configure options: + + +-default: This tells the configure script +to select a sensible set of default options. For example: only English man +pages, no message catalogs, man not suid, handle compressed man pages, compress +cat pages, create cat pages whenever the appropriate directory exists, follow +FHS by putting cat pages under /var/cache/man provided that that directory +exists. + +-confdir=/etc: This tells the +man program to look for the man.conf +configuration file in the /etc directory. + + +Compile the package: + +make + +And install it: + +make install + +If you wish to disable SGR escape sequences, you should +edit the man.conf file and add the -c argument +to nroff. + +You may want to also take a look at the BLFS page at + which deals with +formatting and compression issues for man pages. + + diff --git a/chapter06/manpages-inst.xml b/chapter06/manpages-inst.xml deleted file mode 100644 index 587c681e3..000000000 --- a/chapter06/manpages-inst.xml +++ /dev/null @@ -1,11 +0,0 @@ -   - - -Installation of Man-pages - -Install Man-pages by running: - -make install - - - diff --git a/chapter06/manpages.xml b/chapter06/manpages.xml index 78e14f3f0..699f68b74 100644 --- a/chapter06/manpages.xml +++ b/chapter06/manpages.xml @@ -7,6 +7,17 @@ Estimated required disk space: &man-pages-compsize; &aa-manpages-shortdesc; &aa-manpages-dep; -&c6-manpages-inst; + +   + + +Installation of Man-pages + +Install Man-pages by running: + +make install + + + diff --git a/chapter06/modutils-inst.xml b/chapter06/modutils-inst.xml deleted file mode 100644 index 71fd6e079..000000000 --- a/chapter06/modutils-inst.xml +++ /dev/null @@ -1,19 +0,0 @@ -   - - -Installation of Modutils - -Prepare Modutils for compilation: - -./configure - -Compile the package: - -make - -And install it: - -make install - - - diff --git a/chapter06/modutils.xml b/chapter06/modutils.xml index eb556ca76..d5c6708f1 100644 --- a/chapter06/modutils.xml +++ b/chapter06/modutils.xml @@ -7,6 +7,25 @@ Estimated required disk space: &modutils-compsize; &aa-modutils-shortdesc; &aa-modutils-dep; -&c6-modutils-inst; + +   + + +Installation of Modutils + +Prepare Modutils for compilation: + +./configure + +Compile the package: + +make + +And install it: + +make install + + + diff --git a/chapter06/ncurses-inst.xml b/chapter06/ncurses-inst.xml deleted file mode 100644 index e974379ee..000000000 --- a/chapter06/ncurses-inst.xml +++ /dev/null @@ -1,48 +0,0 @@ -   - - -Installation of Ncurses - -First fix two tiny bugs: - -patch -Np1 -i ../&ncurses-etip-patch; -patch -Np1 -i ../&ncurses-vsscanf-patch; - -The first patch corrects the etip.h header file, and -the second patch prevents some compiler warnings on the use of deprecated -headers. - -Now prepare Ncurses for compilation: - -./configure --prefix=/usr --with-shared \ -    --without-debug - -Compile the package: - -make - -Install the package: - -make install - -Give the Ncurses libraries execute permissions: - -chmod 755 /usr/lib/*.&ncurses-version; - -And fix a library that shouldn't be executable: - -chmod 644 /usr/lib/libncurses++.a - -Move the libraries to the /lib directory, -where they're expected to reside: - -mv /usr/lib/libncurses.so.5* /lib - -Since the libraries have been moved to -/lib, a few symlinks are currently pointing -towards non-existing files. Recreate those symlinks: - -ln -sf ../../lib/libncurses.so.5 /usr/lib/libncurses.so -ln -sf libncurses.so /usr/lib/libcurses.so - - diff --git a/chapter06/ncurses.xml b/chapter06/ncurses.xml index aa97c4867..8cc9008d1 100644 --- a/chapter06/ncurses.xml +++ b/chapter06/ncurses.xml @@ -7,7 +7,54 @@ Estimated required disk space: &ncurses-compsize; &aa-ncurses-shortdesc; &aa-ncurses-dep; -&c6-ncurses-inst; + +   + + +Installation of Ncurses + +First fix two tiny bugs: + +patch -Np1 -i ../&ncurses-etip-patch; +patch -Np1 -i ../&ncurses-vsscanf-patch; + +The first patch corrects the etip.h header file, and +the second patch prevents some compiler warnings on the use of deprecated +headers. + +Now prepare Ncurses for compilation: + +./configure --prefix=/usr --with-shared \ +    --without-debug + +Compile the package: + +make + +Install the package: + +make install + +Give the Ncurses libraries execute permissions: + +chmod 755 /usr/lib/*.&ncurses-version; + +And fix a library that shouldn't be executable: + +chmod 644 /usr/lib/libncurses++.a + +Move the libraries to the /lib directory, +where they're expected to reside: + +mv /usr/lib/libncurses.so.5* /lib + +Since the libraries have been moved to +/lib, a few symlinks are currently pointing +towards non-existing files. Recreate those symlinks: + +ln -sf ../../lib/libncurses.so.5 /usr/lib/libncurses.so +ln -sf libncurses.so /usr/lib/libcurses.so + diff --git a/chapter06/nettools-inst.xml b/chapter06/nettools-inst.xml deleted file mode 100644 index fee875247..000000000 --- a/chapter06/nettools-inst.xml +++ /dev/null @@ -1,38 +0,0 @@ -   - - -Installation of Net-tools - -If you don't know what to answer to all the questions asked during the -make config phase below, then just accept the defaults. -This will be just fine in the majority of cases. What you're asked here is a -bunch of questions about which network protocols you've enabled in your -kernel. The default answers will enable the tools from this package to work -with the most common protocols: TCP, PPP, and several others. You still need -to actually enable these protocols in the kernel -- what you do here is merely -telling the package to include support for those protocols in its programs, -but it's up to the kernel to make the protocols available. - -First fix a small syntax problem in the sources of the mii-tool -program: - -patch -Np1 -i ../&net-tools-mii-patch; - -Now prepare Net-tools for compilation with: - -make config - -If you intend to accept the default settings, you may skip the -questions generated by make config by running -yes "" | make config instead. - -Compile the package: - -make - -And install it: - -make update - - - diff --git a/chapter06/nettools.xml b/chapter06/nettools.xml index 417bd502d..61a6359d6 100644 --- a/chapter06/nettools.xml +++ b/chapter06/nettools.xml @@ -7,7 +7,44 @@ Estimated required disk space: &net-tools-compsize; &aa-nettools-shortdesc; &aa-nettools-dep; -&c6-nettools-inst; + +   + + +Installation of Net-tools + +If you don't know what to answer to all the questions asked during the +make config phase below, then just accept the defaults. +This will be just fine in the majority of cases. What you're asked here is a +bunch of questions about which network protocols you've enabled in your +kernel. The default answers will enable the tools from this package to work +with the most common protocols: TCP, PPP, and several others. You still need +to actually enable these protocols in the kernel -- what you do here is merely +telling the package to include support for those protocols in its programs, +but it's up to the kernel to make the protocols available. + +First fix a small syntax problem in the sources of the mii-tool +program: + +patch -Np1 -i ../&net-tools-mii-patch; + +Now prepare Net-tools for compilation with: + +make config + +If you intend to accept the default settings, you may skip the +questions generated by make config by running +yes "" | make config instead. + +Compile the package: + +make + +And install it: + +make update + + diff --git a/chapter06/patch-inst.xml b/chapter06/patch-inst.xml deleted file mode 100644 index ead7ec11c..000000000 --- a/chapter06/patch-inst.xml +++ /dev/null @@ -1,22 +0,0 @@ -   - - -Installation of Patch - -Prepare Patch for compilation: - -CPPFLAGS=-D_GNU_SOURCE ./configure --prefix=/usr - -Again, the preprocessor flag -D_GNU_SOURCE is only -needed on the PowerPC platform. On other architectures you can leave it out. - -Compile the package: - -make - -And install it: - -make install - - - diff --git a/chapter06/patch.xml b/chapter06/patch.xml index 442ad0e46..cc634a8e8 100644 --- a/chapter06/patch.xml +++ b/chapter06/patch.xml @@ -7,7 +7,28 @@ Estimated required disk space: &patch-compsize; &aa-patch-shortdesc; &aa-patch-dep; -&c6-patch-inst; + +   + + +Installation of Patch + +Prepare Patch for compilation: + +CPPFLAGS=-D_GNU_SOURCE ./configure --prefix=/usr + +Again, the preprocessor flag -D_GNU_SOURCE is only +needed on the PowerPC platform. On other architectures you can leave it out. + +Compile the package: + +make + +And install it: + +make install + + diff --git a/chapter06/perl-inst.xml b/chapter06/perl-inst.xml deleted file mode 100644 index 9b5466010..000000000 --- a/chapter06/perl-inst.xml +++ /dev/null @@ -1,36 +0,0 @@ -   - - -Installation of Perl - -Prepare Perl for compilation: - -./configure.gnu --prefix=/usr - -If you want more control over the way Perl sets itself up to be -built, you can run the interactive Configure script -instead and modify the way Perl is built. If you think you can live with the -(sensible) defaults Perl auto-detects, then just use the command listed -above. - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, you first -have to create a basic /etc/hosts file, needed by a -couple of tests to resolve the name localhost: - -echo "127.0.0.1 localhost $(hostname)" > /etc/hosts - -Now run the tests, if you wish: - -make test - -And install the package: - -make install - - - diff --git a/chapter06/perl.xml b/chapter06/perl.xml index 8528e6149..5e90ec069 100644 --- a/chapter06/perl.xml +++ b/chapter06/perl.xml @@ -7,7 +7,42 @@ Estimated required disk space: &perl-compsize; &aa-perl-shortdesc; &aa-perl-dep; -&c6-perl-inst; + +   + + +Installation of Perl + +Prepare Perl for compilation: + +./configure.gnu --prefix=/usr + +If you want more control over the way Perl sets itself up to be +built, you can run the interactive Configure script +instead and modify the way Perl is built. If you think you can live with the +(sensible) defaults Perl auto-detects, then just use the command listed +above. + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, you first +have to create a basic /etc/hosts file, needed by a +couple of tests to resolve the name localhost: + +echo "127.0.0.1 localhost $(hostname)" > /etc/hosts + +Now run the tests, if you wish: + +make test + +And install the package: + +make install + + diff --git a/chapter06/procinfo-inst.xml b/chapter06/procinfo-inst.xml deleted file mode 100644 index 9ed40c34d..000000000 --- a/chapter06/procinfo-inst.xml +++ /dev/null @@ -1,22 +0,0 @@ -   - - -Installation of Procinfo - -Compile Procinfo: - -make LDLIBS=-lncurses - -The meaning of the make parameter: - -LDLIBS=-lncurses: This tells Procinfo -to use the libncurses library instead of the -long-obsolete libtermcap. - - -And install the package: - -make install - - - diff --git a/chapter06/procinfo.xml b/chapter06/procinfo.xml index 70eabfca6..e02b583b6 100644 --- a/chapter06/procinfo.xml +++ b/chapter06/procinfo.xml @@ -7,6 +7,28 @@ Estimated required disk space: &procinfo-compsize; &aa-procinfo-shortdesc; &aa-procinfo-dep; -&c6-procinfo-inst; + +   + + +Installation of Procinfo + +Compile Procinfo: + +make LDLIBS=-lncurses + +The meaning of the make parameter: + +LDLIBS=-lncurses: This tells Procinfo +to use the libncurses library instead of the +long-obsolete libtermcap. + + +And install the package: + +make install + + + diff --git a/chapter06/procps-inst.xml b/chapter06/procps-inst.xml deleted file mode 100644 index 000145462..000000000 --- a/chapter06/procps-inst.xml +++ /dev/null @@ -1,24 +0,0 @@ -   - - -Installation of Procps - -First fix a problem that can crash w under -certain locale settings: - -patch -Np1 -i ../&procps-patch; - -Now compile Procps: - -make - -Install it: - -make install - -And remove a spurious library link: - -rm /lib/libproc.so - - - diff --git a/chapter06/procps.xml b/chapter06/procps.xml index eb28a8f76..a2a4fb14b 100644 --- a/chapter06/procps.xml +++ b/chapter06/procps.xml @@ -7,6 +7,30 @@ Estimated required disk space: &procps-compsize; &aa-procps-shortdesc; &aa-procps-dep; -&c6-procps-inst; + +   + + +Installation of Procps + +First fix a problem that can crash w under +certain locale settings: + +patch -Np1 -i ../&procps-patch; + +Now compile Procps: + +make + +Install it: + +make install + +And remove a spurious library link: + +rm /lib/libproc.so + + + diff --git a/chapter06/psmisc-inst.xml b/chapter06/psmisc-inst.xml deleted file mode 100644 index 740a808e1..000000000 --- a/chapter06/psmisc-inst.xml +++ /dev/null @@ -1,37 +0,0 @@ -   - - -Installation of Psmisc - -Prepare Psmisc for compilation: - -./configure --prefix=/usr --exec-prefix=/ - -The meaning of the configure option: - - ---exec-prefix=/: This causes the -binaries to be installed in /bin and not in -/usr/bin. As the Psmisc programs are often used in -bootscripts, they should be available also when the /usr -filesystem isn't mounted. - - -Compile the package: - -make - -And install it: - -make install - -By default Psmisc's pidof program isn't installed. -Generally, this isn't a problem because we later install the Sysvinit package, -which provides a better pidof program. But if you're not -going to use Sysvinit, you should complete the installation of Psmisc by -creating the following symlink: - -ln -s killall /bin/pidof - - - diff --git a/chapter06/psmisc.xml b/chapter06/psmisc.xml index e2a9d6c6e..3b939961d 100644 --- a/chapter06/psmisc.xml +++ b/chapter06/psmisc.xml @@ -7,6 +7,43 @@ Estimated required disk space: &psmisc-compsize; &aa-psmisc-shortdesc; &aa-psmisc-dep; -&c6-psmisc-inst; + +   + + +Installation of Psmisc + +Prepare Psmisc for compilation: + +./configure --prefix=/usr --exec-prefix=/ + +The meaning of the configure option: + + +--exec-prefix=/: This causes the +binaries to be installed in /bin and not in +/usr/bin. As the Psmisc programs are often used in +bootscripts, they should be available also when the /usr +filesystem isn't mounted. + + +Compile the package: + +make + +And install it: + +make install + +By default Psmisc's pidof program isn't installed. +Generally, this isn't a problem because we later install the Sysvinit package, +which provides a better pidof program. But if you're not +going to use Sysvinit, you should complete the installation of Psmisc by +creating the following symlink: + +ln -s killall /bin/pidof + + + diff --git a/chapter06/sed-inst.xml b/chapter06/sed-inst.xml deleted file mode 100644 index 4ea0a401f..000000000 --- a/chapter06/sed-inst.xml +++ /dev/null @@ -1,25 +0,0 @@ -   - - -Installation of Sed - -Prepare Sed for compilation: - -./configure --prefix=/usr --bindir=/bin - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so: - -make check - -And install the package: - -make install - - - diff --git a/chapter06/sed.xml b/chapter06/sed.xml index 9cdcf6b69..25f9b488d 100644 --- a/chapter06/sed.xml +++ b/chapter06/sed.xml @@ -7,6 +7,31 @@ Estimated required disk space: &sed-compsize; &aa-sed-shortdesc; &aa-sed-dep; -&c6-sed-inst; + +   + + +Installation of Sed + +Prepare Sed for compilation: + +./configure --prefix=/usr --bindir=/bin + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so: + +make check + +And install the package: + +make install + + + diff --git a/chapter06/shadowpwd-inst.xml b/chapter06/shadowpwd-inst.xml deleted file mode 100644 index 2632f7732..000000000 --- a/chapter06/shadowpwd-inst.xml +++ /dev/null @@ -1,105 +0,0 @@ -   - - -Installation of Shadow - -The login, getty and -init programs (and some others) maintain a number -of logfiles to record who are and who were logged in to the system. These -programs, however, don't create these logfiles when they don't exist, so if -you want this logging to occur you will have to create the files yourself. -The Shadow package needs to detect these files in their proper place, so we -create them now, with their proper permissions: - -touch /var/run/utmp /var/log/{btmp,lastlog,wtmp} -chmod 644 /var/run/utmp /var/log/{btmp,lastlog,wtmp} - -The /var/run/utmp file lists the users that are -currently logged in, the /var/log/wtmp file who -were logged in and when. -The /var/log/lastlog file shows for each user when he -or she last logged in, and the /var/log/btmp lists the -bad login attempts. - -Shadow hard-wires the path to the passwd binary -within the binary itself, but does this the wrong way. If a -passwd binary is not present before installing Shadow, -the package incorrectly assumes it is going to be located at -/bin/passwd, but then installs it in -/usr/bin/passwd. This will lead to errors about not finding -/bin/passwd. To work around this bug, create a dummy -passwd file, so that it gets hard-wired properly: - -touch /usr/bin/passwd - -The current Shadow suite has a problem that causes the -newgrp command to fail. The following patch (also -appearing in Shadow's CVS code) fixes this problem: - -patch -Np1 -i ../&shadow-patch; - -Now prepare Shadow for compilation: - -./configure --prefix=/usr --libdir=/usr/lib --enable-shared - -Compile the package: - -make - -And install it: - -make install - -Shadow uses two files to configure authentication settings for the -system. Install these two config files: - -cp etc/{limits,login.access} /etc - -We want to change the password method to enable MD5 passwords which are -theoretically more secure than the default "crypt" method and also allow -password lengths greater than 8 characters. We also need to change the old -/var/spool/mail location for user -mailboxes to the current location at -/var/mail. We do this by changing the -relevant configuration file while copying it to its destination: - -sed -e 's%/var/spool/mail%/var/mail%' \ -    -e 's%#MD5_CRYPT_ENAB.no%MD5_CRYPT_ENAB yes%' \ -    etc/login.defs.linux > /etc/login.defs - -Be extra careful when typing all of the above. It is probably safer -to cut-and-paste it rather than try and type it all in. - -According to the man page of vipw, a -vigr program should exist too. Since the installation -procedure doesn't create this program, create a symlink manually: - -ln -s vipw /usr/sbin/vigr - -As the /bin/vipw symlink is redundant (and even -pointing to a non-existent file), remove it: - -rm /bin/vipw - -Now move the sg program to its proper place: - -mv /bin/sg /usr/bin - -And move Shadow's dynamic libraries to a more appropriate location: - -mv /usr/lib/lib{shadow,misc}.so.0* /lib - -As some packages expect to find the just-moved libraries in -/usr/lib, create the following symlinks: - -ln -sf ../../lib/libshadow.so.0 /usr/lib/libshadow.so -ln -sf ../../lib/libmisc.so.0 /usr/lib/libmisc.so - -Coreutils has already installed a groups program -in /usr/bin. If you wish, you can remove the one -installed by Shadow: - -rm /bin/groups - - - diff --git a/chapter06/shadowpwd.xml b/chapter06/shadowpwd.xml index f6238c0b1..d61415e08 100644 --- a/chapter06/shadowpwd.xml +++ b/chapter06/shadowpwd.xml @@ -7,7 +7,111 @@ Estimated required disk space: &shadow-compsize; &aa-shadowpwd-shortdesc; &aa-shadowpwd-dep; -&c6-shadowpwd-inst; -&c6-cf-shadowpwd; + +   + + +Installation of Shadow + +The login, getty and +init programs (and some others) maintain a number +of logfiles to record who are and who were logged in to the system. These +programs, however, don't create these logfiles when they don't exist, so if +you want this logging to occur you will have to create the files yourself. +The Shadow package needs to detect these files in their proper place, so we +create them now, with their proper permissions: + +touch /var/run/utmp /var/log/{btmp,lastlog,wtmp} +chmod 644 /var/run/utmp /var/log/{btmp,lastlog,wtmp} + +The /var/run/utmp file lists the users that are +currently logged in, the /var/log/wtmp file who +were logged in and when. +The /var/log/lastlog file shows for each user when he +or she last logged in, and the /var/log/btmp lists the +bad login attempts. + +Shadow hard-wires the path to the passwd binary +within the binary itself, but does this the wrong way. If a +passwd binary is not present before installing Shadow, +the package incorrectly assumes it is going to be located at +/bin/passwd, but then installs it in +/usr/bin/passwd. This will lead to errors about not finding +/bin/passwd. To work around this bug, create a dummy +passwd file, so that it gets hard-wired properly: + +touch /usr/bin/passwd + +The current Shadow suite has a problem that causes the +newgrp command to fail. The following patch (also +appearing in Shadow's CVS code) fixes this problem: + +patch -Np1 -i ../&shadow-patch; + +Now prepare Shadow for compilation: + +./configure --prefix=/usr --libdir=/usr/lib --enable-shared + +Compile the package: + +make + +And install it: + +make install + +Shadow uses two files to configure authentication settings for the +system. Install these two config files: + +cp etc/{limits,login.access} /etc + +We want to change the password method to enable MD5 passwords which are +theoretically more secure than the default "crypt" method and also allow +password lengths greater than 8 characters. We also need to change the old +/var/spool/mail location for user +mailboxes to the current location at +/var/mail. We do this by changing the +relevant configuration file while copying it to its destination: + +sed -e 's%/var/spool/mail%/var/mail%' \ +    -e 's%#MD5_CRYPT_ENAB.no%MD5_CRYPT_ENAB yes%' \ +    etc/login.defs.linux > /etc/login.defs + +Be extra careful when typing all of the above. It is probably safer +to cut-and-paste it rather than try and type it all in. + +According to the man page of vipw, a +vigr program should exist too. Since the installation +procedure doesn't create this program, create a symlink manually: + +ln -s vipw /usr/sbin/vigr + +As the /bin/vipw symlink is redundant (and even +pointing to a non-existent file), remove it: + +rm /bin/vipw + +Now move the sg program to its proper place: + +mv /bin/sg /usr/bin + +And move Shadow's dynamic libraries to a more appropriate location: + +mv /usr/lib/lib{shadow,misc}.so.0* /lib + +As some packages expect to find the just-moved libraries in +/usr/lib, create the following symlinks: + +ln -sf ../../lib/libshadow.so.0 /usr/lib/libshadow.so +ln -sf ../../lib/libmisc.so.0 /usr/lib/libmisc.so + +Coreutils has already installed a groups program +in /usr/bin. If you wish, you can remove the one +installed by Shadow: + +rm /bin/groups + + + diff --git a/chapter06/sysklogd-inst.xml b/chapter06/sysklogd-inst.xml deleted file mode 100644 index 3ce0f9097..000000000 --- a/chapter06/sysklogd-inst.xml +++ /dev/null @@ -1,15 +0,0 @@ -   - - -Installation of Sysklogd - -Compile Sysklogd: - -make - -And install it: - -make install - - - diff --git a/chapter06/sysklogd.xml b/chapter06/sysklogd.xml index 53b5028cc..c5fee1038 100644 --- a/chapter06/sysklogd.xml +++ b/chapter06/sysklogd.xml @@ -7,7 +7,21 @@ Estimated required disk space: &sysklogd-compsize; &aa-sysklogd-shortdesc; &aa-sysklogd-dep; -&c6-sysklogd-inst; -&c6-cf-sysklogd; + +   + + +Installation of Sysklogd + +Compile Sysklogd: + +make + +And install it: + +make install + + + diff --git a/chapter06/sysvinit-inst.xml b/chapter06/sysvinit-inst.xml deleted file mode 100644 index 08f24bf9c..000000000 --- a/chapter06/sysvinit-inst.xml +++ /dev/null @@ -1,29 +0,0 @@ -   - - -Installation of Sysvinit - -When run levels are changed (for example, when halting the system), -init sends the TERM and KILL signals to the processes which it started. -Init prints "Sending processes the TERM signal" to the screen. This seems -to imply that init is sending these signals to all the currently running -processes. To avoid this confusion, the init.c file can be modified, so -that the sentence reads "Sending processes started by init the TERM -signal". - -Edit the halt message: - -cp src/init.c{,.backup} -sed 's/Sending processes/Sending processes started by init/g' \ -    src/init.c.backup > src/init.c - -Compile Sysvinit: - -make -C src - -And install it: - -make -C src install - - - diff --git a/chapter06/sysvinit.xml b/chapter06/sysvinit.xml index 69826f4d5..934e5cfd5 100644 --- a/chapter06/sysvinit.xml +++ b/chapter06/sysvinit.xml @@ -7,7 +7,35 @@ Estimated required disk space: &sysvinit-compsize; &aa-sysvinit-shortdesc; &aa-sysvinit-dep; -&c6-sysvinit-inst; -&c6-cf-sysvinit; + +   + + +Installation of Sysvinit + +When run levels are changed (for example, when halting the system), +init sends the TERM and KILL signals to the processes which it started. +Init prints "Sending processes the TERM signal" to the screen. This seems +to imply that init is sending these signals to all the currently running +processes. To avoid this confusion, the init.c file can be modified, so +that the sentence reads "Sending processes started by init the TERM +signal". + +Edit the halt message: + +cp src/init.c{,.backup} +sed 's/Sending processes/Sending processes started by init/g' \ +    src/init.c.backup > src/init.c + +Compile Sysvinit: + +make -C src + +And install it: + +make -C src install + + + diff --git a/chapter06/tar-inst.xml b/chapter06/tar-inst.xml deleted file mode 100644 index 035682096..000000000 --- a/chapter06/tar-inst.xml +++ /dev/null @@ -1,26 +0,0 @@ -   - - -Installation of Tar - -Prepare Tar for compilation: - -./configure --prefix=/usr --bindir=/bin \ -    --libexecdir=/usr/bin - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so: - -make check - -And install the package: - -make install - - - diff --git a/chapter06/tar.xml b/chapter06/tar.xml index 94c05c86d..3e511f323 100644 --- a/chapter06/tar.xml +++ b/chapter06/tar.xml @@ -7,6 +7,32 @@ Estimated required disk space: &tar-compsize; &aa-tar-shortdesc; &aa-tar-dep; -&c6-tar-inst; + +   + + +Installation of Tar + +Prepare Tar for compilation: + +./configure --prefix=/usr --bindir=/bin \ +    --libexecdir=/usr/bin + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so: + +make check + +And install the package: + +make install + + + diff --git a/chapter06/texinfo-inst.xml b/chapter06/texinfo-inst.xml deleted file mode 100644 index 16c391535..000000000 --- a/chapter06/texinfo-inst.xml +++ /dev/null @@ -1,37 +0,0 @@ -   - - -Installation of Texinfo - -Prepare Texinfo for compilation: - -./configure --prefix=/usr - -Compile the package: - -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so: - -make check - -Install the package: - -make install - -And optionally install the components belonging in a TeX installation: - -make TEXMF=/usr/share/texmf install-tex - -The meaning of the make option: - - -TEXMF=/usr/share/texmf: The TEXMF -makefile variable holds the location of the root of your TeX tree if, for -example, you plan to install a TeX package later on. - - - - diff --git a/chapter06/texinfo.xml b/chapter06/texinfo.xml index 745c044f1..a00d157eb 100644 --- a/chapter06/texinfo.xml +++ b/chapter06/texinfo.xml @@ -7,6 +7,43 @@ Estimated required disk space: &texinfo-compsize; &aa-texinfo-shortdesc; &aa-texinfo-dep; -&c6-texinfo-inst; + +   + + +Installation of Texinfo + +Prepare Texinfo for compilation: + +./configure --prefix=/usr + +Compile the package: + +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so: + +make check + +Install the package: + +make install + +And optionally install the components belonging in a TeX installation: + +make TEXMF=/usr/share/texmf install-tex + +The meaning of the make option: + + +TEXMF=/usr/share/texmf: The TEXMF +makefile variable holds the location of the root of your TeX tree if, for +example, you plan to install a TeX package later on. + + + + diff --git a/chapter06/utillinux-inst.xml b/chapter06/utillinux-inst.xml deleted file mode 100644 index 7bfd91bff..000000000 --- a/chapter06/utillinux-inst.xml +++ /dev/null @@ -1,43 +0,0 @@ -   - - -FHS compliance notes - -The FHS recommends that we use /var/lib/hwclock, -instead of the usual /etc, as the location for the -adjtime file. To make the hwclock -program FHS-compliant, run the following: - -cp hwclock/hwclock.c{,.backup} -sed 's%etc/adjtime%var/lib/hwclock/adjtime%' \ -    hwclock/hwclock.c.backup > hwclock/hwclock.c -mkdir -p /var/lib/hwclock - - - - -Installation of Util-linux - -Prepare Util-linux for compilation: - -./configure - -Compile the package: - -make HAVE_SLN=yes - -The meaning of the make parameter: - - -HAVE_SLN=yes: This prevents the -sln program (a statically linked -ln, already installed by Glibc) from being built -again. - - -And install the package: - -make HAVE_SLN=yes install - - - diff --git a/chapter06/utillinux.xml b/chapter06/utillinux.xml index 6238ca924..487736df2 100644 --- a/chapter06/utillinux.xml +++ b/chapter06/utillinux.xml @@ -7,6 +7,49 @@ Estimated required disk space: &util-linux-compsize; &aa-utillinux-shortdesc; &aa-utillinux-dep; -&c6-utillinux-inst; + +   + + +FHS compliance notes + +The FHS recommends that we use /var/lib/hwclock, +instead of the usual /etc, as the location for the +adjtime file. To make the hwclock +program FHS-compliant, run the following: + +cp hwclock/hwclock.c{,.backup} +sed 's%etc/adjtime%var/lib/hwclock/adjtime%' \ +    hwclock/hwclock.c.backup > hwclock/hwclock.c +mkdir -p /var/lib/hwclock + + + + +Installation of Util-linux + +Prepare Util-linux for compilation: + +./configure + +Compile the package: + +make HAVE_SLN=yes + +The meaning of the make parameter: + + +HAVE_SLN=yes: This prevents the +sln program (a statically linked +ln, already installed by Glibc) from being built +again. + + +And install the package: + +make HAVE_SLN=yes install + + + diff --git a/chapter06/vim-inst.xml b/chapter06/vim-inst.xml deleted file mode 100644 index 28e261969..000000000 --- a/chapter06/vim-inst.xml +++ /dev/null @@ -1,37 +0,0 @@ -   - - -Installation of Vim - -Change the default locations of the vimrc and -gvimrc files to /etc. - -echo '#define SYS_VIMRC_FILE "/etc/vimrc"' >> src/feature.h -echo '#define SYS_GVIMRC_FILE "/etc/gvimrc"' >> src/feature.h - -Now prepare Vim for compilation: - -./configure --prefix=/usr - -Compile the package: - -make - -And install the package: - -make install - -Vim can run in old-fashioned vi mode by -creating a symlink, which may be created with the following command: - -ln -s vim /usr/bin/vi - -If you plan to install the X Window system on your LFS -system, you might want to re-compile Vim after you have installed X. Vim -comes with a nice GUI version of the editor which requires X and a few -other libraries to be installed. For more information read the Vim -documentation. - - - diff --git a/chapter06/vim.xml b/chapter06/vim.xml index a35b54f8c..3c830af75 100644 --- a/chapter06/vim.xml +++ b/chapter06/vim.xml @@ -16,7 +16,43 @@ suggested installation instructions. &aa-vim-shortdesc; &aa-vim-dep; -&c6-vim-inst; -&c6-cf-vim; + +   + + +Installation of Vim + +Change the default locations of the vimrc and +gvimrc files to /etc. + +echo '#define SYS_VIMRC_FILE "/etc/vimrc"' >> src/feature.h +echo '#define SYS_GVIMRC_FILE "/etc/gvimrc"' >> src/feature.h + +Now prepare Vim for compilation: + +./configure --prefix=/usr + +Compile the package: + +make + +And install the package: + +make install + +Vim can run in old-fashioned vi mode by +creating a symlink, which may be created with the following command: + +ln -s vim /usr/bin/vi + +If you plan to install the X Window system on your LFS +system, you might want to re-compile Vim after you have installed X. Vim +comes with a nice GUI version of the editor which requires X and a few +other libraries to be installed. For more information read the Vim +documentation. + + + diff --git a/chapter06/zlib-inst.xml b/chapter06/zlib-inst.xml deleted file mode 100644 index c142e51eb..000000000 --- a/chapter06/zlib-inst.xml +++ /dev/null @@ -1,64 +0,0 @@ -   - - -Installation of Zlib - -Zlib has a potential buffer overflow in its -gzprintf() function, that, though difficult to take -advantage of, should be taken care of by applying this patch: - -patch -Np1 -i ../&zlib-patch; - -Now prepare Zlib for compilation: - -./configure --prefix=/usr --shared - -Note: Zlib is known to build its shared library incorrectly if a CFLAGS -is specified in the environment. If you are using your own CFLAGS variables, -ensure you add the -fPIC directive during -this stage, and remove it afterwards. - -Compile the package: - -make - -Install the shared libraries: - -make install - -Now also build the non-shared libraries: -make clean -./configure --prefix=/usr -make - -This package has a test suite available which can perform a number of -checks to ensure it built correctly. Should you choose to run it, the -following command will do so: - -make test - -And install the package: - -make install - -The shared Zlib library should be installed in the -/lib directory. That way, in the event -that you must boot without the /usr -directory, vital system programs will still have access to -the library: - -mv /usr/lib/libz.so.* /lib - -The /usr/lib/libz.so symlink is -linked to a file which no longer exists, because we moved -it. Create a symbolic link to the new location of the -library: - -ln -sf ../../lib/libz.so.1 /usr/lib/libz.so - -Zlib does not install its manual page. Issue the -following command to install this documentation: - -cp zlib.3 /usr/share/man/man3 - - diff --git a/chapter06/zlib.xml b/chapter06/zlib.xml index 0a204357d..fba00043f 100644 --- a/chapter06/zlib.xml +++ b/chapter06/zlib.xml @@ -7,7 +7,71 @@ Estimated required disk space: &zlib-compsize; &aa-zlib-shortdesc; &aa-zlib-dep; -&c6-zlib-inst; + +   + + +Installation of Zlib + +Zlib has a potential buffer overflow in its +gzprintf() function, that, though difficult to take +advantage of, should be taken care of by applying this patch: + +patch -Np1 -i ../&zlib-patch; + +Now prepare Zlib for compilation: + +./configure --prefix=/usr --shared + +Note: Zlib is known to build its shared library incorrectly if a CFLAGS +is specified in the environment. If you are using your own CFLAGS variables, +ensure you add the -fPIC directive during +this stage, and remove it afterwards. + +Compile the package: + +make + +Install the shared libraries: + +make install + +Now also build the non-shared libraries: +make clean +./configure --prefix=/usr +make + +This package has a test suite available which can perform a number of +checks to ensure it built correctly. Should you choose to run it, the +following command will do so: + +make test + +And install the package: + +make install + +The shared Zlib library should be installed in the +/lib directory. That way, in the event +that you must boot without the /usr +directory, vital system programs will still have access to +the library: + +mv /usr/lib/libz.so.* /lib + +The /usr/lib/libz.so symlink is +linked to a file which no longer exists, because we moved +it. Create a symbolic link to the new location of the +library: + +ln -sf ../../lib/libz.so.1 /usr/lib/libz.so + +Zlib does not install its manual page. Issue the +following command to install this documentation: + +cp zlib.3 /usr/share/man/man3 + + -- cgit v1.2.3-54-g00ecf