env: allow environment to be amended from control dtb
authorRasmus Villemoes <rasmus.villemoes@prevas.dk>
Wed, 21 Apr 2021 09:06:54 +0000 (11:06 +0200)
committerTom Rini <trini@konsulko.com>
Tue, 4 May 2021 15:50:50 +0000 (11:50 -0400)
commit95fd9772011f29fad2c40fbc3060b5dac042152c
treee06d8d10b7e5cd0b011372786ae918067b982d3e
parent1cbfed8d3e9254d7e2a9466498ef867f7cb3f4cd
env: allow environment to be amended from control dtb

It can be useful to use the same U-Boot binary for multiple purposes,
say the normal one, one for developers that allow breaking into the
U-Boot shell, and one for use during bootstrapping which runs a
special-purpose bootcmd. Or one can have several board variants that
can share almost all boot logic, but just needs a few tweaks in the
variables used by the boot script.

To that end, allow the control dtb to contain a /config/enviroment
node (or whatever one puts in fdt_env_path variable), whose
property/value pairs are used to update the run-time environment after
it has been loaded from its persistent location.

The indirection via fdt_env_path is for maximum flexibility - for
example, should the user wish (or board logic dictate) that the values
in the DTB should no longer be applied, one simply needs to delete the
fdt_env_path variable; that can even be done automatically by
including a

  fdt_env_path = "";

property in the DTB node.

Reviewed-by: Simon Glass <sjg@chromium.org>
Signed-off-by: Rasmus Villemoes <rasmus.villemoes@prevas.dk>
Acked-by: Joe Hershberger <joe.hershberger@ni.com>
common/board_r.c
env/Kconfig
env/common.c
include/env.h
include/env_default.h