From mboxrd@z Thu Jan 1 00:00:00 1970 Return-path: Received: from metis.ext.pengutronix.de ([2001:67c:670:201:290:27ff:fe1d:cc33]) by bombadil.infradead.org with esmtps (Exim 4.90_1 #2 (Red Hat Linux)) id 1gKPvM-00038L-93 for barebox@lists.infradead.org; Wed, 07 Nov 2018 15:39:21 +0000 Received: from dude.hi.pengutronix.de ([2001:67c:670:100:1d::7] helo=dude.pengutronix.de.) by metis.ext.pengutronix.de with esmtp (Exim 4.89) (envelope-from ) id 1gKPvA-0008S5-G3 for barebox@lists.infradead.org; Wed, 07 Nov 2018 16:39:08 +0100 From: Lucas Stach Date: Wed, 7 Nov 2018 16:39:08 +0100 Message-Id: <20181107153908.2321-1-l.stach@pengutronix.de> MIME-Version: 1.0 List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "barebox" Errors-To: barebox-bounces+u.kleine-koenig=pengutronix.de@lists.infradead.org Subject: [PATCH v2] scripts: imx-image: fix first instruction in i.MX8MQ header To: barebox@lists.infradead.org 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 --- v2: Implement correct fixup for when the HDMI firmware is present. --- scripts/imx/imx-image.c | 6 ++++++ scripts/imx/imx.c | 2 +- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/scripts/imx/imx-image.c b/scripts/imx/imx-image.c index 88e2cb955f11..fa93e4791784 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 2341732b2fdd..43f67da288c1 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 */}, }; -- 2.19.1 _______________________________________________ barebox mailing list barebox@lists.infradead.org http://lists.infradead.org/mailman/listinfo/barebox