mirror of
https://github.com/linux-sunxi/u-boot-sunxi.git
synced 2024-02-12 11:16:03 +08:00
tools: kwboot: patch destaddr only for SoCs with header version 1
Commitf4db6c976c
("arm: mvebu: Add runtime detection of UART (xmodem) boot-mode") added a change to hdr->destaddr when dynamically patching an image for UART boot mode. With this change, kwboot ceases to work on Kirkwood. Thus, let's change hdr->destaddr only when we are patching an image with header version 1 (Orion and Kirkwood use header version 0). Signed-off-by: Simon Baatz <gmbnomis@gmail.com> Fixes:f4db6c976c
("arm: mvebu: Add runtime detection of UART (xmodem) boot-mode") Cc: Stefan Roese <sr@denx.de> Cc: Luka Perkov <luka.perkov@sartura.hr> Cc: Kevin Smith <kevin.smith@elecsyscorp.com> Signed-off-by: Stefan Roese <sr@denx.de>
This commit is contained in:

committed by
Stefan Roese

parent
c90d7ab6b0
commit
bdf58c73ca
@ -655,14 +655,6 @@ kwboot_img_patch_hdr(void *img, size_t size)
|
|||||||
|
|
||||||
hdr->blockid = IBR_HDR_UART_ID;
|
hdr->blockid = IBR_HDR_UART_ID;
|
||||||
|
|
||||||
/*
|
|
||||||
* Subtract mkimage header size from destination address
|
|
||||||
* as this header is not expected by the Marvell BootROM.
|
|
||||||
* This way, the execution address is identical to the
|
|
||||||
* one the image is compiled for (TEXT_BASE).
|
|
||||||
*/
|
|
||||||
hdr->destaddr = hdr->destaddr - sizeof(struct image_header);
|
|
||||||
|
|
||||||
if (image_ver == 0) {
|
if (image_ver == 0) {
|
||||||
struct main_hdr_v0 *hdr_v0 = img;
|
struct main_hdr_v0 *hdr_v0 = img;
|
||||||
|
|
||||||
@ -672,6 +664,14 @@ kwboot_img_patch_hdr(void *img, size_t size)
|
|||||||
hdr_v0->srcaddr = hdr_v0->ext
|
hdr_v0->srcaddr = hdr_v0->ext
|
||||||
? sizeof(struct kwb_header)
|
? sizeof(struct kwb_header)
|
||||||
: sizeof(*hdr_v0);
|
: sizeof(*hdr_v0);
|
||||||
|
} else {
|
||||||
|
/*
|
||||||
|
* Subtract mkimage header size from destination address
|
||||||
|
* as this header is not expected by the Marvell BootROM.
|
||||||
|
* This way, the execution address is identical to the
|
||||||
|
* one the image is compiled for (TEXT_BASE).
|
||||||
|
*/
|
||||||
|
hdr->destaddr = hdr->destaddr - sizeof(struct image_header);
|
||||||
}
|
}
|
||||||
|
|
||||||
hdr->checksum = kwboot_img_csum8(hdr, hdrsz) - csum;
|
hdr->checksum = kwboot_img_csum8(hdr, hdrsz) - csum;
|
||||||
|
Reference in New Issue
Block a user