Merge branch '2022-04-25-initial-implementation-of-stdboot'
authorTom Rini <trini@konsulko.com>
Mon, 25 Apr 2022 20:02:27 +0000 (16:02 -0400)
committerTom Rini <trini@konsulko.com>
Mon, 25 Apr 2022 20:02:27 +0000 (16:02 -0400)
commit8cfac237b9814d52c843e939a05fc211ba3906de
tree975bba394b3c71a225283c2cb04ecda5c4bb189d
parentbc9da9fb50ac3ba7603487a0366d4db60b984812
parente7b2ce191ecab558b130b3b926dddcfc7231deb0
Merge branch '2022-04-25-initial-implementation-of-stdboot'

To quote the author:
The bootflow feature provide a built-in way for U-Boot to automatically
boot an Operating System without custom scripting and other customisation.
This is called 'standard boot' since it provides a standard way for
U-Boot to boot a distro, without scripting.

It introduces the following concepts:

   - bootdev - a device which can hold a distro
   - bootmeth - a method to scan a bootdev to find bootflows (owned by
                U-Boot)
   - bootflow - a description of how to boot (owned by the distro)

This series provides an implementation of these, enabled to scan for
bootflows from MMC, USB and Ethernet. It supports the existing distro
boot as well as the EFI loader flow (bootefi/bootmgr). It works
similiarly to the existing script-based approach, but is native to
U-Boot.

With this we can boot on a Raspberry Pi 3 with just one command:

   bootflow scan -lb

which means to scan, listing (-l) each bootflow and trying to boot each
one (-b). The final patch shows this.

With a standard way to identify boot devices, booting become easier. It
also should be possible to support U-Boot scripts, for backwards
compatibility only.

...

The design is described in these two documents:

https://drive.google.com/file/d/1ggW0KJpUOR__vBkj3l61L2dav4ZkNC12/view?usp=sharing

https://drive.google.com/file/d/1kTrflO9vvGlKp-ZH_jlgb9TY3WYG6FF9/view?usp=sharing
MAINTAINERS
cmd/Kconfig
drivers/block/blk-uclass.c
include/dm/uclass-id.h