aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorXi Ruoyao <xry111@xry111.site>2022-09-30 17:03:08 +0800
committerXi Ruoyao <xry111@xry111.site>2022-09-30 17:10:06 +0800
commit543c94cb9cf7e27e4817960a94e1429130799f27 (patch)
treeddf59149828b43fd77fa8c6de91ca8832a1837ab
parent77b46db0a84285c86a4963c6fea9f3ec1b45d8f4 (diff)
libstdc++ "stage 3" is not rebuilt for the same reason as "stage 2"
I'm pretty sure "stage 2" libstdc++ (installed in ch6) is already fully featured. The reason to rebuild the stage 3 libstdc++ (or entire stage 3 gcc) is same as the reason to rebuild every packages in multiple chapters: to "settle down" it. Merge the content of https://www.linuxfromscratch.org/lfs/faq.html#rebuild-ch8 into the book as an explanation.
-rw-r--r--general.ent3
-rw-r--r--part3intro/toolchaintechnotes.xml19
2 files changed, 20 insertions, 2 deletions
diff --git a/general.ent b/general.ent
index 1328f7c7c..81a7b51dc 100644
--- a/general.ent
+++ b/general.ent
@@ -123,6 +123,9 @@
<!ENTITY lfs-user "<systemitem class='username'>lfs</systemitem>">
<!ENTITY fstab "<filename>/etc/fstab</filename>">
<!ENTITY boot-dir "<filename class='directory'>/boot</filename>">
+<!ENTITY ch-final "<xref linkend='chapter-building-system'/>">
+<!ENTITY ch-tmp-cross "<xref linkend='chapter-temporary-tools'/>">
+<!ENTITY ch-tmp-chroot "<xref linkend='chapter-chroot-temporary-tools'/>">
<!ENTITY % packages-entities SYSTEM "packages.ent">
%packages-entities;
diff --git a/part3intro/toolchaintechnotes.xml b/part3intro/toolchaintechnotes.xml
index a6206bb91..16b6aafd2 100644
--- a/part3intro/toolchaintechnotes.xml
+++ b/part3intro/toolchaintechnotes.xml
@@ -256,8 +256,23 @@
would be able to build those libraries, but (1) the build system of
gcc does not know that it is usable on pc, and (2) using it on pc
would create a risk of linking to the pc libraries, since cc-lfs is a native
- compiler. So we have to re-build libstdc++ twice later on: as a part of
- gcc stage 2, and then again in the chroot environment (gcc stage 3).</para>
+ compiler. So we have to re-build libstdc++ later as a part of
+ gcc stage 2.</para>
+
+ <para>In &ch-final; (or <quote>stage 3</quote>), all packages needed for
+ the LFS system are built. Even if a package is already installed into
+ the LFS system in a previous chapter, we still rebuild the package
+ unless we are completely sure it's unnecessary. The main reason for
+ rebuilding these packages is to settle them down: if we reinstall a LFS
+ package on a complete LFS system, the installed content of the package
+ should be same as the content of the same package installed in
+ &ch-final;. The temporary packages installed in &ch-tmp-cross; or
+ &ch-tmp-chroot; cannot satisify this expectation because some of them
+ are built without optional dependencies installed, and autoconf cannot
+ perform some feature checks in &ch-tmp-cross; because of cross
+ compilation, causing the temporary packages to lack optional features
+ or use suboptimal code routines. Additionally, a minor reason for
+ rebuilding the packages is allowing to run the testsuite.</para>
</sect2>