]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
arm: mvebu: spl: Fix parsing SDIO kwbimage
authorPali Rohár <pali@kernel.org>
Sun, 8 Jan 2023 12:16:38 +0000 (13:16 +0100)
committerStefan Roese <sr@denx.de>
Wed, 1 Mar 2023 05:39:17 +0000 (06:39 +0100)
Despite the official specification, Marvell BootROM does not interpret
srcaddr from SDIO image as offset in number of sectors (like for SATA
image), but as offset in bytes (like for all other images except SATA).

To process SDIO kwbimage and load U-Boot proper from it in the same way as
Marvell BootROM, it is needed to interpret srcaddr in bytes. This change
fixes booting of U-Boot proper from SPL code stored in SDIO image.

Fixes: 2226ca173486 ("arm: mvebu: Load U-Boot proper binary in SPL code based on kwbimage header")
Signed-off-by: Pali Rohár <pali@kernel.org>
arch/arm/mach-mvebu/spl.c

index 424599286e5e1b18ed9936dc3797672b62430d7b..b238ba2f5d990e7f508a06d9a797be74268e7e86 100644 (file)
@@ -196,14 +196,6 @@ int spl_parse_board_header(struct spl_image_info *spl_image,
                spl_image->offset *= 512;
        }
 
-       /*
-        * For SDIO (eMMC) srcaddr is specified in number of sectors.
-        * This expects that sector size is 512 bytes and recalculates
-        * data offset to bytes.
-        */
-       if (IS_ENABLED(CONFIG_SPL_MMC) && mhdr->blockid == IBR_HDR_SDIO_ID)
-               spl_image->offset *= 512;
-
        if (spl_image->offset % 4 != 0) {
                printf("ERROR: Wrong srcaddr (0x%08x) in kwbimage\n",
                       spl_image->offset);