From: Ahmad Fatoum <a.fatoum@pengutronix.de>
To: barebox@lists.infradead.org
Cc: Ahmad Fatoum <a.fatoum@pengutronix.de>
Subject: [PATCH 14/16] defaultenv: base: add new devboot script
Date: Thu, 12 Mar 2026 15:44:57 +0100 [thread overview]
Message-ID: <20260312144505.2159816-14-a.fatoum@pengutronix.de> (raw)
In-Reply-To: <20260312144505.2159816-1-a.fatoum@pengutronix.de>
devboot is a new command wrapper that makes it easier to use overrides
with network-provided artifacts:
- On the host side, add a *-devboot-* script that describes which
overrides to use
- On the barebox side, ensure the script can be found at either
${fetchfs}/${global.user}-devboot-${global.hostname} or
${fetchfs}/${global.user}-devboot-${global.arch}
- barebox will source this script and pass the applicable overrides
to the boot command in addition to whatever arguments devboot
was given
Here's an example *-devboot-* script:
devboot_image=afa-fit-rock3a
devboot_oftree= # force use of barebox DT
devboot_initrd=":afa-rsinit-arm64" # append specified CPIO to FIT's
global linux.bootargs.dyn.rsinit=rsinit.bind=/lib/modules
Signed-off-by: Ahmad Fatoum <a.fatoum@pengutronix.de>
---
Documentation/user/booting-linux.rst | 5 +-
Documentation/user/devboot.rst | 204 +++++++++++++++++++++++
Documentation/user/user-manual.rst | 1 +
defaultenv/defaultenv-2-base/bin/devboot | 48 ++++++
defaultenv/defaultenv-2-base/boot/devel | 3 +
5 files changed, 260 insertions(+), 1 deletion(-)
create mode 100644 Documentation/user/devboot.rst
create mode 100644 defaultenv/defaultenv-2-base/bin/devboot
create mode 100755 defaultenv/defaultenv-2-base/boot/devel
diff --git a/Documentation/user/booting-linux.rst b/Documentation/user/booting-linux.rst
index ed1ec3f68a93..3972777f30cf 100644
--- a/Documentation/user/booting-linux.rst
+++ b/Documentation/user/booting-linux.rst
@@ -182,7 +182,10 @@ and configure the overrides as arguments to the ``boot`` command:
.. code-block:: sh
- boot -o bootm.image=/mnt/tftp/oftree mmc
+ boot -o bootm.image=/mnt/tftp/zImage mmc
+
+See :ref:`devboot` for the full override syntax and the ``devboot``
+convenience script for network-based development.
Generic Boot Targets
^^^^^^^^^^^^^^^^^^^^
diff --git a/Documentation/user/devboot.rst b/Documentation/user/devboot.rst
new file mode 100644
index 000000000000..ad1b4c909ab0
--- /dev/null
+++ b/Documentation/user/devboot.rst
@@ -0,0 +1,204 @@
+.. _devboot:
+
+Devboot
+=======
+
+Devboot is a development convenience that builds on top of the
+:ref:`boot override <boot_overrides>` mechanism. It sources a per-user,
+per-board script from the network and translates it into ``boot -o``
+arguments, making it easy to redirect any combination of kernel, device tree
+and initrd to network-hosted files without touching the boot medium.
+
+.. _boot_overrides:
+
+Boot overrides
+--------------
+
+Enable ``CONFIG_BOOT_OVERRIDE`` to allow partial overrides of boot entries.
+This is already enabled in ``multi_v7_defconfig`` and ``multi_v8_defconfig``.
+
+The ``boot`` command then accepts one or more ``-o`` flags:
+
+.. code-block:: sh
+
+ boot -o bootm.image=/mnt/tftp/my-zImage mmc
+ boot -o bootm.oftree=/mnt/tftp/my-board.dtb mmc
+ boot -o bootm.initrd=/mnt/tftp/my-initrd mmc
+
+Multiple overrides can be combined in a single invocation:
+
+.. code-block:: sh
+
+ boot -o bootm.image=/mnt/tftp/zImage \
+ -o bootm.oftree=/mnt/tftp/board.dtb \
+ -o bootm.initrd=/mnt/tftp/initrd \
+ mmc
+
+Overrides are applied after the boot entry has been loaded, so the original
+entry still selects the boot handler, kernel arguments, etc. Only the
+specified components are replaced.
+
+Override rules
+^^^^^^^^^^^^^^
+
+``bootm.image``
+ The override file is probed for its type. If it is a FIT image, the
+ FIT configuration is re-opened and all components (kernel, initrd, device
+ tree) are taken from the override FIT. If it is a plain kernel image
+ (zImage, Image, uImage, ...), only the OS loadable is replaced.
+
+``bootm.oftree``
+ A colon-separated list of files. The first entry is the base device tree;
+ subsequent entries are applied as overlays:
+
+ .. code-block:: sh
+
+ # Use a as the device tree
+ boot -o bootm.oftree=a mmc
+
+ # Use a as the device tree, apply b as overlay
+ boot -o bootm.oftree=a:b mmc
+
+ # Keep the existing device tree, apply b as overlay
+ boot -o bootm.oftree=:b mmc
+
+ # Use a as the device tree, apply b and c as overlays
+ boot -o bootm.oftree=a:b:c mmc
+
+ Setting ``bootm.oftree`` to an empty string (``bootm.oftree=``) discards
+ whatever device tree the boot entry provides. If
+ ``CONFIG_BOOTM_OFTREE_FALLBACK`` is enabled (the default), the
+ barebox-internal device tree is passed to the kernel instead. If the
+ option is disabled, no device tree is passed at all.
+
+``bootm.initrd``
+ A colon-separated list of initrd/CPIO files. Linux can transparently
+ extract any number of concatenated CPIOs, even if individually compressed.
+ A leading colon appends to the initrd that the boot entry already provides:
+
+ .. code-block:: sh
+
+ # Replace with a single initrd
+ boot -o bootm.initrd=/mnt/tftp/initrd mmc
+
+ # Concatenate two initrds
+ boot -o bootm.initrd=initrd1:initrd2 mmc
+
+ # Append an extra CPIO to the existing initrd
+ boot -o bootm.initrd=:extra.cpio mmc
+
+ .. tip::
+
+ The Linux kernel ``make cpio-modules-pkg`` target builds a CPIO archive
+ containing all kernel modules. This is useful for supplementing an existing
+ initramfs with modules without modifying the root filesystem.
+ Combined with initrd concatenation, a devboot script
+ can append it to any boot entry's initrd::
+
+ devboot_initrd=":afa-modules-arm64"
+
+ To make use of the modules, the initramfs init will need to make initramfs
+ /modules available to the rootfs, e.g. via a bind mount:
+
+ mount -n --bind /lib/modules ${ROOT_MOUNT}/lib/modules
+
+.. note::
+
+ When secure boot is enforced (``bootm_signed_images_are_forced()``),
+ overrides are silently ignored.
+
+The devboot script
+------------------
+
+The ``devboot`` command (``/env/bin/devboot``) automates the override
+workflow for network-based development:
+
+1. Brings up the network (``ifup -a1``).
+2. Changes into the fetch directory
+ (:ref:`global.net.fetchdir <magicvar_global_net_fetchdir>`, default
+ ``/mnt/tftp``).
+3. Sources a configuration script named
+ ``${global.user}-devboot-${global.hostname}``. If that file does not
+ exist, it falls back to ``${global.user}-devboot-${global.arch}``.
+4. Translates the variables set by the script into ``boot -o`` arguments.
+5. Passes any extra arguments through to the ``boot`` command.
+
+.. note::
+
+ TFTP is not a real file system, e.g., listing of directories is not
+ possible. Keep that in mind if the devboot script does more than
+ just fetch files by name from TFTP.
+
+Usage
+^^^^^
+
+.. code-block:: sh
+
+ # Boot from MMC with devboot overrides
+ devboot mmc
+
+ # Boot from the default boot entry
+ devboot
+
+ # Make devboot the default for subsequent boots
+ nv.boot.default=devel
+
+Configuration script
+^^^^^^^^^^^^^^^^^^^^
+
+The configuration script lives in the fetch directory and sets up to three
+variables:
+
+``devboot_image``
+ Override for ``bootm.image``. Path is relative to the fetch directory.
+
+``devboot_oftree``
+ Override for ``bootm.oftree``. An empty string discards the boot
+ entry's device tree (see ``bootm.oftree`` rules above).
+
+``devboot_initrd``
+ Override for ``bootm.initrd``. A leading colon appends to the boot
+ entry's existing initrd.
+
+Variables that are not set (using ``[[ -v ... ]]``) are left alone,
+so unset variables do not generate override arguments.
+
+The script can also set arbitrary barebox variables, for example
+kernel command line fragments:
+
+.. code-block:: sh
+
+ # /tftpboot/afa-devboot-rock3a
+ devboot_image=afa-fit-rock3a
+ devboot_oftree=
+ devboot_initrd=":afa-rsinit-arm64"
+
+ global linux.bootargs.dyn.rsinit="rsinit.bind=/lib/modules"
+
+With this script in place and ``global.user=afa``, ``global.hostname=rock3a``,
+running ``devboot mmc`` on the board expands to::
+
+ boot -o bootm.image="afa-fit-rock3a" \
+ -o bootm.oftree="" \
+ -o bootm.initrd=":afa-rsinit-arm64" \
+ mmc
+
+This fetches the FIT image ``afa-fit-rock3a`` from the fetch directory,
+discards the FIT's device tree (falling back to the barebox-internal one
+when ``CONFIG_BOOTM_OFTREE_FALLBACK`` is enabled), and appends the
+``afa-rsinit-arm64`` CPIO archive to whatever initrd the FIT already
+contains.
+
+Setting up the variables
+^^^^^^^^^^^^^^^^^^^^^^^^
+
+The ``global.user`` and ``global.hostname`` variables control which
+script is loaded. Make them persistent with:
+
+.. code-block:: sh
+
+ nv user=afa
+ nv hostname=rock3a
+
+``global.hostname`` is typically derived from the device tree, but can be
+overridden.
diff --git a/Documentation/user/user-manual.rst b/Documentation/user/user-manual.rst
index cb01721863dd..aa55017c69d7 100644
--- a/Documentation/user/user-manual.rst
+++ b/Documentation/user/user-manual.rst
@@ -26,6 +26,7 @@ Contents:
usb
ubi
booting-linux
+ devboot
bootchooser
remote-control
security
diff --git a/defaultenv/defaultenv-2-base/bin/devboot b/defaultenv/defaultenv-2-base/bin/devboot
new file mode 100644
index 000000000000..124bfec01ba3
--- /dev/null
+++ b/defaultenv/defaultenv-2-base/bin/devboot
@@ -0,0 +1,48 @@
+#!/bin/sh
+
+devboot_path="${global.net.fetchdir}"
+
+# global.net.server and global.hostname may be set by DHCP, so trigger it first
+ifup -a1
+
+cd "${devboot_path}" || exit 1
+saved_pwd="$OLDPWD"
+
+devboot_script="${global.user}-devboot-${global.hostname}"
+if [ ! -f "${devboot_script}" ]; then
+ devboot_script2="${global.user}-devboot-${global.arch}"
+ if [ ! -f "${devboot_script2}" ]; then
+ echo "Error: Neither ${devboot_script} nor ${devboot_script2} found"
+ echo "Create one of them and set as needed:"
+ echo " devboot_image, devboot_initrd, devboot_oftree"
+ cd "${saved_pwd}"
+ exit 1
+ fi
+ devboot_script="${devboot_script2}"
+fi
+
+echo Sourcing "${devboot_path}/${devboot_script}"
+source "${devboot_path}/${devboot_script}"
+if [ $? -ne 0 ]; then
+ cd "${saved_pwd}"
+ exit 1
+fi
+
+override_args=""
+
+if [[ -v devboot_image ]]; then
+ override_args="${override_args} -o bootm.image=\"${devboot_image}\""
+fi
+
+if [[ -v devboot_oftree ]]; then
+ override_args="${override_args} -o bootm.oftree=\"${devboot_oftree}\""
+fi
+
+if [[ -v devboot_initrd ]]; then
+ override_args="${override_args} -o bootm.initrd=\"${devboot_initrd}\""
+fi
+
+echo boot ${override_args} $*
+boot ${override_args} $*
+
+cd "${saved_pwd}"
diff --git a/defaultenv/defaultenv-2-base/boot/devel b/defaultenv/defaultenv-2-base/boot/devel
new file mode 100755
index 000000000000..9bcaaffb5870
--- /dev/null
+++ b/defaultenv/defaultenv-2-base/boot/devel
@@ -0,0 +1,3 @@
+#!/bin/sh
+
+devboot
--
2.47.3
next prev parent reply other threads:[~2026-03-12 15:03 UTC|newest]
Thread overview: 22+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-03-12 14:44 [PATCH 01/16] lib: add lazy loadable infrastructure for deferred boot component loading Ahmad Fatoum
2026-03-12 14:44 ` [PATCH 02/16] bootm: split preparatory step from handler invocation Ahmad Fatoum
2026-03-12 14:44 ` [PATCH 03/16] boot: add bootm_boot wrapper that takes struct bootentry Ahmad Fatoum
2026-03-12 14:44 ` [PATCH 04/16] bootchooser: pass along " Ahmad Fatoum
2026-03-12 14:44 ` [PATCH 05/16] bootm: switch plain file names case to loadable API Ahmad Fatoum
2026-03-12 14:44 ` [PATCH 06/16] uimage: add offset parameter to uimage_load Ahmad Fatoum
2026-03-12 14:44 ` [PATCH 07/16] bootm: uimage: switch to loadable API Ahmad Fatoum
2026-03-12 14:44 ` [PATCH 08/16] bootm: fit: switch to new " Ahmad Fatoum
2026-03-12 14:44 ` [PATCH 09/16] bootm: stash initial OS address/entry in image_data Ahmad Fatoum
2026-03-12 14:44 ` [PATCH 10/16] bootm: support multiple entries for bootm.initrd Ahmad Fatoum
2026-03-12 14:44 ` [PATCH 11/16] bootm: implement plain and FIT bootm.image override Ahmad Fatoum
2026-03-18 9:01 ` Sascha Hauer
2026-03-18 9:17 ` Ahmad Fatoum
2026-03-12 14:44 ` [PATCH 12/16] bootm: overrides: add support for overlays Ahmad Fatoum
2026-03-12 14:44 ` [PATCH 13/16] test: py: add test for initrd concatenation Ahmad Fatoum
2026-03-12 14:44 ` Ahmad Fatoum [this message]
2026-03-18 9:50 ` [PATCH 14/16] defaultenv: base: add new devboot script Sascha Hauer
2026-03-18 10:50 ` Ahmad Fatoum
2026-03-18 14:49 ` Sascha Hauer
2026-03-12 14:44 ` [PATCH 15/16] Documentation: user: devboot: add section on forwarding build dirs Ahmad Fatoum
2026-03-12 14:44 ` [PATCH 16/16] libfile: remove file_to_sdram Ahmad Fatoum
2026-03-18 10:06 ` [PATCH 01/16] lib: add lazy loadable infrastructure for deferred boot component loading Sascha Hauer
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20260312144505.2159816-14-a.fatoum@pengutronix.de \
--to=a.fatoum@pengutronix.de \
--cc=barebox@lists.infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox