3ddc7eb50f
Signed-off-by: Leah Rowe <info@minifree.org> |
||
---|---|---|
config | ||
include | ||
script | ||
util | ||
.gitignore | ||
build | ||
COPYING | ||
README.md | ||
update |
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