2024-10-02 04:30:29 +08:00
|
|
|
|
LFS SystemD Build Scripts
|
|
|
|
|
=========================
|
2024-10-02 04:21:23 +08:00
|
|
|
|
Shell scripts for building LFS SystemD
|
2024-10-02 04:30:29 +08:00
|
|
|
|
|
2024-10-02 05:19:23 +08:00
|
|
|
|
Based upon https://www.linuxfromscratch.org/lfs/view/stable-systemd/
|
|
|
|
|
version 12.2
|
|
|
|
|
|
2024-10-02 04:30:29 +08:00
|
|
|
|
Do not yet use
|
|
|
|
|
|
|
|
|
|
This git repository contains shell scripts needed to build LFS 12.2-systemd and
|
|
|
|
|
is being worked on in an `x86_64` LFS 11.3 (modified) system.
|
|
|
|
|
|
|
|
|
|
There are some deviations from LFS 12.2, namely:
|
|
|
|
|
|
|
|
|
|
* LibreSSL is used instead of OpenSSL
|
|
|
|
|
* LTS Kernel series 6.6 is being used in place of 6.10.x kernel series
|
2024-10-08 16:30:00 +08:00
|
|
|
|
* Some versions are updated from what is in the LFS book.
|
2024-10-02 04:30:29 +08:00
|
|
|
|
|
2024-10-08 16:30:00 +08:00
|
|
|
|
The host I am building from is an LFS 11.3 system with similar modifications.
|
2024-10-02 04:30:29 +08:00
|
|
|
|
|
|
|
|
|
As of present, these scripts are not complete and probably broken.
|
2024-10-02 05:19:23 +08:00
|
|
|
|
|
2024-10-08 16:30:00 +08:00
|
|
|
|
These instructions are incomplete notes.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Chapter 03 ‘Get Sources’ Script
|
|
|
|
|
-------------------------------
|
|
|
|
|
|
2024-10-08 16:33:32 +08:00
|
|
|
|
This script is to be run by the `lfs` user. The partition LFS is to be built on
|
2024-10-08 18:16:22 +08:00
|
|
|
|
must already be mounted at `/mnt/newlfs` and the directory `/mnt/newlfs/sources`
|
2024-10-08 16:33:32 +08:00
|
|
|
|
should exist and be owned by the `lfs` user.
|
2024-10-08 16:30:00 +08:00
|
|
|
|
|
2024-10-08 16:33:32 +08:00
|
|
|
|
The script will download the needed sources (sourcing `versions.sh`) and make a
|
2024-10-08 16:30:00 +08:00
|
|
|
|
backup of the downloaded sources so that if run again, it can get the sources
|
|
|
|
|
from the backup and not need to download them again.
|
|
|
|
|
|
2024-10-08 16:33:32 +08:00
|
|
|
|
The file `versions.sh` also includes `sha256sum` digests so that the script can
|
2024-10-08 18:16:22 +08:00
|
|
|
|
verify the integrity of the fetched files.
|
2024-10-08 16:30:00 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Chapter 05 Building
|
|
|
|
|
-------------------
|
|
|
|
|
|
2024-10-08 16:33:32 +08:00
|
|
|
|
In the `CH5Build` directory, the `lfs` user should execute the `Master.sh`
|
2024-10-08 16:30:00 +08:00
|
|
|
|
script:
|
|
|
|
|
|
|
|
|
|
lfs$ bash Master.sh
|
|
|
|
|
|
|
|
|
|
The script works but is not finished. To do, it needs to verify the system is
|
2024-10-08 16:33:32 +08:00
|
|
|
|
ready for the script to run. The `Master.sh` script calls the `CH05.*` scripts.
|
2024-10-08 16:30:00 +08:00
|
|
|
|
|
|
|
|
|
|
2024-10-08 16:55:16 +08:00
|
|
|
|
Chapter 06 Building
|
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
|
|
In the `CH6Build` directory, the `lfs` user should execute the `Master.sh`
|
|
|
|
|
script:
|
|
|
|
|
|
2024-10-09 01:57:10 +08:00
|
|
|
|
lfs$ bash Master.sh
|
2024-10-08 16:55:16 +08:00
|
|
|
|
|
|
|
|
|
The script works but is not finished. To do, it needs to verify the system is
|
|
|
|
|
ready for the script to run. The `Master.sh` script calls the `CH06.*` scripts.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Chapter 07 Building
|
|
|
|
|
-------------------
|
|
|
|
|
|
2024-10-10 21:16:13 +08:00
|
|
|
|
__PAY ATTENTION__: First, the `root` user must execute the `CHROOT.sh` script:
|
|
|
|
|
|
|
|
|
|
root# bash CHROOT.sh
|
|
|
|
|
|
2024-10-08 16:55:16 +08:00
|
|
|
|
That script will copy `CH7Build` and `CH8Build` into `/mnt/newlfs/sources` and
|
|
|
|
|
then fix some permissions and set up `/mnt/newlfs` for the `chroot`
|
|
|
|
|
environment.
|
|
|
|
|
|
|
|
|
|
Finally, it echoes the command that the `root` user must execute to enter the
|
|
|
|
|
`chroot` environment.
|
|
|
|
|
|
|
|
|
|
Once in the `chroot`:
|
|
|
|
|
|
2024-10-10 21:16:13 +08:00
|
|
|
|
root# cd /sources/CH7Build
|
|
|
|
|
root# bash 0-CH07-Prep.sh
|
2024-10-08 16:55:16 +08:00
|
|
|
|
|
|
|
|
|
After executing `0-CH07-Prep.sh` reload `bash` with the following:
|
|
|
|
|
|
2024-10-10 21:16:13 +08:00
|
|
|
|
root# exec /usr/bin/bash --login
|
2024-10-08 16:55:16 +08:00
|
|
|
|
|
|
|
|
|
Then, still inside the `chroot` at `/sources/CH7Build`, execute:
|
|
|
|
|
|
2024-10-10 21:16:13 +08:00
|
|
|
|
root# bash Master.sh
|
2024-10-08 16:55:16 +08:00
|
|
|
|
|
2024-10-08 17:49:16 +08:00
|
|
|
|
The script works but is not finished. To do, it needs to verify the system is
|
|
|
|
|
ready for the script to run. The `Master.sh` script calls the `CH07.*` scripts.
|
|
|
|
|
|
2024-10-08 16:55:16 +08:00
|
|
|
|
Some important build tools previously built in the host environment will be
|
|
|
|
|
rebuilt within the `chroot` environment. After the script runs, it will echo
|
|
|
|
|
instructions on how to back things up. The backup takes a few minutes but it
|
|
|
|
|
saves time if something goes wrong in Chapter 8 building.
|
|
|
|
|
|
2024-10-08 16:30:00 +08:00
|
|
|
|
|
2024-10-08 17:49:16 +08:00
|
|
|
|
Chapter 08 Building
|
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
|
|
__PAY ATTENTION__: After running the build scripts for LFS Chapter 7, the
|
|
|
|
|
instructions for creating the backup involved deleted the `/mnt/newlfs/sources`
|
|
|
|
|
directory.
|
|
|
|
|
|
|
|
|
|
As the `lfs` user, re-run the `CH03-get-sources.sh` script to restore the
|
2024-10-10 21:16:13 +08:00
|
|
|
|
sources:
|
|
|
|
|
|
|
|
|
|
lfs$ bash CH03-get-sources.sh
|
|
|
|
|
|
|
|
|
|
The script will restore the sources from the backup it made the first time it
|
|
|
|
|
ran, it will not need to fetch them again.
|
2024-10-08 17:49:16 +08:00
|
|
|
|
|
|
|
|
|
Then as the `root` user, once again execute the `CHROOT.sh` script to set up
|
2024-10-10 21:16:13 +08:00
|
|
|
|
the `chroot` environment and copy the build scripts into it:
|
2024-10-08 17:49:16 +08:00
|
|
|
|
|
2024-10-10 21:16:13 +08:00
|
|
|
|
root# bash CHROOT.sh
|
|
|
|
|
|
|
|
|
|
Again, the script will echo the command to enter the `chroot`. Execute it as
|
|
|
|
|
`root` and then once in the `chroot` environment:
|
|
|
|
|
|
|
|
|
|
root# cd /sources/CH8Build
|
|
|
|
|
root# bash Master.sh
|
2024-10-08 17:49:16 +08:00
|
|
|
|
|
|
|
|
|
That will run many of the `CH08.*` scripts, building the LFS system through
|
|
|
|
|
`CH08.34-bash`. Note that when it builds the `shadow` package, it first builds
|
|
|
|
|
the `cracklib` package from BLFS and then links `shadow` against it. It does
|
|
|
|
|
not however build PAM.
|
|
|
|
|
|
|
|
|
|
After it finishes building `bash`, the `Master.sh` script will instruct you to
|
|
|
|
|
set the `root` password. After doing so, exit the `chroot` and re-enter so that
|
|
|
|
|
the freshly rebuilt `bash` will be loaded.
|
|
|
|
|
|
|
|
|
|
Once in the `chroot` environment again:
|
|
|
|
|
|
2024-10-10 21:16:13 +08:00
|
|
|
|
root# cd /sources/CH8Build
|
|
|
|
|
root# bash Master2.sh
|
2024-10-08 17:49:16 +08:00
|
|
|
|
|
|
|
|
|
That will run the rest of the `CH08.*` scripts. Assuming all goes well, the
|
|
|
|
|
system will be ready for LFS Chapter 9 configuration.
|
|
|
|
|
|
2024-10-10 21:16:13 +08:00
|
|
|
|
It also builds several packages from BLFS, specifically enough so that `wget`
|
|
|
|
|
and `curl` are built, along with the TLS certificate bundles needed for those
|
|
|
|
|
tools to make TLS (HTTPS) connections.
|
|
|
|
|
|
2024-10-08 17:49:16 +08:00
|
|
|
|
Note that `Master2.sh` does have a major deviation from the LFS book. It builds
|
|
|
|
|
LibreSSL to provide the OpenSSL API (e.g. as used by the `kmod` package). Most
|
|
|
|
|
software that builds against OpenSSL will build against LibreSSL and I have
|
|
|
|
|
more trust in the LibreSSL developers.
|
|
|
|
|
|
|
|
|
|
As of Python 3.10, Python 3 no longer allows building against LibreSSL. So
|
|
|
|
|
OpenSSL is still built, the `_ssl` and `_hashlib` Python modules need it and
|
|
|
|
|
are pretty important to a sane Python environment.
|
|
|
|
|
|
|
|
|
|
See the file `TLS-README.md` for more information.
|
|
|
|
|
|
|
|
|
|
The `CH08.*` scripts seem to work but I need to audit them against the LFS book
|
|
|
|
|
and some of them are missing the running of the tests. Also, I need to add a
|
|
|
|
|
way to disable the running of the tests.
|
|
|
|
|
|
2024-10-03 05:46:02 +08:00
|
|
|
|
|
2024-10-02 05:19:23 +08:00
|
|
|
|
The Madness
|
|
|
|
|
-----------
|
|
|
|
|
|
|
|
|
|
Long term goal is to produce a GNU/Linux distribution largely based upon LFS
|
|
|
|
|
but using RPM packages with a ‘core’ package repository and then additional
|
|
|
|
|
package repositories that require the ‘core’ package repository.
|
|
|
|
|
|
|
|
|
|
Multilib is not a goal, nor is compatibility with WINE. The goal is to allow
|
|
|
|
|
‘Free Libre Open Source Software’ to have a capable GNU system running the
|
|
|
|
|
Linux kernel upon which to run.
|
|
|
|
|
|
|
|
|
|
I *personally* will be involved in the package repository for the MATE Desktop
|
|
|
|
|
Environment when it gets that far, but as far as GNOME, KDE, etc. if they are
|
|
|
|
|
to have package repositories then others will have to provide them.
|
|
|
|
|
|
|
|
|
|
What I want is a stable ‘LTS’ distribution along the lines of what CentOS used
|
|
|
|
|
to be but third-party package repositories providing for the needs of the user
|
|
|
|
|
community, similar to how ‘Fedora Extras’ supplemented Red Hat Linux back in the
|
|
|
|
|
day.
|
|
|
|
|
|
|
|
|
|
Is that too much to ask?
|
2024-10-03 05:46:02 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
The Plan
|
|
|
|
|
--------
|
|
|
|
|
|
|
|
|
|
These scripts will be used to build a bootable USB thumb drive that will then
|
|
|
|
|
be used to run the scripts again to rebuild itself on the hard disk. The thumb
|
|
|
|
|
drive then becomes my emergency boot device.
|
|
|
|
|
|
|
|
|
|
Once installed on the hard drive, BLFS packages will be added until I have a
|
|
|
|
|
basic usable system bootstrapped with the RPM package manager.
|
|
|
|
|
|
|
|
|
|
At that point, packages will be added until I am able to run the XFCE desktop
|
|
|
|
|
environment. Long-term goal personally is MATE but MATE will be done as a
|
|
|
|
|
separate package repository. Hopefully KDE and GNOME will also be done as
|
|
|
|
|
separate package repositories as well.
|
|
|
|
|
|
|
|
|
|
Users who are happy with XFCE will not need a separate package repository for
|
|
|
|
|
their desktop environment.
|
|
|
|
|
|
|
|
|
|
Back on topic, once XFCE is properly packaged and working, then the scripts
|
|
|
|
|
used to build the bootable USB thumb drive will be used to build an installer
|
|
|
|
|
thumb drive with a crude basic installer to create a system using RPM packages.
|
|
|
|
|
|
|
|
|
|
That will be the first release of ‘Yellow-Jacket GNU/Linux’ and it is probable
|
|
|
|
|
that by the time that happens, the LTS kernel will have changed and quite
|
|
|
|
|
likely other core components like GCC and GlibC and Python.
|
|
|
|
|
|
|
|
|
|
|