9
0
Fork 0

imx: hab: Make hab status functions SoC specific

The HABv4 functions need access a part of the ROM which is
located in the zero page. This must be done early, before the
MMU has been configured and the zero page has been set to faulting.
The HAB functions currently use cpu_is_imxxy(). At the stage where
HAB is called the i.MX CPU type variable is not yet initialized,
so this code only works when only one i.MX type is enabled and
cpu_is_imxxy() are compile time constants.

To fix HAB support when more than one i.MX type is enabled make the
HAB status function SoC specific so that we can drop the use of
cpu_is_imxxy().

Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
This commit is contained in:
Sascha Hauer 2016-02-02 15:23:42 +01:00
parent 610cc35c1e
commit 48d74b1ca4
2 changed files with 26 additions and 29 deletions

View File

@ -99,29 +99,6 @@ struct habv4_rvt {
void (*failsafe)(void);
} __packed;
static const struct habv4_rvt *__rvt;
static inline const struct habv4_rvt *habv4_get_rvt(void)
{
if (__rvt)
return __rvt;
if (cpu_is_mx28())
__rvt = (void *)HABV4_RVT_IMX28;
else if (cpu_is_mx6())
__rvt = (void *)HABV4_RVT_IMX6;
if (__rvt->header.tag != HAB_TAG_RVT) {
pr_err("ERROR - RVT not found!\n");
return NULL;
}
pr_info("Found RVT v%d.%d\n", __rvt->header.par >> 4,
__rvt->header.par & 0xf);
return __rvt;
}
static const char *habv4_get_status_str(enum hab_status status)
{
switch (status) {
@ -197,9 +174,8 @@ static void habv4_display_event(uint8_t *data, uint32_t len)
printf("\n\n");
}
int habv4_get_status(void)
static int habv4_get_status(const struct habv4_rvt *rvt)
{
const struct habv4_rvt *rvt = habv4_get_rvt();
uint8_t data[256];
uint32_t len = sizeof(data);
uint32_t index = 0;
@ -207,8 +183,10 @@ int habv4_get_status(void)
enum hab_config config = 0x0;
enum hab_state state = 0x0;
if (!rvt)
return -ENODEV;
if (rvt->header.tag != HAB_TAG_RVT) {
pr_err("ERROR - RVT not found!\n");
return -EINVAL;
}
status = rvt->report_status(&config, &state);
pr_info("Status: %s (0x%02x)\n", habv4_get_status_str(status), status);
@ -235,3 +213,17 @@ int habv4_get_status(void)
return -EPERM;
}
int imx6_hab_get_status(void)
{
const struct habv4_rvt *rvt = (void *)HABV4_RVT_IMX6;
return habv4_get_status(rvt);
}
int imx28_hab_get_status(void)
{
const struct habv4_rvt *rvt = (void *)HABV4_RVT_IMX28;
return habv4_get_status(rvt);
}

View File

@ -19,9 +19,14 @@
#define __HABV4_H
#ifdef CONFIG_HABV4
int habv4_get_status(void);
int imx28_hab_get_status(void);
int imx6_hab_get_status(void);
#else
static inline int habv4_get_status(void)
static inline int imx28_hab_get_status(void)
{
return -EPERM;
}
static inline int imx6_hab_get_status(void)
{
return -EPERM;
}