summaryrefslogtreecommitdiff
path: root/documentation/DEPENDENCIES-BUILD.md
diff options
context:
space:
mode:
Diffstat (limited to 'documentation/DEPENDENCIES-BUILD.md')
-rw-r--r--documentation/DEPENDENCIES-BUILD.md175
1 files changed, 0 insertions, 175 deletions
diff --git a/documentation/DEPENDENCIES-BUILD.md b/documentation/DEPENDENCIES-BUILD.md
deleted file mode 100644
index e1d97de..0000000
--- a/documentation/DEPENDENCIES-BUILD.md
+++ /dev/null
@@ -1,175 +0,0 @@
-
-# lh-bootstrap: software built for the BUILD machine
-
-Laurent Bercot
-2016-03-31
-
-
-This file documents the software installed and run on the BUILD
-machine prior to building the HOST image.
-
-Please read the INTERNALS.md file first, for the general organization
-of the build, and basic definitions.
-
-
-## BUILD tools
-
-### Linux kernel headers
-
-Makefile directory: sub/kernel
-
-The Linux kernel is downloaded and will be configured and compiled
-to boot a qemu image for the HOST. Since it will be downloaded
-anyway, we reuse the source to process and install the kernel headers
-for the BUILD.
-Those kernel headers, coupled with the musl libc's headers, are
-necessary to compile Linux-specific software such as util-linux and skarnet-org.
-
-
-### musl libc
-
-Makefile directory: sub/musl
-
- We have no control over the BUILD's native compiler and libc. Most
-likely, it's gcc and produces binaries that are dynamically linked
-against the glibc - but we're not certain; we would like certainty,
-even for the build tools. We do not want our tools' behaviour to
-depend on external factors such as a misconfigured libc or dynamic
-linker.
-
- So, we download the musl libc (which we would download for use in
-the HOST anyway) and compile it for the BUILD. We then link all our
-BUILD tools against it.
-
-
-### skarnet.org packages
-
-Makefile directory: sub/skarnet.org
-
- The HOST uses s6-rc as its service manager. We provide a template
-for the database in source format in `layout/rootfs/etc/s6-rc/source-base`;
-this template is preprocessed and added to the rootfs at layout
-installation time, at the beginning of the HOST build.
- However, in order to boot, the HOST needs the database in compiled
-form, not in source form: so we must run s6-rc-compile before the HOST
-boots. Since the source and compiled formats are platform-independent,
-we just run s6-rc-compile on the BUILD. Which means we need to compile
-s6-rc for the BUILD, with the same settings that the HOST is using.
-So we end up compiling most of the skarnet.org stack.
-
- Since we have to compile skalibs anyway, which is by far the heaviest
-component of the stack, we also use the opportunity to compile
-s6-portable-utils for the BUILD: the time spent compiling this package
-is negligible once skalibs is built, and it contains
-alternative tools that we use subsequently in the build, because their
-behaviour is more predictible than the tools provided by the BUILD's
-distribution.
-
- Note: since we need to mirror the HOST's layout for s6-rc-compile
-to work properly, we compile the skarnet.org stack following the
-slashpackage convention, with --enable-slashpackage. However, we
-obviously don't install a slashpackage hierarchy on the BUILD's root
-filesystem, we use the $(OUTPUT)/build-build staging directory.
-The consequence is that skarnet.org binaries that exec other binaries
-via slashpackage paths will not work. This is ok for our use since
-the main tool we need is s6-rc-compile, which does not exec anything
-else, but it's something to keep in mind. It's the reason why we do
-not use s6-setuidgid even after building s6: we stick to the hackish
-and inefficient bin/setuidgid script to drop privileges, because our
-temporary installation of s6-setuidgid simply does not work.
-
-
-#### skalibs
-
- The library which all other skarnet.org packages depend on.
-
-
-#### execline
-
- The scripting language used by s6 and s6-rc.
-
-
-#### s6
-
- The supervision suite used by s6-rc.
-
-
-#### s6-rc
-
- The service manager used by the HOST. We compile it for the BUILD in
-order to use s6-rc-compile to compile the service database before
-booting the HOST.
-
-
-#### s6-portable-utils
-
- Some utilities are akin to POSIX tools, but will have reproducible behavior
-no matter what distribution is used. We have had trouble with
-differences across BUILD distributions, with some distributions
-slightly deviating from the standard (looking at you, Ubuntu); using
-our own tools is insurance against that.
-
-
-### util-linux
-
-Makefile directory: sub/util-linux
-
- To make the qemu image, we need losetup -P, to set up a loopback
-mount that supports partitions. But the -P option to losetup only
-appear in latest versions of util-linux, and not all distributions
-ship a recent enough version. (Looking at you, Ubuntu and Debian
-stable.)
- So we download and build util-linux. Except the util-linux
-build system is a bloated plate of noodles, that can have a lot
-of dependencies - in particular a dependency to ncurses, and we
-DO NOT want to build ncurses if it can be avoided. Fortunately,
-none of the tools we need require ncurses. So we end up building
-those individual binaries from util-linux and avoid pulling in
-the kitchen sink.
- Currently, the binaries we build are: losetup, fdisk, mkswap,
-mount, umount. This list can change as the package evolves; the
-current list is described in the UTLX_PROGLIST variable definition
-in the sub/util-linux/Makefile file.
-
-
-### xz-utils
-
-Makefile directory: sub/xz
-
- xz-utils includes another compression library (liblzma), which
-is also a dependency of kmod - actually, this is the one that
-interests us. So we have to build the xz-utils package for
-BUILD.
-
-
-### kmod
-
-Makefile directory: sub/kmod
-
- Ah, kmod.
-
- We build the Linux kernel for HOST with module support, for
-practicality. Modules are compressed, to save storage space.
-Traditionally, there are compressed with gzip (and have extension
-`.ko.gz`), but xz is generally a better compressor than gzip:
-it decompresses faster and the compressed data is smaller. So
-we use xz to compress the modules (extension `.ko.xz`). On the
-HOST, we load the modules with busybox modprobe, which supports
-both extensions. So far, so good.
-
- Except that xz support for kmod is relatively recent, and some
-distributions insist on providing an ancient version of kmod,
-which *does not* allows modules to be compressed with xz.
-(And the kernel's build system does not report the error - the
-modules silently fail to be installed, which makes diagnostic
-fun!)
-
- So, we have to provide our own version of kmod.
-
- I have to say that kmod is the single worst package that appears
-in this whole build. The software itself works, but the
-build system is *extremely* buggy and requires several workarounds,
-that have all been implemented in the Makefile. Please do not
-attempt to "simplify" this Makefile by using "correct" configure
-options and eliminating make variables: that will not work.
-