[PATCH] arch: arm: mach-imx: print HAB ROM code version
Rouven Czerwinski
r.czerwinski at pengutronix.de
Fri Mar 12 10:21:54 GMT 2021
Hi Denis,
On Thu, 2021-03-11 at 17:07 +0000, Denis Osterland-Heim wrote:
> From: Denis Osterland-Heim <Denis.Osterland at diehl.com>
>
> Add the two missing function pointers according to HAB4_API.pdf
> from cst-3.1.0 and print the version of ROM code.
>
> Signed-off-by: Denis Osterland-Heim <Denis.Osterland at diehl.com>
> ---
> drivers/hab/habv4.c | 7 +++++++
> 1 file changed, 7 insertions(+)
>
> diff --git a/drivers/hab/habv4.c b/drivers/hab/habv4.c
> index c2acb8136..f30e5d68c 100644
> --- a/drivers/hab/habv4.c
> +++ b/drivers/hab/habv4.c
> @@ -161,6 +161,7 @@ struct hab_header {
> uint8_t par;
> } __packed;
>
> +typedef void (*hab_image_entry_fn)(void);
> typedef enum hab_status hab_loader_callback_fn(void **start, uint32_t *bytes, const void *boot_data);
>
> struct habv4_rvt {
> @@ -175,6 +176,8 @@ struct habv4_rvt {
> enum hab_status (*report_event)(enum hab_status status, uint32_t index, void *event, uint32_t *bytes);
> enum hab_status (*report_status)(enum hab_config *config, enum hab_state *state);
> void (*failsafe)(void);
> +hab_image_entry_fn (*authenticate_image_no_dcd)(uint8_t cid, ptrdiff_t ivt_offset, void **start, size_t *bytes, hab_loader_callback_fn loader);
> +uint32_t (*get_version)(void);
> } __packed;
>
> #define FSL_SIP_HAB 0xC2000007
> @@ -528,6 +531,7 @@ static int habv4_get_status(const struct habv4_rvt *rvt)
> uint8_t *data;
> uint32_t len;
> int i;
> +uint32_t version;
> enum hab_status status;
> enum hab_config config = 0x0;
> enum hab_state state = 0x0;
> @@ -537,6 +541,9 @@ static int habv4_get_status(const struct habv4_rvt *rvt)
> return -EINVAL;
> }
>
> +version = rvt->get_version();
This unconditional call will break HAB on i.MX8MQ where it isn't
implemented in the RVT, I don't know if the call is even routed in the
downstream TF-A.
Aside from this your mailer/mailserver is mangling the patches, if it
is the mailer, maybe you can switch to git-send-email, see
https://git-send-email.io
> +pr_info("version: %u.%u.%u\n", (version >> 16), ((version >> 8) & 0xff), (version & 0xff));
> +
> status = rvt->report_status(&config, &state);
> pr_info("Status: %s (0x%02x)\n", habv4_get_status_str(status), status);
> pr_info("Config: %s (0x%02x)\n", habv4_get_config_str(config), config);
> --
> 2.30.2
Regards,
Rouven Czerwinski
More information about the barebox
mailing list