[PATCH 1/2] bloblist: fix the overriding of fdt from bloblist
Raymond Mao
raymond.mao at linaro.org
Fri Mar 28 15:28:00 CET 2025
Hi Caleb,
On Fri, 28 Mar 2025 at 08:27, Caleb Connolly <caleb.connolly at linaro.org> wrote:
>
>
>
> On 3/28/25 11:44, Caleb Connolly wrote:
> > Hi Raymond,
> >
> > On 3/28/25 00:13, Raymond Mao wrote:
> >> When a bloblist is valid and contains fdt, it explicitly means
> >> a previous boot stage is passing transfer list compliant with
> >> Firmware Handoff specification, thus the fdt from bloblist should
> >> not be overridden with the ones from board or env variables.
>
> Actually, I'm a little confused here. Can you point to the documentation
> that says an FDT from a bloblist should always take priority?
>
> I can see why this makes sense to lock down, but clarification would be
> good regardless.
>
All the adaptations on bloblist are in order to make it compliant with
the Firmware Handoff spec [1].
In the spec, all data being handed over between boot stages should be
within a transfer list (aka. bloblist in U-Boot).
So the logic is clear to me, when the bloblist contains a valid fdt,
that explicitly means the previous boot stages are passing arguments
following the Firmware Handoff spec, and U-Boot should follow the same
way to pass them to the next stage - kernel.
[1]: https://github.com/FirmwareHandoff/firmware_handoff
Regards,
Raymond
> Kind regards,
> >>
> >> Fixes: 70fe23859437 ("fdt: Allow the devicetree to come from a bloblist")
> >> Signed-off-by: Raymond Mao <raymond.mao at linaro.org>
> >
> > Reviewed-by: Caleb Connolly <caleb.connolly at linaro.org>
> >> ---
> >> lib/fdtdec.c | 3 ++-
> >> 1 file changed, 2 insertions(+), 1 deletion(-)
> >>
> >> diff --git a/lib/fdtdec.c b/lib/fdtdec.c
> >> index f09c9926a7a..c38738b48c7 100644
> >> --- a/lib/fdtdec.c
> >> +++ b/lib/fdtdec.c
> >> @@ -1708,7 +1708,7 @@ int fdtdec_setup(void)
> >> gd->fdt_src = FDTSRC_BLOBLIST;
> >> log_debug("Devicetree is in bloblist at %p\n",
> >> gd->fdt_blob);
> >> - ret = 0;
> >> + goto setup_fdt;
> >> } else {
> >> log_debug("No FDT found in bloblist\n");
> >> ret = -ENOENT;
> >> @@ -1752,6 +1752,7 @@ int fdtdec_setup(void)
> >> }
> >> }
> >> +setup_fdt:
> >> if (CONFIG_IS_ENABLED(MULTI_DTB_FIT))
> >> setup_multi_dtb_fit();
> >
>
> --
> Caleb (they/them)
>
More information about the U-Boot
mailing list