summaryrefslogtreecommitdiffstats
path: root/scripts
diff options
context:
space:
mode:
authorLucas Stach <l.stach@pengutronix.de>2018-11-07 16:39:08 +0100
committerSascha Hauer <s.hauer@pengutronix.de>2018-11-09 08:06:49 +0100
commit084aaa7f71efdcd3341e37a9fd92cede1e281035 (patch)
treeba38e2ab4c25397849480c6799f97fb6d2ce7415 /scripts
parent5a054ae4fabf323908087865bead1df72c7d843a (diff)
downloadbarebox-084aaa7f71efdcd3341e37a9fd92cede1e281035.tar.gz
barebox-084aaa7f71efdcd3341e37a9fd92cede1e281035.tar.xz
scripts: imx-image: fix first instruction in i.MX8MQ header
The instruction being patched in was a branch to 0x24000, instead of the intended 0x9000. This doesn't matter when starting the image from a regular boot source, but breaks starting the image via bootm, as we rely on the jump in the first header instruction taking us to the actual code. As the code offset changes depending on the presence of the signed HDMI firmware, compute the offet dynamically while building the image. Fixes: 6d2132a9ded7 (scripts: imx-image: Add i.MX8MQ support) Signed-off-by: Lucas Stach <l.stach@pengutronix.de> Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
Diffstat (limited to 'scripts')
-rw-r--r--scripts/imx/imx-image.c6
-rw-r--r--scripts/imx/imx.c2
2 files changed, 7 insertions, 1 deletions
diff --git a/scripts/imx/imx-image.c b/scripts/imx/imx-image.c
index 88e2cb955f..fa93e47917 100644
--- a/scripts/imx/imx-image.c
+++ b/scripts/imx/imx-image.c
@@ -894,6 +894,12 @@ int main(int argc, char *argv[])
if (cpu_is_aarch64(&data)) {
bb_header = bb_header_aarch64;
sizeof_bb_header = sizeof(bb_header_aarch64);
+ /*
+ * Compute jump offset, must be done dynamically as the code
+ * location changes depending on the presence of a signed HDMI
+ * firmware.
+ */
+ data.first_opcode |= (data.header_gap + header_len) >> 2;
} else {
bb_header = bb_header_aarch32;
sizeof_bb_header = sizeof(bb_header_aarch32);
diff --git a/scripts/imx/imx.c b/scripts/imx/imx.c
index 2341732b2f..43f67da288 100644
--- a/scripts/imx/imx.c
+++ b/scripts/imx/imx.c
@@ -243,7 +243,7 @@ static struct soc_type socs[] = {
{ .name = "imx53", .header_version = 2, .cpu_type = IMX_CPU_IMX53, .header_gap = 0, .first_opcode = 0xea0003fe /* b 0x1000 */},
{ .name = "imx6", .header_version = 2, .cpu_type = IMX_CPU_IMX6, .header_gap = 0, .first_opcode = 0xea0003fe /* b 0x1000 */},
{ .name = "imx7", .header_version = 2, .cpu_type = IMX_CPU_IMX7, .header_gap = 0, .first_opcode = 0xea0003fe /* b 0x1000 */},
- { .name = "imx8mq", .header_version = 2, .cpu_type = IMX_CPU_IMX8MQ, .header_gap = SZ_32K, .first_opcode = 0x14009000 /* b 0x9000 */},
+ { .name = "imx8mq", .header_version = 2, .cpu_type = IMX_CPU_IMX8MQ, .header_gap = SZ_32K, .first_opcode = 0x14000000 /* b 0x0000 (offset computed) */},
{ .name = "vf610", .header_version = 2, .cpu_type = IMX_CPU_VF610, .header_gap = 0, .first_opcode = 0xea0003fe /* b 0x1000 */},
};