1625 lines
65 KiB
Markdown
1625 lines
65 KiB
Markdown
---
|
|
title: lbmk maintenance manual
|
|
x-toc-enable: true
|
|
...
|
|
|
|
NOTE: Libreboot standardises on [flashprog](https://flashprog.org/wiki/Flashprog)
|
|
now, as of 27 January 2024, which is a fork of flashrom.
|
|
|
|
In addition to this manual, you should also refer to [porting.md](porting.md)
|
|
and [testing.md](testing.md).
|
|
|
|
Please also read about the [lbmk coding style and design](style.md).
|
|
|
|
Automated coreboot build system
|
|
===============================
|
|
|
|
This document describes the entire Libreboot build system, its design philosophy
|
|
and how it's used to prepare Libreboot releases; it is provided as a *reference*
|
|
for *Libreboot development*, pertaining to the current development branch of
|
|
Libreboot's build system (called *lbmk*).
|
|
|
|
The homepage of Libreboot says that Libreboot is a *coreboot distro*, providing
|
|
the necessary integration of coreboot, payloads and utilities so as to provide
|
|
releases, much like Linux distros do for your operating system, but here we are
|
|
concerned about the *boot firmware* instead. Libreboot is to coreboot, what
|
|
Debian is to Linux. It provides easier, more automated configuration and
|
|
installation.
|
|
|
|
The build system, lbmk, *is* that coreboot distro, at its very core. You can
|
|
basically think of it as a package manager; it is even a *source-based* package
|
|
manager. If you simply want to build ROM images, refer instead to the [basic
|
|
build instructions](../build/).
|
|
|
|
This build system, lbmk, is completely automated in every way. It is designed
|
|
to take care of itself; so long as build dependencies are installed, it will
|
|
check itself when running *any* command; if another command had to be executed
|
|
first, it will do so automatically. Therefore, you can run any part of lbmk
|
|
on its own, and the entire design is modular.
|
|
|
|
Best practises for learning lbmk
|
|
================================
|
|
|
|
The follow sections will cover subdirectories, within lbmk. Contrary to what
|
|
some may otherwise assume, it's best to learn about everything *except* scripts
|
|
or code within Libreboot, first. No, you should first learn about config files
|
|
used in the Libreboot build system, and *then* learn about the logic. By doing
|
|
it in this order, you will have greater context later when reading about those
|
|
scripts. Learning about each upstream project (such as coreboot) will also be
|
|
useful; check documentation provided by each project.
|
|
|
|
After learning about configuration, you will then read about files and
|
|
directories generated by the build system; only *then* will this document
|
|
describe each script or program that forms part of the build system. In other
|
|
words, this document adopts a *top-down* approach to education, rather than
|
|
bottom-up; most documents take the latter approach, in other projects, but
|
|
most people naturally want to learn how a specific thing works first, hence
|
|
the approach taken here.
|
|
|
|
Don't be deceived by simplicity
|
|
-------------------------------
|
|
|
|
Libreboot's build system is powerful, and highly configurable, yet deceptively
|
|
simple at the same time. Remember this rule, a rule that applies to *all*
|
|
software projects: code equals bugs, so smaller codebases will yield fewer bugs.
|
|
Libreboot is [regularly](../../news/audit.md) [audited](../../news/audit2.md).
|
|
|
|
Many people will be shocked by how *small* Libreboot is, at its core. You will
|
|
be surprised by just how much can be done with so little. Continue reading!
|
|
|
|
libreboot blob reduction policy
|
|
============================
|
|
|
|
The coreboot software is nominally free, but it requires additional files from
|
|
the vendor on many supported systems. These programs lack source code, and the
|
|
coreboot project does not control them, but they can be used to perform
|
|
specific initialization tasks.
|
|
|
|
The libreboot project *allows* vendor code within coreboot, but there is *still* a
|
|
lot of nuance to precisely what is allowed. It is important that you understand
|
|
these nuances, when working on *libreboot*.
|
|
|
|
[Please read the blob reduction guidelines](../../news/policy.md) and also
|
|
the [freedom status page](../../freedom-status.md).
|
|
|
|
Before *configuration* info, you will first be shown a brief overview of every
|
|
project that Libreboot imports, such as coreboot.
|
|
|
|
Environmental variables
|
|
=======================
|
|
|
|
XBMK\_THREADS
|
|
-------------
|
|
|
|
For example:
|
|
|
|
export XBMK_THREADS=2
|
|
|
|
This would build on two threads, when running lbmk. It defaults to 1.
|
|
|
|
Previous revisions of lbmk used `nproc` by default, but this was set to 1
|
|
instead, because nproc is not available on every operating system.
|
|
|
|
XBMK\_RELEASE
|
|
-------------
|
|
|
|
If set to `y`, it signals to `script/roms` that a release is being built,
|
|
and it will honour `release="n"` in target.cfg files. You could also set this
|
|
yourself, when doing regular builds, if you wanted to test how `./build roms`
|
|
behaves running it in release mode. Do this if you want to:
|
|
|
|
export XBMK_RELEASE=y
|
|
|
|
Projects/files downloaded/generated by lbmk
|
|
===========================================
|
|
|
|
The following sections will describe files and directories that are not
|
|
included in `lbmk.git`, but *are* created by running various lbmk commands;
|
|
many of these will also be provided, pre-generated, under release archives.
|
|
|
|
Some of these are *downloaded* by Libreboot's build system, automatically, while
|
|
others are created during the build process based on these downloaded programs.
|
|
|
|
bin/
|
|
---------------
|
|
|
|
This directory is created when running any of the following commands, with the
|
|
right arguments:
|
|
|
|
./mk -b coreboot ARGUMENTS_HERE
|
|
./mk -b stm32-vserprog
|
|
./mk -b pico-serprog
|
|
|
|
Simply speaking, `bin/` shall contain finished ROM images or firmware, that
|
|
can then be installed (flashed) to the target device.
|
|
|
|
The files under `bin/` are provided in regular Libreboot releases.
|
|
|
|
**These** are the ROM images that you should flash.
|
|
|
|
Older versions of lbmk build coreboot images separately under `elf/`, but
|
|
without payloads, using `elf/` as a build cache, then inserting payloads
|
|
into copies of these images in files under `bin/`. However, modern lbmk
|
|
now only puts coreboot images in `bin/`, with payloads included.
|
|
|
|
If you still have `elf/` coreboot images in your lbmk tree, please do not
|
|
use them (and you may aswell delete them).
|
|
|
|
cache/
|
|
---------------
|
|
|
|
Certain files are cached here automatically, by lbmk. The user need not touch
|
|
these files.
|
|
|
|
cache/app
|
|
--------------
|
|
|
|
When vendor updates are extracted, they go here, which is then processed to
|
|
find individual files for use in coreboot images (e.g. KBC1126 EC firmware).
|
|
|
|
This directory is constantly over-written, so it's essentially another temporary
|
|
directory used by the build system.
|
|
|
|
cache/file/
|
|
--------------
|
|
|
|
Files that are downloaded are hashed, and the cached version of the file
|
|
is stored there, named as the SHA512 checksum. This is used for vendor file
|
|
downloads, and subfile downloads.
|
|
|
|
A *subfile* is like a Git submodule, but it's a *file* (just a humble file),
|
|
downloaded via curl/wget. The build system does not
|
|
run `git submodule update` commands when handling Git repositories anymore,
|
|
instead processing submodules manually; it supports both repositories *and*
|
|
files relative to the directory locations for those repositories, but subfiles
|
|
are not downloaded to the *cached git repository*, only the work directory used
|
|
for building in lbmk.
|
|
|
|
cache/hash
|
|
---------------
|
|
|
|
When lbmk is handling any project, it sorts a list of files under `config/`
|
|
including `config/project` (or `config/project/TREE`) and `config/data/project`.
|
|
|
|
SHA512 checksums are calculated from these files, in the sorted order, and
|
|
written in that order, to a file. *That* file is then checksummed, and this
|
|
hash is stored in `cache/hash` for that project.
|
|
|
|
If the currently stored hash differs from what's calculated, it means that
|
|
the project has changed, and the source directories plus builds are deleted.
|
|
The project source is then re-prepared and re-build.
|
|
|
|
cache/repo
|
|
--------------
|
|
|
|
Git repositories are cached here. This avoids wasting bandwidth, when downloading
|
|
multiple repositories. **Git submodules are also cached here!**
|
|
|
|
ec/
|
|
---------------
|
|
|
|
KBC1126 EC firmware goes here, required on HP EliteBook laptops. These images
|
|
are inserted into those coreboot images, under `elf/` *and* `bin/`.
|
|
|
|
elf/
|
|
---------------
|
|
|
|
**DO NOT flash coreboot ROM images contained under `elf/`. Please use ROM images
|
|
under `bin/` instead! - In modern lbmk, only the ones under `bin/` are ever
|
|
created anyway.**
|
|
|
|
Compiled binaries (compiled by lbmk) go here, but they are not the final
|
|
binaries; coreboot ROM images are compiled without payloads, then cached here
|
|
under `elf/coreboot` as one example
|
|
|
|
GRUB and SeaBIOS which go
|
|
under `elf/grub` and `elf/seabios` respectively - `elf/u-boot` is another
|
|
example. A given project can include a `build.list` file
|
|
at `config/data/PROJECT/build.list`, which would contain a list of file paths
|
|
relative to the *source directory*; these files would be copied, after a build
|
|
operation, to `elf/PROJECT` for single-tree projects,
|
|
or `elf/PROJECT/TREE` for multi-tree projects.
|
|
|
|
It is technically possible to re-use these files elsewhere. For example, you
|
|
may wish to only compile GRUB with lbmk, and then use the `grub.elf` file from
|
|
lbmk in your own custom coreboot ROM (that you didn't build with lbmk). However,
|
|
this use is not officially supported by the Libreboot project; these files are
|
|
simply used by the Libreboot build system.
|
|
|
|
Some utilities are also provided compiled here, when building. For
|
|
example: `elf/flashprog/flashprog`. This is because lbmk tries to provide
|
|
out-of-source builds whenever feasible.
|
|
|
|
This is only used by the build system, but these images are *not* provided in
|
|
releases (only the images under `bin/` are provided).
|
|
|
|
As of Libreboot 20240612, the `elf/` directory must be used by default for all
|
|
builds, in an effort to make exclusive use of *out-of-source builds*. As such,
|
|
the `cbutils` directory is no longer used.
|
|
|
|
mrc/
|
|
---------------
|
|
|
|
Intel System Agent downloaded at build time for HP EliteBook 820 G2.
|
|
|
|
The *Haswell* MRC file is no longer downloaded here, because Haswell machines
|
|
now use native raminit *exclusively*; only Broadwell uses MRC, at present.
|
|
|
|
pciroms/
|
|
---------------
|
|
|
|
PCI Option ROMs, currently used only for the VGA ROM on models of Dell Latitude
|
|
E6400 containing an Nvidia GPU; it provides video initialisation, where coreboot
|
|
currently only initialises Intel GPUs natively, on Libreboot systems.
|
|
|
|
release/
|
|
---------------
|
|
|
|
The script at `build` create tarballs in here, which
|
|
constitute regular Libreboot releases. It is meticulously maintained, as per
|
|
current lbmk behaviour, and executed so as to provide Libreboot release
|
|
archives.
|
|
|
|
This provides source tarballs, and ROM images for example; however, ROM images
|
|
containing non-redistributable vendor code are *scrubbed* such that these files must,
|
|
in regular releases, be [re-added manually](../install/ivy_has_common.md) by
|
|
the user.
|
|
|
|
You can create release archives by doing:
|
|
|
|
./mk release
|
|
|
|
By default, this creates a release under `release/`, but you can change the
|
|
directory, for example:
|
|
|
|
./mk release -d path
|
|
|
|
You can also specify that only a *source archive* be created, like so:
|
|
|
|
./mk release -m src
|
|
|
|
Or with a custom directory:
|
|
|
|
./mk release -d path -m src
|
|
|
|
The build system expects there to be a *git tag*, so make sure there is one.
|
|
This is used to create the version number for a given release.
|
|
|
|
src/
|
|
----
|
|
|
|
Third-party source trees are downloaded into this directory, by lbmk.
|
|
|
|
src/bios\_extract/
|
|
---------------
|
|
|
|
Used by the vendor file handler scripts. The upstream that we use is here:
|
|
<https://review.coreboot.org/bios_extract>
|
|
|
|
The `dell_inspiron_1100_unpacker.py` script is used here, to extract from Dell
|
|
BIOS updates, to get at the VGA ROM for Nvidia GPU on certain models of Dell
|
|
Latitude E6400.
|
|
|
|
src/biosutilities/
|
|
---------------
|
|
|
|
Used by the vendor file handler scripts. The upstream that we use is here:
|
|
<https://github.com/platomav/BIOSUtilities>
|
|
|
|
Specifically: the pfs extract utility from this is used on Dell vendor updates,
|
|
to extract SCH5545 EC (Environment Control) firmware.
|
|
|
|
src/coreboot/
|
|
---------------
|
|
|
|
Please also visit: <https://coreboot.org/>
|
|
|
|
Coreboot is the main boot firmware, providing hardware initialisation. Libreboot
|
|
makes extensive use of coreboot, on supported mainboards.
|
|
|
|
Coreboot trees go here. Libreboot's build system does not simply use one tree,
|
|
or multiple branches in the same tree; entirely separate directories are
|
|
created, for each revision of coreboot used, each able to have its own patches.
|
|
These can then be re-use appropriately, per mainboard. For example:
|
|
|
|
* `src/coreboot/default` is used by most mainboards.
|
|
* `src/coreboot/cros` is used by cros devices.
|
|
|
|
This may be less efficient on disk usage, but it simplifies the logic greatly.
|
|
Coreboot also uses its own toolchain called *crossgcc*, and crossgcc is in fact
|
|
compiled *per tree* in Libreboot.
|
|
|
|
src/deguard/
|
|
------------
|
|
|
|
Mate Kukri's utility that disables the Intel Boot Guard on Intel MEv11-based
|
|
PCH. More info available on the [deguard page](../install/deguard.md).
|
|
|
|
On coreboot targets that have Intel Boot Guard, you can specify in
|
|
target configuration, on the vendor file config, something like:
|
|
|
|
ME11bootguard="y"
|
|
ME11delta="thinkpad_t480s" # subdirectory under deguard's data/delta/
|
|
ME11version="11.6.0.1126"
|
|
ME11sku="2M"
|
|
ME11pch="LP"
|
|
|
|
The above example is used on the ThinkPad T480S, and specifies that in
|
|
addition to downloading and neutering an Intel ME image, it should also run
|
|
deguard to set up a Boot Guard-disabled configuration, or *deguarded*
|
|
installation (or less politically correctly, a disreguarded ME!)
|
|
|
|
Libreboot uses a generic, universal ME image on all MEv11 based systems,
|
|
downloading it from a vendor, generic because its configuration is stripped
|
|
out and replaced by deguard, with one specific to the target machine. More
|
|
information is available on the deguard page, and in the deguard README,
|
|
which when downloading in lbmk in the `src/deguard/` directory.
|
|
|
|
src/flashprog/
|
|
---------------
|
|
|
|
Please also visit: <https://flashprog.org/>
|
|
|
|
Although currently unused by any part of lbmk, we provide flashprog for the
|
|
convenience of users, and this is copied to release archives. Flashrom is the
|
|
program that you will use to read, erase and write the flash, containing
|
|
coreboot firmware.
|
|
|
|
src/gpio-scripts
|
|
----------------
|
|
|
|
This is a fork of the original gpio-scripts. The fork is maintained by Riku
|
|
Viitanen, based on code written by Angel Pons (author of the Haswell native
|
|
raminit patches and many other excellent works), but Riku's version parses
|
|
the inteltool log files. This is useful for adapting GPIO configs on Intel
|
|
machines, when porting new boards to coreboot.
|
|
|
|
NOTE: Not included in Libreboot yet, but `intelp2m` is used instead for this
|
|
purpose, on much newer Intel systems (from around Skylake era or later).
|
|
|
|
src/grub/TREE
|
|
---------------
|
|
|
|
Please also visit: <https://www.gnu.org/software/grub/>
|
|
|
|
The GNU GRUB bootloader, a reference multiboot implementation with its own
|
|
small kernel/OS and drivers (e.g. file systems, cryptography). This is the
|
|
default recommended [coreboot payload](https://doc.coreboot.org/payloads.html)
|
|
on x86-based Libreboot systems. GRUB will load and execute your Linux kernel,
|
|
which then runs on the bare metal.
|
|
|
|
The *utilities* for GRUB are compiled here, and used from here; specifically,
|
|
the `grub-mkstandalone` utility is executed from here to create the final
|
|
GRUB image under `elf/grub/`.
|
|
|
|
NOTE: This is *only* provided for x86 machines, in Libreboot. For ARM, we ship
|
|
U-Boot instead. Since Libreboot 20240612, the GRUB builds are *multi-tree*,
|
|
much like, say, coreboot or SeaBIOS.
|
|
|
|
As of August 2024, the following GRUB source trees can be downloaded:
|
|
|
|
* `src/grub/default`
|
|
* `src/grub/xhci`
|
|
* `src/grub/nvme`
|
|
|
|
Simplify specify the tree. For example:
|
|
|
|
./mk -b grub xhci
|
|
|
|
The `xhci` tree contains patches for both NVMe SSD support, and xHCI. The `nvme`
|
|
tree contains NVMe SSD support but not xHCI support. The `default` tree contains
|
|
no NVMe or xHCI support. All trees otherwise have the same fixes on top of
|
|
upstream GRUB, e.g. fix for Dell Latitude keyboard controllers.
|
|
|
|
src/int/
|
|
--------
|
|
|
|
Riku Viitanen wrote this tool for debugging, when implementing MXM option ROM
|
|
support in coreboot and SeaBIOS, for the HP EliteBook 8560w.
|
|
|
|
src/memtest86plus/
|
|
---------------
|
|
|
|
Please also visit: <https://www.memtest.org/>
|
|
|
|
This is provided inside ROM images, as a payload executed from main GRUB or
|
|
SeaBIOS payload. It checks for corrupted memory.
|
|
|
|
src/mxmdump/
|
|
------------
|
|
|
|
Riku Viitanen wrote this utility, for dumping the MXM config on graphics cards
|
|
that use it. The HP EliteBook 8560w uses these cards, and normally you would
|
|
just run a VGA option ROM to get a display at boot time. The MXM cards
|
|
additionally contain a configuration called MXM, which basically describes
|
|
ports and several power management capabilities.
|
|
|
|
MXM data is loaded via an INT15H handler, which Riku also implemented in
|
|
SeaBIOS. If the MXM data is not handled, the VGA option ROM (when executed)
|
|
will often complain and refuse to boot; some of them can be hacked to bypass
|
|
this fact, but such hacks are no longer required because of Riku's tool.
|
|
|
|
src/seabios/
|
|
---------------
|
|
|
|
Please also visit: <https://www.seabios.org/SeaBIOS>
|
|
|
|
This is the PC BIOS implementation used by Libreboot, on x86 machines (not all
|
|
of them). A BIOS/UEFI implementation is not required, because Linux and BSD
|
|
kernels can execute on bare metal, but it can nonetheless still be useful; in
|
|
particular, the BSD bootloaders can be executed from SeaBIOS.
|
|
|
|
This is provided as a coreboot payload, either as first payload or it can be
|
|
executed from GRUB (if GRUB is the main payload, on a given target).
|
|
|
|
src/u-boot/
|
|
---------------
|
|
|
|
Please also visit: <https://www.denx.de/project/u-boot/>
|
|
|
|
This is a bootloader provided on ARM chromebooks, within Libreboot. It also
|
|
provides UEFI. Information about that can be found on these resources:
|
|
|
|
* [U-Boot documentation](../u-boot/)
|
|
* [Chromebook documentation](../install/chromebooks.md)
|
|
|
|
This is currently the only payload on *ARM* systems, within Libreboot.
|
|
|
|
U-Boot is also available on x86 machines, since the Libreboot 20241206 release.
|
|
More information can be found on the [U-Boot x86 page](../uboot/uboot-x86.md);
|
|
it is available as an alternative to the traditional SeaBIOS and GRUB payloads,
|
|
and it can successfully boot UEFI applications on x86 Libreboot systems.
|
|
|
|
src/uefitool/
|
|
---------------
|
|
|
|
Please also visit: <https://github.com/LongSoft/UEFITool>
|
|
|
|
This is compiled, so as to provide `UEFIExtract`. Currently used by the
|
|
vendor download logic within `include/vendor.sh`, to download SCH5545 EC
|
|
firmware (used for fan control on Dell Precision T1650).
|
|
|
|
This has also been modified to build reliably on non-glibc-based systems e.g.
|
|
Alpine Linux, which uses musl libc.
|
|
|
|
src/pcsx-redux
|
|
----------------
|
|
|
|
PCSX-Redux is a Sony Playstation (PS1/PSX) emulator, but Libreboot only uses
|
|
one part from it: the Open BIOS. This is used by Libreboot to provide an
|
|
open BIOS for the Sony Playstation!
|
|
|
|
More information available on the [PlayStation page](../install/playstation.md).
|
|
|
|
This is automatically compiled by the main build script, and the resulting
|
|
BIOS image is provided in Libreboot release archives.
|
|
|
|
src/pico-serprog
|
|
---------------------------
|
|
|
|
Used by lbmk, to build firmware for serprog-based SPI flashers with RP2040 SoC.
|
|
Alongside this, `util-fw/rp2040/pico-sdk` is imported which is required for
|
|
building it.
|
|
|
|
Please visit these pages:
|
|
|
|
* <https://github.com/raspberrypi/pico-sdk>
|
|
* <https://codeberg.org/libreboot/pico-serprog>
|
|
|
|
src/stm32-vserprog
|
|
----------------------
|
|
|
|
Used by lbmk, to build firmware for serprog-based SPI flashers with STM32 MCU.
|
|
Alongside this, `libopencm3` is imported which is required for building it.
|
|
|
|
* <https://codeberg.org/libreboot/stm32-vserprog>
|
|
* <https://github.com/libopencm3/libopencm3>
|
|
|
|
These serprog programmers are quite desirable, owing to their low cost and ease
|
|
of use. You can learn more on the [SPI flashing guide](../install/spi.md).
|
|
|
|
Before moving onto configurations, we will now cover *utilities* provided by
|
|
Libreboot itself (included within lbmk, rather than being downloaded like the
|
|
third party projects listed above):
|
|
|
|
tmp/
|
|
---------------
|
|
|
|
The `TMPDIR` environmental variable is set by lbmk, to a location under `/tmp`,
|
|
but some users may have `/tmp` mounted as a *tmpfs* (file system in RAM), and
|
|
may not have much RAM.
|
|
|
|
Where large files (or a large number of files) are handled by lbmk on a
|
|
temporary basis, this `tmp/` directory is created and then used.
|
|
|
|
vendorfiles/
|
|
---------------
|
|
|
|
Used by the vendor file handler scripts, referenced in certain coreboot configs.
|
|
|
|
Certain vendor files such as Intel ME or SCH5545 EC firmware are downloaded
|
|
here; not all such files are downloaded here however, as some are handled under
|
|
separate directories.
|
|
|
|
util/
|
|
===============
|
|
|
|
If a codebase is not frequently used by Libreboot, is actively developed (making
|
|
it not viable to maintain in Libreboot) or the codebase is very large, we would
|
|
import that as a third party module in lbmk - this rule exists for all projects,
|
|
where the intention is that `lbmk.git` itself should be small and efficient.
|
|
|
|
Where appropriate, and where the code is small enough, or it is otherwise deemed
|
|
desirable, `lbmk.git` provides a few utilities as part of itself, namely:
|
|
|
|
util/dell-flash-unlock/
|
|
---------------
|
|
|
|
This program, written by Nicholas Chin, unlocks the boot flash on Dell Latitude
|
|
E6400; it permits internal flashing, from factory firmware to Libreboot, so that
|
|
the user need not disassemble and flash externally.
|
|
|
|
It also supports several other Dell laptops, with similar ECs. Check the
|
|
README file included in this directory, for more information.
|
|
|
|
util/me7\_update\_parser/
|
|
---------------
|
|
|
|
This is a special fork of `me_cleaner`, specifically for parsing and neutering
|
|
Intel ME images provided by Lenovo for ThinkPad X220 and other Lenovo
|
|
ThinkPads of Intel SandyBridge platform. You can find information about this
|
|
on the original repository:
|
|
|
|
<https://github.com/Thrilleratplay/me7_update_parser>
|
|
|
|
ME7 Update Parser was originally written for *Heads*, another coreboot distro
|
|
very similar to Libreboot that provides coreboot build automation with Linux
|
|
based payload configurations. *Their* build system auto-downloads and
|
|
auto-neuters Intel ME images, during build, so that the user does not have to
|
|
manually extract such images from dumps of the original vendor firmware (in
|
|
the flash) on a given machine.
|
|
|
|
Such logic was ported to Libreboot, courtesy of `shmalebx9` as mentioned
|
|
on the [who page](../../who.md) - Caleb is a core developer in the Libreboot
|
|
project.
|
|
|
|
util/nvmutil/
|
|
---------------
|
|
|
|
The `nvmutil` software allows you to set the MAC address on Intel GbE NVM
|
|
files. It also allows you to set *random* MAC addresses, in addition to
|
|
arbitrary ones.
|
|
|
|
This directory contains the source code for `nvmutil`, which you can read
|
|
about here:
|
|
|
|
[nvmutil manual](../install/nvmutil.md)
|
|
|
|
util/spkmodem\_recv/
|
|
---------------
|
|
|
|
FSF has original copyright on this; it was imported from coreboot, who in turn
|
|
imported it from GRUB with very little modification. Therefore, this code is
|
|
canonically based on what is provided in GNU GRUB.
|
|
|
|
This is a receiving client for spkmodem, which is a method of providing serial
|
|
consoles via pulses on the PC speaker. The `spkmodem_recv` client will *decode*
|
|
these pulses. Coreboot has a driver for generating these pulses, as does
|
|
GRUB; this client code was imported from GRUB, and has in fact been provided
|
|
by every Libreboot release since the start of the project (look inside the GRUB
|
|
or coreboot source code and you'll find it).
|
|
|
|
However, the original code from GRUB was of quite poor quality and this code
|
|
is often used. For fun, it was decided that this utility would be imported
|
|
directly into `lbmk.git`, and thoroughly cleaned. The lbmk version has been
|
|
more or less re-written, using the original logic as a base; variables are
|
|
more clearly named. A top-down, OpenBSD-inspired coding style is used,
|
|
replacing the GNU coding style implemented in the original code. The [OpenBSD
|
|
coding style][https://man.openbsd.org/style.9] is much easier to read.
|
|
|
|
This code has been modified to make use of the `pledge()` system call, when used
|
|
on [OpenBSD](https://www.openbsd.org/); the original version from GRUB did not
|
|
do this. Other improvemnts include:
|
|
|
|
* Superior error handling (the program actually exits with non-zero status now,
|
|
under fault conditions, whereas the original code did *not* handle errors).
|
|
* Debug mode is now handled via `getopt()` by passing the `-d` flag at run time,
|
|
whereas the original code only enabled it if a DEBUG build-time flag was used.
|
|
* The code has been translated into English (e.g. references to "trames" in
|
|
the code, now say "frames" in the Libreboot version).
|
|
* Certain magic numbers, and certain equations in code, are now labelled as
|
|
either variables or as `#define` values, thus increasing code legibility.
|
|
|
|
*Now* in the next sections, you will learn about configuration files provided
|
|
by lbmk:
|
|
|
|
config/
|
|
=======
|
|
|
|
This directory contains configuration files, used by the Libreboot build
|
|
system. These next sections will cover specific configuration files.
|
|
|
|
config/PROJECT\*/nuke.list
|
|
--------------------------
|
|
|
|
The script `include/git.sh` handles deletion of certain files, for downloaded
|
|
projects, based on a `nuke.list` file that can (for single-tree projects) be
|
|
included at `config/PROJECT/nuke.list` or (multi-tree project)
|
|
at `config/PROJECT/TREE/nuke.list` (entries are relative links from the root
|
|
directory of the given source tree e.g. `src/coreboot/default/`).
|
|
|
|
So, if `src/coreboot/default/` contained foo/bar.txt, you could add to
|
|
the `nuke.list` file as follows:
|
|
|
|
```
|
|
foo/bar.txt
|
|
```
|
|
|
|
Ditto `src/flashprog/`, if you wanted to delete a file from in there, as one
|
|
other example. Deletions occur when the source tree is created.
|
|
|
|
config/vendor/
|
|
---------------
|
|
|
|
URLs and hashes for vendor files containing Intel ME images within them. Where
|
|
feasible, backup URLs are also provided. SHA512 checksums are defined, so that
|
|
lbmk can verify the integrity of downloaded files.
|
|
|
|
When building for sandybridge, ivybridge and haswell machines, Libreboot's
|
|
build system automatically downloads such updates from the vendor, to extract
|
|
the Intel ME image and neuter it with `me_cleaner` or `me7_update_parser.py`.
|
|
|
|
Of course, backing up the original firmware is still a good idea, before
|
|
installing Libreboot or any other spin of coreboot.
|
|
|
|
This file is also used to define the VGA ROM, on Nvidia models of Dell Latitude
|
|
E6400.
|
|
|
|
config/coreboot
|
|
---------------
|
|
|
|
### config/coreboot/BOARDNAME/
|
|
|
|
Each target name (e.g. `x200_8mb`) has its own directory under here. Targets
|
|
that do not define defconfigs also exist here; for example, the `default`
|
|
directory defines a coreboot revision and patches.
|
|
|
|
Targets under `config/coreboot` can specify `tree=TREE` where `TREE` could,
|
|
for example, be `default`. In other words, they can refer to other trees.
|
|
|
|
The coreboot downloads are based on scanning of these directories, and ROM
|
|
images are also built based on them; coreboot defconfigs are also used by
|
|
the vendor scripts, for adding or removing certain vendor firmware (for example,
|
|
a config will define where `me.bin` is located, and if it doesn't exist, the
|
|
vendor scripts will look up that file and download/process it with `me_cleaner`).
|
|
|
|
### config/coreboot/BOARDNAME/patches/
|
|
|
|
For any given coreboot tree, patches with the `patch` file extension are placed
|
|
here, alphanumerically in the order that they should be applied.
|
|
|
|
These patches are then so applied, when lbmk downloads the given source tree.
|
|
|
|
### config/coreboot/BOARDNAME/target.cfg
|
|
|
|
This file can contain several configuration lines, each being a string, such
|
|
as:
|
|
|
|
* `tree="default"` (example entry)
|
|
* `rev="ad983eeec76ecdb2aff4fb47baeee95ade012225"` (example entry)
|
|
* `xarch="i386-elf"` (example entry)
|
|
* `payload_grub="y"` (example entry)
|
|
* `payload_seabios="y"` (example entry)
|
|
* `payload_memtest="y"` (example entry)
|
|
* `payload_uboot="y"` (example entry)
|
|
* `grub_scan_disk="ata"`
|
|
* `uboot_config=default` (specify which U-Boot tree to use)
|
|
* `release="n"` (example entry)
|
|
* `xtree="default"` (example entry)
|
|
* `tree_depend="default"` (example entry)
|
|
* `grubtree="nvme" (example entry)`
|
|
* `payload_uboot_i386="y"` (example entry - 32 bit U-Boot)
|
|
* `payload_uboot_amd64="y"` (example entry - 64 bit U-Boot)
|
|
|
|
Please also check the `build_depend` variable
|
|
in `config/data/coreboot/mkhelper.cfg` - and compare to what trees are used
|
|
for payloads in the given target. If your board's `target.cfg` requires trees
|
|
and projects other than that specified in `mkhelper.cfg`, you must replace
|
|
the entire `build_depend` string. For example, if your board requires GRUB with
|
|
xHCI patches, with SeaBIOS and with U-Boot AMD64, and you also want memtest86plus,
|
|
you would therefore set the string as follows:
|
|
|
|
```
|
|
build_depend="grub/xhci seabios/default u-boot/amd64coreboot memtest86plus"
|
|
```
|
|
|
|
In the above example, you would also set `grubtree="xhci"`,
|
|
but please note that there is only one SeaBIOS tree so `/default` is implied,
|
|
but must still be in the `build_depend` variable. Multiple U-Boot trees exist,
|
|
but for x86 32-bit you would only specify `i386coreboot` and for 64-bit you
|
|
would only specify `amd64coreboot` and for ARM64 you say `default` - so you
|
|
do not need to specify a `seabiostree` or `uboottree` variable, and these are
|
|
not handled, because lbmk simply assumes use of the aforementioned tree names.
|
|
|
|
The `tree` value refers to `config/coreboot/TREE`; in other words, a given
|
|
target could specify a name other than its own as the tree; it would then
|
|
re-use code from that tree, rather than providing its own.
|
|
|
|
The `rev` entry defines which coreboot revision to use, from the
|
|
coreboot Git repository. *At present, lbmk only supports use of the official
|
|
repository from the upstream coreboot project*.
|
|
|
|
The `xarch` entry specifies which CPU architecture is to be used: currently
|
|
recognized entries are `i386-elf`, `arm-eabi` and `aarch64-elf`. This is the
|
|
target architecture for building GCC/toolchain from coreboot crossgcc,
|
|
hence `xarch`.
|
|
|
|
The `payload_grub` entry specifies whether or not GRUB is to be included in
|
|
ROM images.
|
|
|
|
The `payload_seabios` entry specifies whether or not SeaBIOS is to be included
|
|
in ROM images. If GRUB is also enabled, standalone SeaBIOS images will be
|
|
created alongside SeaGRUB images. SeaGRUB is where SeaBIOS automatically
|
|
loads GRUB, via `bootorder` inserted into CBFS.
|
|
|
|
The `payload_memtest` entry specifies whether or not MemTest86+ is to be
|
|
included in ROM images; it will only be included in ROM images for *text mode*
|
|
startup, on x86 machines.
|
|
|
|
The `payload_uboot` entry specifies whether or not U-Boot is to be included in
|
|
ROM images.
|
|
|
|
The `uboot_config` option specifies which U-Boot board configuration file
|
|
variant should be used. It currently doesn't make sense for this to be anything
|
|
other than `default`, which is the default if the option is missing.
|
|
|
|
The `grub_scan_disk` option specifies can be `ahci`, `ata` or `both`, and it
|
|
determines which types of disks are to be scanned, when the `grub.cfg` file in
|
|
GRUB payloads tries to automatically find other `grub.cfg` files supplied by
|
|
your Linux distribution. On some machines, setting it to `ata` or `ahci`
|
|
can improve boot speed by reducing delays; for example, trying to scan `ata0`
|
|
on a ThinkPad X60 with the optical drive may cause GRUB to hang, so on that
|
|
machine it is advisable to set this option to `ahci` (becuse the default HDD
|
|
slot is AHCI).
|
|
|
|
The `release` variable can be set to n, which makes the `./mk release`
|
|
call skip that target, when creating release images. For example, a given
|
|
board may not be stable and you don't want images for it to be included in the
|
|
release.
|
|
|
|
The `xtree` option specifies that a given tree with use a specific coreboot
|
|
tree for compiling crossgcc. This can be used to skip building gcc if OK on
|
|
a given board; two trees may use the same crossgcc as each other.
|
|
|
|
The `tree_depend` option means that a given tree needs another tree, defined
|
|
by this variable, to also be present.
|
|
|
|
The `grubtree` option specifies which GRUB tree to use. If unset, it defers to
|
|
the `default` GRUB tree.
|
|
|
|
### config/coreboot/BOARDNAME/config/
|
|
|
|
Files in this directory are *coreboot* configuration files.
|
|
|
|
Configuration file names can be as follows:
|
|
|
|
* `libgfxinit_corebootfb`
|
|
* `libgfxinit_txtmode`
|
|
* `vgarom_vesafb`
|
|
* `vgarom_txtmode`
|
|
* `normal`
|
|
|
|
Information pertaining to this can be found on
|
|
the [installation manual](../install/)
|
|
|
|
In `lbmk`, a board-specific directory under `config/coreboot/` should never
|
|
specify a coreboot revision. Rather, a directory *without* coreboot configs
|
|
should be created, specifying a coreboot revision. For example, the
|
|
directory `config/coreboot/default/` specifies a coreboot revision. In the
|
|
board-specific directory, your `board.cfg` could then
|
|
specify `cbtree="default"` but without specifying a coreboot revision (this
|
|
is specified by `config/coreboot/default/board.cfg`).
|
|
|
|
When you create a coreboot configuration, you should set the payload to *none*
|
|
because `lbmk` itself will assume that is the case, and insert payloads itself.
|
|
|
|
Configurations with `libgfxinit` will use coreboot's native graphics init code
|
|
if available on that board. If the file name has `txtmode` in it, coreboot
|
|
will be configured to start in *text mode*, when setting up the display. If
|
|
the file name has `corebootfb` in it, coreboot will be configured to set up a
|
|
high resolution *frame buffer*, when initializing the display.
|
|
|
|
NOTE: If the configuration file is `libgfxinit_txtmode`, the SeaBIOS payload
|
|
can still run *external* VGA option ROMs on graphics cards, and this is the
|
|
recommended setup (SeaBIOS in text mode) if you have a board with both onboard
|
|
and an add-on graphics card (e.g. PCI express slot) installed.
|
|
|
|
Configuration files with `vgarom` in the name have coreboot itself configured
|
|
to run VGA option ROMs (and perhaps other option ROMs). *This* setup is not
|
|
strictly recommended for *SeaBIOS*, and it is recommended that you only run
|
|
GRUB in this setup. As such, if you wish for a board to have coreboot initialize
|
|
the VGA ROM (on an add-on graphics card, as opposed to onboard chipset), you
|
|
should have a *separate* directory just for that, under `config/coreboot/`;
|
|
another directory for that board will have configs with `libgfxinit`. HOWEVER:
|
|
|
|
It *is* supported in lbmk to have SeaBIOS used, on either setup. In the
|
|
directory `config/seabios/` there are SeaBIOS configs for both; the vgarom
|
|
one sets VGA hardware type to *none* while the libgfxinit one sets it
|
|
to *coreboot linear framebuffer*. However, if you use SeaBIOS on a setup with
|
|
coreboot also doing option ROM initialization, such initialization is being
|
|
performed *twice*. As such, if you want to use an add-on graphics card in
|
|
SeaBIOS, but the board has libgfxinit, it is recommended that you do it from
|
|
a `libgfxinit` ROM.
|
|
|
|
HOWEVER: there's no hard and fast rule. For example, you could make a vgarom
|
|
configuration, on a board in lbmk, but in its coreboot configuration, don't
|
|
enable native init *or* oproms, and do SeaBIOS-only on that board.
|
|
|
|
On `vgarom` setups, coreboot can be configured to start with a high resolution
|
|
VESA frame buffer (NOT to be confused with the coreboot frame buffer), or just
|
|
normal text mode. Text mode startup is always recommended, and in that setup,
|
|
GRUB (including coreboot GRUB, but also PC GRUB) can use VGA modes.
|
|
|
|
The name `libgfxinit` is simply what `./mk -b coreboot` uses, but it may be
|
|
that a board uses the old-school native video init code written in C. On some
|
|
platforms, coreboot implemented a 3rd party library called `libgfxinit`, which
|
|
is written in Ada and handles video initialization. In this setup, coreboot
|
|
*itself* should *never* be configured to run any option ROMs, whether you
|
|
start in text mode or with the coreboot framebuffer initialization.
|
|
|
|
The `normal` config type is for desktop boards that lack onboard graphics
|
|
chipsets, where you would always use an add-on graphics card (or *no* graphics
|
|
card, which would be perfectly OK on servers).
|
|
|
|
Even if your board doesn't actually use `libgfxinit`, the config for it should
|
|
still be named as such. From a user's perspective, it really makes no
|
|
difference.
|
|
|
|
config/dependencies/
|
|
---------------
|
|
|
|
Files here are so named, and called like so: e.g. the `debian` file would be
|
|
referenced when running:
|
|
|
|
./mk dependencies debian
|
|
|
|
These files define a list of packages, and the correct package manager command
|
|
to use on a given distro. This can be used to install build dependencies, which
|
|
are required for compiling Libreboot from source code.
|
|
|
|
config/git/
|
|
---------------
|
|
|
|
Configuration related to third-party Git repositories, that Libreboot makes
|
|
use of.
|
|
|
|
These file define third party codebases, with repository links, revision IDs,
|
|
and dependencies (referring to other modules defined in this file).
|
|
|
|
Almost every third party codebase that lbmk downloads is based on the handling
|
|
of *this* file. Some of the codebases defined here will also have a directory
|
|
of their own; for example, `config/grub/` exists.
|
|
|
|
Multiple files exist here, and they are *concatenated* in a temporary file by
|
|
lbmk, which is then scanned to find information about projects.
|
|
|
|
config/data/PROJECT/mkhelper.cfg
|
|
--------------------------------
|
|
|
|
These `mkhelper.cfg` files define common configuration that can be supplied
|
|
for any single- or multi-tree project. Arguments available are as follows:
|
|
|
|
* `makeargs`: This defines what arguments to append when running the
|
|
main `make` command on a given project. For example, this is used on coreboot
|
|
to tell coreboot's build system that the submodules have been updated (to
|
|
avoid downloading any that we didn't manually specify).
|
|
* `build_depend`: Just before running the main `make` command on a given
|
|
project, this specifies other projects to build. It also works with multi
|
|
tree projects. Example: `seabios/default grub/xhci memtest86plus`
|
|
* `premake`: This defines a function to be called *before* running make, on a
|
|
given project; the mkhelper file itself can also import any given file to
|
|
provide that function.
|
|
* `mkhelper` (variable name): Defines a function to be called just after
|
|
running make, on a given project.
|
|
* `postmake`: This is run *after* `mkhelper`, and can be used for additional
|
|
functions. For example, it's used on coreboot to call `mkcoreboottar` which
|
|
will create tarballs of ROM images if `XBMK_RELEASE` is enabled.
|
|
|
|
You can define anything else here, for use by a given project. More specifically,
|
|
anything you put in mkhelper files will be imported as part of a normal shell
|
|
script during operation of lbmk, to complement core functionality across all
|
|
the various projects.
|
|
|
|
The `mkhelper` file is a global configuration for the project. Individual
|
|
projects can complement what is set in mkhelper, via `target.cfg` files for
|
|
each project, project tree or target on a given multi-tree project.
|
|
|
|
The `mkhelper` functionality (and postmake/premake) was originally implemented
|
|
so that lots of special configuration could be done per project, without a lot
|
|
of code repetition. This is a unique design of lbmk, different from many other
|
|
coreboot-distro build systems.
|
|
|
|
The `mkhelper` functionality is an essential component that makes lbmk work
|
|
the way it does; for example, the `trees` script builds coreboot images without
|
|
payloads, and functions to add payloads are handled by mkhelper-type functions.
|
|
This design allows almost all functionality to be centralised, where the mkhelper
|
|
functions only provide functionality that differs from core functionality.
|
|
|
|
In the simplest of terms, you may regard mkhelpers as *plugins*, of a sort.
|
|
They simply extend the core functionality of the build system, in a way that
|
|
can differ flexibly between projects.
|
|
|
|
GRUB config
|
|
---------------
|
|
|
|
### config/data/grub/background
|
|
|
|
Splash screen images applied duing startup when using the GRUB payload.
|
|
|
|
### config/data/grub/background/background1024x768.png
|
|
|
|
Used on ThinkPad X60 and T60.
|
|
|
|
### config/data/grub/background/background1280x800.png
|
|
|
|
Used on all other machines, besides X60 and T60 thinkpads.
|
|
|
|
NOTE: the `grub_background` option can be set under `target.cfg` in the
|
|
relevant coreboot directory, under `config/coreboot/`; for
|
|
example, `config/coreboot/x60/target.cfg` specifies this:
|
|
|
|
grub_background="background1024x768.png"
|
|
|
|
### config/data/grub/background/COPYING
|
|
|
|
Licensing info for GRUB bootsplash images.
|
|
|
|
### config/grub/TREE/config/
|
|
|
|
GRUB configuration files.
|
|
|
|
### config/grub/config/AUTHORS
|
|
|
|
Author info for GRUB configuration files.
|
|
|
|
### config/grub/config/COPYING
|
|
|
|
Licensing info for GRUB configuration files.
|
|
|
|
### config/grub/TREE/config/payload
|
|
|
|
This is a configuration file. It is used to program GRUB's shell.
|
|
|
|
This is inserted (as `grub.cfg`) into the GRUB memdisk, in the ROM image. It
|
|
contains a lot of logic in it, for booting various system configurations, when
|
|
the GRUB payload is in use.
|
|
|
|
It can be overridden by inserting `grub.cfg` into coreboot's main CBFS root.
|
|
|
|
A `grubtest.cfg` can be inserted into CBFS, but it will not override the
|
|
default `grub.cfg` (either in CBFS or on memdisk); however, the one in memdisk
|
|
will provide a menuentry for switching to this, if available.
|
|
|
|
### config/data/grub/memdisk.cfg
|
|
|
|
This GRUB configuration checks whether `grub.cfg` exists in CBFS and switches
|
|
to that first (not provided by default) or, if one is not available in CBFS,
|
|
it will load the `grub.cfg` stored inside GRUB memdisk.
|
|
|
|
The GRUB memdisk is a file system within `grub.elf`, itself stored within the
|
|
coreboot file system named *CBFS*, which is part of the coreboot ROM image on
|
|
every coreboot target.
|
|
|
|
### config/data/grub/keymap/
|
|
|
|
Keymap files used by GRUB. They can alter the character set corresponding to
|
|
inputted scancodes.
|
|
|
|
### config/data/grub/keymap/\*.gkb
|
|
|
|
The keymap files themselves. These are inserted into the GRUB memdisk, and
|
|
the `grub.cfg` file can specify which one is to be used.
|
|
|
|
These files are binary-encoded, defining which characters correspond to which
|
|
scancodes. It is handled by `grub-core/commands/keylayouts.c` in the GRUB source
|
|
code.
|
|
|
|
### config/data/grub/module/TREE
|
|
|
|
This defines which modules are inserted into `grub.elf`. These modules can be
|
|
anything from file systems, small applications/utilities, launchers (e.g.
|
|
the `linux` command will execute a Linux kernel), you name it.
|
|
|
|
Libreboot defines only a very conservative set of modules here, so as to reduce
|
|
the amount of space used in the main boot flash. (GRUB payloads are also
|
|
compressed when they are inserted into coreboot images)
|
|
|
|
This list is used by lbmk when it runs `grub-mkstandalone`, which is the utility
|
|
from GRUB that generates `grub.elf` files (to be compressed inside CBFS and then
|
|
executed as a coreboot payload).
|
|
|
|
### config/grub/TREE/patches/
|
|
|
|
For a given GRUB revision, patches with the `patch` file extension are placed
|
|
here, alphanumerically in the order that they should be applied. For example,
|
|
Libreboot provides argon2 key derivation support out of tree, allowing LUKS2
|
|
partitions to be decrypted by GRUB.
|
|
|
|
These patches are then so applied, when lbmk downloads the given source tree.
|
|
|
|
config/ifd/\*
|
|
---------------
|
|
|
|
Intel Flash Descriptors and GbE NVM images, which are binary-encoded
|
|
configuration files. These files are referenced in coreboot defconfigs, used
|
|
by lbmk to build coreboot ROM images.
|
|
|
|
config/seabios/
|
|
---------------
|
|
|
|
### config/data/seabios/build.list
|
|
|
|
When a given SeaBIOS tree is compiled, for a given target, this file defines
|
|
which files to copy from the `seabios/` directory, which are then copied to
|
|
a location under `elf/seabios`.
|
|
|
|
### config/seabios/default/
|
|
|
|
Currently the only tree in use, this defines what SeaBIOS revision is to be
|
|
used, when the SeaBIOS payload is enabled on a given coreboot target.
|
|
|
|
### config/seabios/default/config/
|
|
|
|
Configuration files go in here.
|
|
|
|
### config/seabios/default/config/libgfxinit
|
|
|
|
Configuration file for when native video initialisation is available in
|
|
coreboot.
|
|
|
|
### config/seabios/default/config/normal
|
|
|
|
Configuration file for when native video initialisation is unavailable in
|
|
coreboot, and VGA ROM initialisation is also not provided by coreboot (in
|
|
this configuration, the usual setup will be that *SeaBIOS* finds and
|
|
executes them, instead of coreboot).
|
|
|
|
### config/seabios/default/config/vgarom
|
|
|
|
Configuration file for when native video initialisation is unavailable in
|
|
coreboot, and VGA ROM initialisation is provided by coreboot; in this setup,
|
|
SeaBIOS should not execute VGA ROMs.
|
|
|
|
### config/seabios/default/target.cfg
|
|
|
|
Similar concept to `target.cfg` files provided by coreboot. This specifies
|
|
which SeaBIOS revision (from Git) is to be used, when compiling SeaBIOS images.
|
|
|
|
config/u-boot/
|
|
---------------
|
|
|
|
This directory contains configuration, patches and so on, for each mainboard
|
|
that can use U-Boot as a payload in the `lbmk` build system. U-Boot doesn't yet
|
|
have reliable generic configurations that can work across all coreboot boards
|
|
(per-architecture), so these are used to build it per-board.
|
|
|
|
### config/data/u-boot/build.list
|
|
|
|
When a given U-Boot tree is compiled, for a given target, this file defines
|
|
which files to copy from the U-Boot source build, which are then copied to
|
|
a location under `elf/u-boot/`.
|
|
|
|
### config/u-boot/TREENAME/
|
|
|
|
Each `TREENAME` directory defines configuration for a corresponding mainboard.
|
|
It doesn't actually have to be for a board; it can also be used to just define
|
|
a U-Boot revision, with patches and so on. To enable use as a payload in ROM
|
|
images, this must have the same name as its `config/coreboot/TREENAME/`
|
|
counterpart.
|
|
|
|
### config/u-boot/TREENAME/patches/
|
|
|
|
For any given U-Boot tree, patches with the `patch` file extension are placed
|
|
here, alphanumerically in the order that they should be applied.
|
|
|
|
These patches are then so applied, when lbmk downloads the given source tree.
|
|
|
|
### config/u-boot/TREENAME/target.cfg
|
|
|
|
This file can contain several configuration lines, each being a string, such
|
|
as:
|
|
|
|
* `tree="default"` (example entry)
|
|
* `rev="4debc57a3da6c3f4d3f89a637e99206f4cea0a96"` (example entry)
|
|
* `arch="AArch64"` (example entry)
|
|
|
|
These are similar in meaning to their coreboot counterparts.
|
|
|
|
The tree` entry is actually a link, where its value is a directory name
|
|
under `config/u-boot`. For example, `tree="default"` would refer to
|
|
`config/u-boot/default` and the corresponding U-Boot source tree created
|
|
(when running `./mk u-boot`, which makes use of `target.cfg`)
|
|
would be `u-boot/default/`. In other words: a `target.cfg` file
|
|
in `config/u-boot/foo` might refer to `config/u-boot/bar` by
|
|
specifying `tree="bar"`, and the created u-boot source tree would
|
|
be `u-boot/bar/`. ALSO:
|
|
|
|
FUN FACT: such references are infinitely checked until resolved. For
|
|
example, `foo` can refer to `bar` and `bar` can refer to `baz` but if there is
|
|
an infinite loop, this is detected and handled by lbmk. For example,
|
|
if `bar` refers to `foo` which refers back to `bar`, this is not permitted
|
|
and will throw an error in lbmk.
|
|
|
|
The `rev` entry defines which U-Boot revision to use, from the U-Boot
|
|
Git repository. *At present, lbmk only supports use of the official repository
|
|
from the upstream U-Boot project*.
|
|
|
|
The `arch` entry specifies which CPU architecture is to be used: currently
|
|
recognized entries are `x86_32`, `x86_64`, `ARMv7` and `AArch64`. *Setting it
|
|
to a non-native arch means that necessary crossgcc-arch will be compiled and be
|
|
available when building roms, but not necessarily built or discovered when
|
|
individual scripts are called manually.*
|
|
|
|
### config/u-boot/TREENAME/config/
|
|
|
|
Files in this directory are *U-Boot* configuration files. Configuration file
|
|
names can be anything, but for now `default` is the only one used.
|
|
|
|
In lbmk, a board-specific directory under `config/u-boot/` should never
|
|
specify a U-Boot revision. Rather, a directory *without* U-Boot configs should
|
|
be created, specifying a U-Boot revision. For example, the directory
|
|
`config/u-boot/default/` specifies a U-Boot revision. In the board-specific
|
|
directory, your `board.cfg` could then specify `ubtree="default"` but without
|
|
specifying a U-Boot revision (this is specified by
|
|
`config/u-boot/default/board.cfg`).
|
|
|
|
Normally, the U-Boot build process results in the U-Boot executable and a
|
|
device-tree file for the target board, which must further be packaged together
|
|
to make things work. When you create a U-Boot configuration, you should enable
|
|
`CONFIG_REMAKE_ELF` or `CONFIG_OF_EMBED` that handles this. The former option
|
|
enables creation of a `u-boot.elf` that bundles them together after the build,
|
|
and the latter option embeds it into the `u-boot` executable.
|
|
|
|
When making a U-Boot configuration, you should also pay special attention to
|
|
the `CONFIG_SYS_TEXT_BASE` (`CONFIG_TEXT_BASE` in later versions), whose defaults
|
|
may cause it to overlap coreboot, in which case it won't boot. Normally, the
|
|
upstream coreboot build system checks for this when given `CONFIG_PAYLOAD_ELF`,
|
|
but `lbmk` injects the payload itself and doesn't check for this yet.
|
|
|
|
Another interesting config option is `CONFIG_POSITION_INDEPENDENT` for ARM
|
|
boards, which has been so far enabled in the ones `lbmk` supports, just to be
|
|
safe.
|
|
|
|
config/submodule
|
|
----------------
|
|
|
|
In here you can find submodule configurations for projects. It works for both
|
|
single- and multi-tree projects. Use the existing examples as reference.
|
|
|
|
Files, in each directory:
|
|
|
|
* `module.list` lists paths (files and directories) for given modules, which
|
|
can be files(via URL) or Git repositories, or both.
|
|
* NAME/module.cfg
|
|
|
|
NAME is the file/directory name for the module, with everything up to the
|
|
final forward slash removed. E.g. foo/bar/thing.zip would be thing.zip as
|
|
NAME.
|
|
|
|
In `module.cfg` there can be either, file:
|
|
|
|
```
|
|
subfile="url"
|
|
subfile_bkup="url"
|
|
subhash="sha512sum for file"
|
|
```
|
|
|
|
or, git repository:
|
|
|
|
```
|
|
subrepo="url"
|
|
subrepo_bkup="url"
|
|
subhash="sha1 git commit id"
|
|
```
|
|
|
|
You must only use `subfile` or `subrepo`, not both, and there must be a backup
|
|
URL. The build system intentionally *avoids* using Git's actual submodules
|
|
feature, instead opting to download such repositories manually, because the
|
|
official submodules feature doesn't have very good redundancy.
|
|
|
|
Additionally, a `patches` directory can be included alongside `module.cfg`,
|
|
which can be used to patch the submodule (only supported for Git repositories
|
|
because files are not extracted, only placed at their configured destination).
|
|
|
|
The destination path in `module.list` is relative to the location of the main
|
|
Git repository under which it is placed.
|
|
|
|
config/data/PROJECT
|
|
-------------------
|
|
|
|
Random configuration data provided on a per-project basis. Complements
|
|
the `config/PROJECT` directory.
|
|
|
|
U-Boot build system
|
|
-------------------
|
|
|
|
If you wish to know about U-Boot, refer here:\
|
|
<https://u-boot.readthedocs.io/en/latest/>
|
|
|
|
This and other documents from U-Boot shall help you to understand *U-Boot*.
|
|
|
|
You create a config, for `config/u-boot/TREENAME/configs`, by finding the
|
|
corresponding board name in the upstream U-Boot `configs` directory, and
|
|
running `make BOARDNAME_defconfig` and `make menuconfig` commands in the
|
|
*U-Boot* build system. You should do this after
|
|
running `./mk u-boot` in lbmk.
|
|
|
|
You might want to consider basing your config on the upstream `coreboot` boards
|
|
when possible, but such a board is not available upstream for ARM yet.
|
|
|
|
You can simply clone U-Boot upstream, add whatever patches you want, and
|
|
then you can make your config. It will appear afterwards in a file
|
|
named `.config` which is your config for inside `config/u-boot/TREENAME/`.
|
|
|
|
You can then use `git format-patch -nX` where `X` is however many patches you
|
|
added to that U-Boot tree. You can put them in the patches directory
|
|
under `config/u-boot/BOARDNAME`.
|
|
|
|
The *base* revision, upon which any custom patches you wrote are applied,
|
|
shall be the `rev` entry.
|
|
|
|
Scripts exist in lbmk for automating the modification/updating of *existing*
|
|
configs, but not for adding them. Adding them is to be done manually, based on
|
|
the above guidance.
|
|
|
|
Config files in lbmk root directory
|
|
===================================
|
|
|
|
projectsite
|
|
-------------
|
|
|
|
Domain name linking to the project home page (e.g. libreboot.org).
|
|
|
|
projectname
|
|
---------------
|
|
|
|
This is a text file, containing a single line that says `libreboot`. This string
|
|
is used by the build system, when naming releases alongside the version number.
|
|
|
|
version
|
|
---------------
|
|
|
|
Updated each time lbmk runs, based on either `git describe` or, on release
|
|
archives, this file is static and never changes. It says what Libreboot revision
|
|
is currently in use (or was in use, if lbmk isn't running).
|
|
|
|
versiondate
|
|
---------------
|
|
|
|
Updated each time lbmk runs, based on either `git describe` or, on release
|
|
archives, this file is static and never changes. It says the *time* of
|
|
whichever Libreboot revision is currently in use (time of commit).
|
|
|
|
At last, you will now learn about the *scripts* (exclusively written as
|
|
posix shell scripts) that constitute the entire Libreboot build system, lbmk:
|
|
|
|
Scripts in root directory of lbmk
|
|
=================================
|
|
|
|
build
|
|
---------------
|
|
|
|
This is the main script. Symlinks `vendor` and `update` also point to it, as
|
|
does `mk`. Direct use of this script is considered deprecate, because in a
|
|
future audit, it will be removed; the `./mk` commands will be used,
|
|
exclusively, so please use only `./mk` as directed here and elsewhere.
|
|
|
|
Take any given file under `script/` and you can do:
|
|
|
|
./build file # (THIS IS NOT A VALID COMMAND)
|
|
|
|
For example:
|
|
|
|
./mk -b coreboot
|
|
./mk
|
|
|
|
Special commands available (not provided by files under `script/`):
|
|
|
|
./mk release
|
|
./mk inject
|
|
./mk -d coreboot TARGET # also downloads vendor files
|
|
|
|
The `vendor` commands are handled by the `build` script, calling functions
|
|
inside `include/vendor.sh`, and the `./mk release` logic is handled
|
|
directly by the `build` script.
|
|
|
|
More information about `./vendor` commands can be found
|
|
here: [inserting vendor files](../install/ivy_has_internal.md)
|
|
|
|
Information about `./mk release` is written elsewhere on this page.
|
|
|
|
You can also know what build system revision you have by running:
|
|
|
|
./mk version
|
|
|
|
This script is the beating heart of Libreboot. Break it and you break Libreboot.
|
|
|
|
include/
|
|
===============
|
|
|
|
This directory contains *helper scripts*, to be included
|
|
by main scripts using the `.` command (called the `source`
|
|
command in `bash`, but we rely upon posix `sh` only).
|
|
|
|
include/git.sh
|
|
--------------
|
|
|
|
These functions in here previously existed as independent scripts, but they
|
|
were unified here, and they are used when you pass the `-f` argument
|
|
to `script/update/trees` (e.g. `./mk -f coreboot`).
|
|
|
|
These functions deal with git cloning, submodule updates, revision resets and
|
|
the application of patch files via `git am`. *Every* git repository downloaded
|
|
by lbmk is handled by the functions in this file.
|
|
|
|
include/mrc.sh
|
|
--------------
|
|
|
|
This was previously a separate script. The download logic was removed, and
|
|
now the logic under `include/vendor.sh` is used for downloads. This file now
|
|
only contains those functions used for extraction of MRC files from Google
|
|
Chromebook images, currently only used for Haswell mainboards.
|
|
|
|
This is an include, used by `include/vendor.sh`, but it's here in
|
|
this file because the vendor download script is GPLv3-only, while the MRC
|
|
extract logic in this file is GPLv2-only (forked from coreboot ages ago). Thus,
|
|
it is provided as an include to bypass license incompatibility. It has been
|
|
heavily modified to use the same style of logic and general control flow used
|
|
in the script at `include/vendor.sh`, and it is used from there.
|
|
|
|
include/lib.sh
|
|
---------------
|
|
|
|
Several other parts of lbmk also use this file. It is added to as little as
|
|
possible, and contains miscallaneous functions that don't belong anywhere else.
|
|
|
|
The functions here are mostly those that deal with configuration files; scanning
|
|
them to set variables and so on.
|
|
|
|
This file also contains generic error handling, used by all lbmk scripts.
|
|
|
|
This also contains functions to verify the current libreboot version, and check
|
|
whether Git is properly initialised on the host system. It also contains
|
|
the `setvars` function, which provides a shorthand way of initialising many
|
|
variables (combined with use of `eval`), which lbmk uses heavily.
|
|
|
|
This function also contains `x_()` which lbmk uses to execute commands
|
|
and ensure that they cause an exit (with non-zero status) from lbmk, if they
|
|
return an error state.
|
|
|
|
This also includes the `mk()` function, which can be used as shorthand to
|
|
build multiple projects, but it doesn't handle targets within multi-tree projects,
|
|
so if for example you say `mk coreboot`, it would build every coreboot target.
|
|
This is useful for the release build logic, because now it can much more simply
|
|
build all of Libreboot, while still being flexible about it.
|
|
|
|
include/rom.sh
|
|
-----------
|
|
|
|
This builds coreboot ROM images. Specifically, this contains mkhelper functions.
|
|
It also builds serprog images, and it could be used to provide functions for
|
|
building other types of firmware.
|
|
|
|
Command: `./mk -b coreboot targetname`
|
|
|
|
The `targetname` argument must be specified, chosen from this output:
|
|
|
|
./mk -b coreboot list
|
|
|
|
Pass several board names if you wish to build only for specific targets. For
|
|
example:
|
|
|
|
./mk -b coreboot x60 x200_8mb
|
|
|
|
To build *all* targets, specify:
|
|
|
|
./mk -b coreboot
|
|
|
|
For x86 targets, these scripts build with the GRUB and/or SeaBIOS payloads
|
|
inserted into the ROM images; secondary payloads like Memtest86+ are also
|
|
handled and inserted here.
|
|
|
|
It heavily makes use of the `target.cfg` file, for a given board. This script
|
|
will *only* operate on a single target, from a directory in `config/coreboot/`.
|
|
|
|
If `grub_scan_disk` is set, it sets that in the `scan.cfg` file that is to be
|
|
inserted into a ROM image, when `payload_grub` is turned on.
|
|
|
|
It automatically detects if `crossgcc` is to be compiled, on a given coreboot
|
|
tree (in cases where it has not yet been compiled), and compiles it for a
|
|
target based on the `arch` entry in `target.cfg`.
|
|
|
|
It creates ROM images with GRUB, SeaBIOS, U-Boot, optionally with Memtest86+
|
|
also included, in various separate configurations in many different ROM images
|
|
for user installation.
|
|
|
|
If no payload is defined in `target.cfg`, the `build/roms` script will exit
|
|
with error status.
|
|
|
|
If SeaBIOS is to be used, on `libgfxinit` setups, SeaVGABIOS will also be
|
|
inserted. This provides a minimal VGA compatibility layer on top of the
|
|
coreboot framebuffer, but does not allow for *switching* the VGA mode. It is
|
|
currently most useful for directly executing ISOLINUX/SYSLINUX bootloaders,
|
|
and certain OS software (some Windows setups might work, poorly, depending on
|
|
the board configuration, but don't hold your breath; it is far from complete).
|
|
|
|
If SeaBIOS is to be used, in `vgarom` setups or `normal` setups, SeaVGABIOS
|
|
is not inserted and you rely on either coreboot and/or SeaBIOS to execute VGA
|
|
option ROMs.
|
|
|
|
In all cases, this script automatically inserts several SeaBIOS runtime
|
|
configurations, such as: `etc/ps2-keyboard-spinup` set to 3000 (PS/2 spinup
|
|
wait time), `etc/pci-optionrom-exec` set to 2 (despite that already being
|
|
the default anyway) to enable *all* option ROMs, unless `vgarom` setups are
|
|
used, in which case the option is set to *0* (disabled) because coreboot is
|
|
then expected to handle option ROMs, and SeaBIOS should not do it.
|
|
|
|
This script handles U-Boot separately, for ARM-based chromeos devices.
|
|
|
|
When the ROM is finished compiling, it will appear under a directory in `bin/`
|
|
|
|
This script is the beating heart of Libreboot. Break it, and you break
|
|
Libreboot!
|
|
|
|
CCACHE is automatically used, when building coreboot, but not currently for
|
|
other projects. This is done by cooking coreboot configs at build time, enabling
|
|
coreboot's build option for it.
|
|
|
|
Serprog images:
|
|
--------------
|
|
|
|
Build firmware images for serprog-based SPI programmers, where they use an
|
|
STM32 MCU. It also builds for RP2040-based programmers like Raspberry Pi Pico.
|
|
|
|
Example command: `./mk -b pico-serprog`
|
|
|
|
Example command: `./mk -b stm32-vserprog`
|
|
|
|
This also uses `rom.sh` as with the coreboot image build logic. It's all
|
|
defined in that file, so read the main section pertaining to this file.
|
|
|
|
include/vendor.sh
|
|
-----------------
|
|
|
|
Helper functions for downloading and injecting vendor files. How to use:
|
|
|
|
./mk inject ARGUMENTS
|
|
./mk -d coreboot TARGET
|
|
|
|
Refer elsewhere in the documentation for how to handle vendor files.
|
|
|
|
script/
|
|
=======
|
|
|
|
script/trees
|
|
------------
|
|
|
|
*This* is the other beating heart of Libreboot. Used heavily by Libreboot, this
|
|
script is what handles defconfig files for SeaBIOS, U-Boot *and* coreboot; it
|
|
used to be separate scripts, but the logic was unified under this single script.
|
|
|
|
It *also* handles simple git trees, where there is only one revision for the
|
|
project, e.g. GRUB, and the command syntax is the same. Whether a project is
|
|
multi-tree or single-tree is determined by the presence of the
|
|
file `config/PROJECT/build.list` - if it exists, it's multi-tree, otherwise
|
|
single-tree.
|
|
|
|
It *also*, in addition to downloading from git, can handle modification or
|
|
updating of defconfig files. As already stated, and stated further: it is
|
|
Libreboot's other beating heart. Break this, and you break Libreboot.
|
|
|
|
For multi-tree projects, it handles the following files (PROJECT can
|
|
be `coreboot`, `seabios` or `u-boot`):
|
|
|
|
* `config/PROJECT/build.list` (defines what files to copy, after building for
|
|
the target)
|
|
* `config/PROJECT/*/target.cfg` (lbmk build parameters, project project/target)
|
|
* `config/PROJECT/*/config/*` (defconfig files)
|
|
|
|
For single-tree projects, these files are used:
|
|
|
|
* `config/git/` - files are concatenated and then scanned, to find project info.
|
|
|
|
NOTE: For multi-tree projects, `config/git` is still used, to download the
|
|
upstream repository to `src/PROJECT/PROJECT` but with git revision being `HEAD`.
|
|
In this way, you always have the latest code, but revisions defined
|
|
in `config/PROJECT/TARGET/target.cfg` will define a tree,
|
|
then `config/PROJECT/TREE/target.cfg` (which could be the same as `TARGET`,
|
|
but this is not the preferred style in lbmk) will define a revision; then,
|
|
the directory `src/PROJECT/TREE` will be created, reset to the specific
|
|
revision - for multi-tree projects, all defined targets are scanned for their
|
|
corresponding tree, and the trees are prepared as defined above.
|
|
|
|
Basic command: `./mk FLAG projectname`
|
|
|
|
Special operation: for building coreboot utilities `cbfstool` and `ifdtool` to
|
|
go under `cbutils/`, do this:
|
|
|
|
./mk -d coreboot TREENAME
|
|
|
|
Or define specific coreboot tree such as:
|
|
|
|
./mk -d coreboot default
|
|
./mk -d coreboot cros
|
|
|
|
FLAG values are (only *one* to be used at a time):
|
|
|
|
* `-b` builds an image for the target, based on defconfig for multi-tree
|
|
projects, or based only on a Makefile for single-tree projects; on some
|
|
single-tree projects, this script also handles *cmake*.
|
|
* `-u` runs `make oldconfig` on the target's corresponding source tree, using
|
|
its defconfig (useful for automatically updating configs, when updating trees
|
|
like when adding patches or switching git revisions)
|
|
* `-m` runs `make menuconfig` on the target's corresponding source tree, using
|
|
its defconfig (useful for modifying configs, e.g. changing CBFS size on
|
|
a coreboot image)
|
|
* `-c` tries `make distclean`, deferring to `make clean` under fault
|
|
conditions and from that, non-zero exit under fault conditions. This is done
|
|
on the target's corresponding source tree.
|
|
* `-x` tries 'make crossgcc-clean`. This only works on coreboot trees, but no
|
|
error status will be returned on exit if you try it on other project trees; no
|
|
action will be performed.
|
|
* `-f` downloads the Git repository for the given project, and resets to a
|
|
revision as defined under `config/git/`, or (for multi-tree projects), the
|
|
file `config/PROJECT/TREE/target.cfg` to create `src/project/treename`.
|
|
|
|
As for *projectname", this can either be `coreboot`, `u-boot` or `seabios`.
|
|
|
|
Example commands:
|
|
|
|
./mk -b coreboot
|
|
./mk -b coreboot x200_8mb
|
|
./mk -b coreboot x230_12mb x220_8mb t1650_12mb
|
|
./mk -x coreboot default
|
|
./mk -u seabios
|
|
./mk -m u-boot gru_bob
|
|
./mk -f coreboot
|
|
./mk -d coreboot default
|
|
./mk -d coreboot
|
|
|
|
NOTE: the `-x` and `-c` options will cause an exit with zero status, when
|
|
the target's corresponding source tree is unavailable; a non-zero status is
|
|
only return under fault conditions when said source tree is *available*. ALL
|
|
other flags will cause the very same source tree to be downloaded and prepared,
|
|
if unavailable and *that* too will return with non-zero status under fault
|
|
conditions.
|
|
|
|
NOTE: "target" can indeed be the tree name, under some circumstances. For
|
|
example, `./mk -m seabios default`
|
|
|
|
After `projectname`, a target can be specified, but if no target is specified,
|
|
then *all* targets will be operated on. For
|
|
example, `./mk -b coreboot` will attempt to build *all*
|
|
coreboot ROM images.
|
|
|
|
NOTE: the `coreboot` projectname here shall cause the ROM images to go
|
|
under `elf/` - this is the no-payload ROM images, which are later used
|
|
separately by `script/build/roms` to provide full images, with
|
|
payloads inserted. It is an intentional design choice of Libreboot, to split
|
|
it up this way and *not* use coreboot's own build system to handle payloads.
|
|
|
|
In lbmk, there are *two* types of git download: *simple* downloads where only
|
|
a single revision would ever be used, or *multi* downloads where different
|
|
revisions are used depending on target.
|
|
|
|
All such downloads are *simple* downloads, except for coreboot, U-Boot and
|
|
SeaBIOS which are *multi* downloads. The *other* requirement is that defconfigs
|
|
be used, though this could be worked around in the future if a *multi* setup is
|
|
needed on a project that *does not use defconfigs* (this is not yet the case in
|
|
lbmk).
|
|
|
|
All of this used to about 20 different scripts, all with much-duplicated logic.
|
|
Now it is unified, efficiently, under a single script.
|
|
|
|
Remember: code equals bugs, so less code equals fewer bugs.
|