diff options
author | Bruce Dubbs <bdubbs@linuxfromscratch.org> | 2020-06-16 11:56:28 +0000 |
---|---|---|
committer | Bruce Dubbs <bdubbs@linuxfromscratch.org> | 2020-06-16 11:56:28 +0000 |
commit | 675606bde2ba53946537b42a5aa576692a311621 (patch) | |
tree | af20c20ce3841c16b24d0b9903af6878a4a0f5a6 /chapter02 | |
parent | 560065f976e371779928dbf8b9428217f3f57331 (diff) | |
parent | 1cd59612d00603c9ce773ad821a15d20bc4fa0b7 (diff) |
Split Chapter 5 into three separate chapters.
Implement a new method of cross-building the LFS tool chain
and other tools to simplify the method of isolating the
new system from the original host. This will be the start of
LFS-10.0.
Move old trunk/BOOK to branches/old-trunk.
git-svn-id: http://svn.linuxfromscratch.org/LFS/trunk/BOOK@11946 4aa44e1e-78dd-0310-a6d2-fbcd4c07a689
Diffstat (limited to 'chapter02')
-rw-r--r-- | chapter02/creatingfilesystem.xml | 35 | ||||
-rw-r--r-- | chapter02/creatingpartition.xml | 45 | ||||
-rw-r--r-- | chapter02/stages.xml | 30 |
3 files changed, 38 insertions, 72 deletions
diff --git a/chapter02/creatingfilesystem.xml b/chapter02/creatingfilesystem.xml index 4a722efe0..f01b745e9 100644 --- a/chapter02/creatingfilesystem.xml +++ b/chapter02/creatingfilesystem.xml @@ -52,42 +52,9 @@ <screen role="nodump"><userinput>mkfs -v -t ext4 /dev/<replaceable><xxx></replaceable></userinput></screen> -<!-- <para>Replace <replaceable><xxx></replaceable> with the name of the LFS - partition (<filename class="devicefile">sda5</filename> in our previous - example).</para> + partition.</para> - <note> - <para>Some host distributions use custom features in their filesystem - creation tools (E2fsprogs). This can cause problems when booting into your new - LFS in Chapter 9, as those features will not be supported by the LFS-installed - E2fsprogs; you will get an error similar to <quote>unsupported filesystem - features, upgrade your e2fsprogs</quote>. To check if your host system - uses custom enhancements, run the following command:</para> - -<screen role="nodump"><userinput>debugfs -R feature /dev/<replaceable><xxx></replaceable></userinput></screen> - - <para>If the output contains features other than - <option>has_journal</option>, <option>ext_attr</option>, - <option>resize_inode</option>, <option>dir_index</option>, - <option>filetype</option>, <option>sparse_super</option>, - <option>large_file</option> or <option>needs_recovery</option>, then your - host system may have custom enhancements. In that case, to avoid later - problems, you should compile the stock E2fsprogs package and use the - resulting binaries to re-create the filesystem on your LFS partition:</para> - -<screen role="nodump"><userinput>cd /tmp -tar -xzvf /path/to/sources/e2fsprogs-&e2fsprogs-version;.tar.gz -cd e2fsprogs-&e2fsprogs-version; -mkdir -v build -cd build -../configure -make #note that we intentionally don't 'make install' here! -./misc/mke2fs -jv /dev/<replaceable><xxx></replaceable> -cd /tmp -rm -rfv e2fsprogs-&e2fsprogs-version;</userinput></screen> - </note> ---> <para>If you are using an existing <systemitem class="filesystem">swap </systemitem> partition, there is no need to format it. If a new <systemitem class="filesystem"> swap</systemitem> partition was created, diff --git a/chapter02/creatingpartition.xml b/chapter02/creatingpartition.xml index 02d6528b1..672c2efb5 100644 --- a/chapter02/creatingpartition.xml +++ b/chapter02/creatingpartition.xml @@ -15,21 +15,6 @@ is to use an available empty partition or, if you have enough unpartitioned space, to create one.</para> -<!-- - - <para>It is possible to install an LFS system (in fact even multiple LFS - systems) on a partition already occupied by another - operating system and the different systems will co-exist peacefully. The - document <ulink url="&hints-root;lfs_next_to_existing_systems.txt"/> - contains notes on how to implement this. This document was last updated - in 2004. It has not been updated since and it has not been tested with - recent versions of this LFS book. The document is more than likely not - usable as-is and you will need to account for changes made to the LFS - procedures since it was written. This is only recommended for expert LFS - users.</para> - ---> - <para>A minimal system requires a partition of around 10 gigabytes (GB). This is enough to store all the source tarballs and compile the packages. However, if the LFS system is intended to be the primary Linux system, @@ -77,7 +62,7 @@ <title>Other Partition Issues</title> <para>Requests for advice on system partitioning are often posted on the LFS mailing - lists. This is a highly subjective topic. The default for most distributions + lists. This is a highly subjective topic. The default for most distributions is to use the entire drive with the exception of one small swap partition. This is not optimal for LFS for several reasons. It reduces flexibility, makes sharing of data across multiple distributions or LFS builds more difficult, makes @@ -89,7 +74,7 @@ <para>A root LFS partition (not to be confused with the <filename class="directory">/root</filename> directory) of - ten gigabytes is a good compromise for most systems. It provides enough + twenty gigabytes is a good compromise for most systems. It provides enough space to build LFS and most of BLFS, but is small enough so that multiple partitions can be easily created for experimentation.</para> </sect3> @@ -102,13 +87,21 @@ hold the swap partition to two gigabytes and monitor the amount of disk swapping.</para> - <para>Swapping is never good. Generally you can tell if a system is - swapping by just listening to disk activity and observing how the system - reacts to commands. The first reaction to swapping should be to check for - an unreasonable command such as trying to edit a five gigabyte file. If - swapping becomes a normal occurrence, the best solution is to purchase more - RAM for your system.</para> - </sect3> + <para>If you want to use the hibernation feature (suspend-to-disk) of Linux, + it writes out the contents of RAM to the swap partition before turning off + the machine. In this case the size of the swap partition should be at + least as large as the system's installed RAM.</para> + + <para>Swapping is never good. For mechanical hard drives you can generally + tell if a system is swapping by just listening to disk activity and + observing how the system reacts to commands. For an SSD drive you will not + be able to hear swapping but you can tell how much swap space is being used + by the <command>top</command> or <command>free</command> programs. Use of + an SSD drive for a swap partition should be avoided if possible. The first + reaction to swapping should be to check for an unreasonable command such as + trying to edit a five gigabyte file. If swapping becomes a normal + occurrence, the best solution is to purchase more RAM for your + system.</para> </sect3> <sect3> <title>The Grub Bios Partition</title> @@ -140,7 +133,7 @@ <listitem><para>/boot – Highly recommended. Use this partition to store kernels and other booting information. To minimize potential boot problems with larger disks, make this the first physical partition on - your first disk drive. A partition size of 100 megabytes is quite + your first disk drive. A partition size of 200 megabytes is quite adequate.</para></listitem> <listitem><para>/home – Highly recommended. Share your home @@ -150,7 +143,7 @@ <listitem><para>/usr – A separate /usr partition is generally used if providing a server for a thin client or diskless workstation. It is - normally not needed for LFS. A size of five gigabytes will handle most + normally not needed for LFS. A size of ten gigabytes will handle most installations.</para></listitem> <listitem><para>/opt – This directory is most useful for diff --git a/chapter02/stages.xml b/chapter02/stages.xml index 30e820213..0d513383d 100644 --- a/chapter02/stages.xml +++ b/chapter02/stages.xml @@ -25,40 +25,40 @@ <itemizedlist> <listitem> - <para>Procedures done as the root user after Section 2.4 need to - have the LFS environment variable set <emphasis>FOR THE ROOT - USER</emphasis>.</para> + <para>Procedures done as the root user after Section 2.4 need to + have the LFS environment variable set <emphasis>FOR THE ROOT + USER</emphasis>.</para> </listitem> </itemizedlist> </sect2> <sect2> - <title>Chapter 5</title> + <title>Chapter 5–6</title> <itemizedlist> <listitem> - <para>The /mnt/lfs partition must be mounted.</para> + <para>The /mnt/lfs partition must be mounted.</para> </listitem> <listitem> - <para><emphasis>ALL</emphasis> instructions in Chapter 5 - must be done by user <emphasis>lfs</emphasis>. - A <command>su - lfs</command> needs to be done before any - task in Chapter 5.</para> + <para>Threse two chapters must be done as user <emphasis>lfs</emphasis>. + A <command>su - lfs</command> needs to be done before any task in these + chapters. Failing to do that, you are at risk of installing packages to the + host, and potentially rendering it unusable.</para> </listitem> <listitem> <para>The procedures in <xref linkend='ch-tools-generalinstructions'/> are critical. If there is any doubt about installing a package, ensure any previously expanded - tarballs are removed, re-extract the package files, and complete all + tarballs are removed, then re-extract the package files, and complete all instructions in that section.</para> </listitem> </itemizedlist> </sect2> <sect2> - <title>Chapters 6–8</title> + <title>Chapter 7–10</title> <itemizedlist> <listitem> @@ -66,8 +66,14 @@ </listitem> <listitem> + <para>A few operations, from <quote>Changing Ownership</quote> to + <quote>Entering the Chroot Environment</quote> must be done as the + root user, with the LFS envirnment variable set for the root user.</para> + </listitem> + + <listitem> <para> When entering chroot, the LFS environment variable must be set - for root. The LFS variable is not used otherwise.</para> + for root. The LFS variable is not used afterwards.</para> </listitem> <listitem> |