[PATCH v3 1/9] bloblist: add API to check the register conventions
Simon Glass
sjg at chromium.org
Tue Dec 26 10:47:44 CET 2023
Hi Raymond,
On Fri, Dec 22, 2023 at 9:31 PM Raymond Mao <raymond.mao at linaro.org> wrote:
>
> Add bloblist_check_reg_conv() to check whether the bloblist is compliant
> to the register conventions defined in Firmware Handoff specification.
> This API can be used for all Arm platforms.
>
> Signed-off-by: Raymond Mao <raymond.mao at linaro.org>
> ---
> Changes in v2
> - Refactor of bloblist_check_reg_conv().
> Changes in v3
> - bloblist_check_reg_conv() returns -ENOENT if OF_BOARD is disabled.
>
> common/bloblist.c | 13 +++++++++++++
> include/bloblist.h | 12 ++++++++++++
> 2 files changed, 25 insertions(+)
>
> diff --git a/common/bloblist.c b/common/bloblist.c
> index 625e480f6b..ba17dd851a 100644
> --- a/common/bloblist.c
> +++ b/common/bloblist.c
> @@ -542,3 +542,16 @@ int bloblist_maybe_init(void)
>
> return 0;
> }
> +
> +int bloblist_check_reg_conv(ulong rfdt, ulong rzero)
> +{
> + if (!IS_ENABLED(CONFIG_OF_BOARD))
> + return -ENOENT;
> +
> + if (rzero || rfdt != (ulong)bloblist_find(BLOBLISTT_CONTROL_FDT, 0)) {
> + gd->bloblist = NULL; /* Reset the gd bloblist pointer */
> + return -EIO;
> + }
Where does the magic 4a0fb10b value get checked?
> +
> + return 0;
> +}
> diff --git a/include/bloblist.h b/include/bloblist.h
> index 84fc943819..bd32e38a06 100644
> --- a/include/bloblist.h
> +++ b/include/bloblist.h
> @@ -461,4 +461,16 @@ static inline int bloblist_maybe_init(void)
> }
> #endif /* BLOBLIST */
>
> +/**
> + * bloblist_check_reg_conv() - Check whether the bloblist is compliant to
> + * the register conventions according to the
> + * Firmware Handoff spec.
> + *
> + * @rfdt: Register that holds the FDT base address.
> + * @rzero: Register that must be zero.
> + * Return: 0 if OK, -EIO if the bloblist is not compliant to the register
> + * conventions, -ENOENT if OF_BOARD is disabled.
> + */
> +int bloblist_check_reg_conv(ulong rfdt, ulong rzero);
> +
> #endif /* __BLOBLIST_H */
> --
> 2.25.1
>
Regards,
Simon
More information about the U-Boot
mailing list