* [PATCH] i.MX habv4: Fix RVT address for newer SoCs
@ 2016-02-05 14:51 Sascha Hauer
0 siblings, 0 replies; only message in thread
From: Sascha Hauer @ 2016-02-05 14:51 UTC (permalink / raw)
To: Barebox List
Newer i.MX SoCs have the RVT at 0x98, not at 0x94 any more.
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
---
drivers/hab/habv4.c | 17 ++++++++++++++---
1 file changed, 14 insertions(+), 3 deletions(-)
diff --git a/drivers/hab/habv4.c b/drivers/hab/habv4.c
index a44a94b..91dbb7a 100644
--- a/drivers/hab/habv4.c
+++ b/drivers/hab/habv4.c
@@ -25,7 +25,8 @@
#include <mach/generic.h>
#define HABV4_RVT_IMX28 0xffff8af8
-#define HABV4_RVT_IMX6 0x00000094
+#define HABV4_RVT_IMX6_OLD 0x00000094
+#define HABV4_RVT_IMX6_NEW 0x00000098
enum hab_tag {
HAB_TAG_IVT = 0xd1, /* Image Vector Table */
@@ -216,9 +217,19 @@ static int habv4_get_status(const struct habv4_rvt *rvt)
int imx6_hab_get_status(void)
{
- const struct habv4_rvt *rvt = (void *)HABV4_RVT_IMX6;
+ const struct habv4_rvt *rvt;
- return habv4_get_status(rvt);
+ rvt = (void *)HABV4_RVT_IMX6_OLD;
+ if (rvt->header.tag == HAB_TAG_RVT)
+ return habv4_get_status(rvt);
+
+ rvt = (void *)HABV4_RVT_IMX6_NEW;
+ if (rvt->header.tag == HAB_TAG_RVT)
+ return habv4_get_status(rvt);
+
+ pr_err("ERROR - RVT not found!\n");
+
+ return -EINVAL;
}
int imx28_hab_get_status(void)
--
2.7.0.rc3
_______________________________________________
barebox mailing list
barebox@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/barebox
^ permalink raw reply [flat|nested] only message in thread
only message in thread, other threads:[~2016-02-05 14:51 UTC | newest]
Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-02-05 14:51 [PATCH] i.MX habv4: Fix RVT address for newer SoCs Sascha Hauer
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox