From: Pali Rohár Date: Sun, 8 Jan 2023 12:42:07 +0000 (+0100) Subject: tools: kwboot: Validate optional kwbimage v1 headers X-Git-Tag: v2025.01-rc5-pxa1908~1023^2~41^2~43 X-Git-Url: http://git.dujemihanovic.xyz/projects?a=commitdiff_plain;h=53ee6ec82744666719f2c9954a013c4397b77be9;p=u-boot.git tools: kwboot: Validate optional kwbimage v1 headers Before starting parsing of kwbimage, first validate that all optional v1 headers and correct. This prevents kwboot crashes on invalid input. Signed-off-by: Pali Rohár --- diff --git a/tools/kwboot.c b/tools/kwboot.c index da840864b5..c8c7a8d246 100644 --- a/tools/kwboot.c +++ b/tools/kwboot.c @@ -1939,6 +1939,7 @@ static int kwboot_img_patch(void *img, size_t *size, int baudrate) { struct main_hdr_v1 *hdr; + struct opt_hdr_v1 *ohdr; uint32_t srcaddr; uint8_t csum; size_t hdrsz; @@ -1990,6 +1991,13 @@ kwboot_img_patch(void *img, size_t *size, int baudrate) *size < le32_to_cpu(hdr->srcaddr) + le32_to_cpu(hdr->blocksize)) goto err; + for_each_opt_hdr_v1 (ohdr, hdr) { + if (!opt_hdr_v1_valid_size(ohdr, (const uint8_t *)hdr + hdrsz)) { + fprintf(stderr, "Invalid optional image header\n"); + goto err; + } + } + /* * The 32-bit data checksum is optional for UART image. If it is not * present (checksum detected as invalid) then grow data part of the