cbmk/README.md
Leah Rowe 8badcf1cf4 klompboot 20240609
Signed-off-by: Leah Rowe <info@minifree.org>
2024-06-11 01:05:31 +01:00

80 lines
4.2 KiB
Markdown

Klompboot 2
=========
Software voor de vrijheid!
This version, from the "klompboot" branch of canoeboot, is a special version
of Canoeboot. It only builds for x86 machines, and does not have release
scripts, so the deblobbing has also been removed. The codename for this
version is *klompboot*. *Klompen* (plural) are wooden shoes popular in the
Netherlands, and the name *Canoeboot* was coined because *boot* means *boat*
in Dutch; it was going to be called Kanuboot as a joke, originally, but it
was named Canoeboot instead. Then I thought: what might you wear while riding
in a canoe?
*Klompen* enable you to walk, while a *canoe* will allow you to travel via
many of the Netherlands' beautiful rivers. Klompen are nimble footwear, light
and simple to use.
This is klompboot *2*; the original klompboot can be found
at <https://codeberg.org/canoeboot/cbmk/src/branch/klompboot>
As with the original klompboot, klompboot 2 is probably the dumbest thing
you've ever seen, but it works well and it was done purely for science. It cuts
Canoeboot right down to the very bone, seeing just how small it can get while
still enabling you to build bootable images for x86 machines.
Ok, what's this about?
----------------------
Coreboot's own build system skips downloading blobs during checkout, if
you omit the `--checkout` argument in git submodule update. Since the release
scripts are not there, the few blobs that coreboot overlooked shouldn't be
a problem for FSF stans. Thus, *klompboot* could be considered a *rolling
release* FSDG-aligned coreboot distro. Support for U-Boot and ARM could be
re-added, but the purpose of klompboot was to be small, and most people who
use FSDG coreboot are on GM45 thinkpads or AMD fam15h based boards anyway. The
purpose of klompboot is to be *simple*. If you want to use the RK3399 machines,
with U-Boot, just use regular Canoeboot or Libreboot. Similarly, the serprog
firmware build scripts have been removed - ditto, use Libreboot/Canoeboot for
these. The purpose of klompboot is to provide an extremely simple build system
for building coreboot images, targeting x86 machines exclusively.
Additionally: `CONFIG_USE_BLOBS` is not enabled, on each given mainboard
configuration. Each coreboot tree that *would* use microcode has been patched,
as in Canoeboot proper, to never attempt adding microcode, even if told to, so
there's no risk of that either (which, if not avoided, would either add them,
or more likely result in a build error since `CONFIG_USE_BLOBS` is disabled).
This special branch of Canoeboot was made as part of an experiment, to see how
small the build system could become, reducing the functionality so that it is
similar to the Libreboot 20220710 build system in function, but with the modern
lbmk redesign based on first five lbmk audits (2023 and 2024), and with modern code
revisions as of June 2024 - so for example, it uses GRUB 2.12.
The reason 20220710 was focused on, for comparison, is that the featureset of
klompboot really is about the same as that; 20230710's release build scripts
were much simpler, about 100 sloc for `src` and `roms` release scripts. Alas,
Libreboot 20220710's build system was 2117 source lines, versus
klompboot's very tight 704 lines of code, but klompboot is vastly superior
in terms of features and quality (and actually supports 1 additional board
in klompboot, namely the Dell Latitude E6400).
704 code lines, counting `build`, `script/*/*` and `include/*` in
the `sloccount` utility by David Wheeler.
Actually, klompboot2 has way more features now, such as support for out-of-source
builds, and multi-tree GRUB handling. It can also download files as submodules,
which is used to redundantly provide crossgcc tarballs, ditto git submodules;
it can use redundant repositories per project, when submodules are needed.
By comparison, Canoeboot cbmk is 1054 code lines (in the shell scripts that
make the build system), on the revision that the second *klompboot* revision
was based on, namely `4f6fbfde81f5176e5892d1c00627f8f680fd3780`.
This version of Canoeboot was made for fun, and will not be used officially,
and it should not be used in production.
This readme is licensed under Creative Commons Zero 1.0, which you can find
the text of here:
https://creativecommons.org/publicdomain/zero/1.0/legalcode.txt