]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
tools: kwboot: Fix parsing SATA kwbimage
authorPali Rohár <pali@kernel.org>
Sat, 21 Jan 2023 12:45:36 +0000 (13:45 +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 SATA image as number of sectors the beginning of the hard
drive, but as number of sectors relative to the main header.

To parse SATA kwbimage in the same way as Marvell BootROM, it is needed to
interpret srcaddr as relative offset to the main header. This change fixes
loading of SATA images via kwboot over UART.

Fixes: 792e42355083 ("tools: kwboot: Patch source address in image header")
Signed-off-by: Pali Rohár <pali@kernel.org>
tools/kwboot.c

index 188f944263fa201a9effaef076a9879ead9a0037..bf410520de6305c402befc0bbf718944042b1a73 100644 (file)
@@ -1888,10 +1888,7 @@ kwboot_img_patch(void *img, size_t *size, int baudrate)
 
        switch (hdr->blockid) {
        case IBR_HDR_SATA_ID:
-               if (srcaddr < 1)
-                       goto err;
-
-               hdr->srcaddr = cpu_to_le32((srcaddr - 1) * 512);
+               hdr->srcaddr = cpu_to_le32(srcaddr * 512);
                break;
 
        case IBR_HDR_PEX_ID: