summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHeinrich Schuchardt <xypron.glpk@gmx.de>2020-08-30 11:34:12 +0200
committerTom Rini <trini@konsulko.com>2020-09-11 17:13:56 -0400
commit21d3946840fd62dc09e93986743915bcbac100b7 (patch)
treec79e2b5d97120df3eee7bc698798c2080bd03872
parent91b735d11f95ecf608a95a255281c36dcc7e37a4 (diff)
downloadu-boot-21d3946840fd62dc09e93986743915bcbac100b7.tar.gz
u-boot-21d3946840fd62dc09e93986743915bcbac100b7.tar.xz
u-boot-21d3946840fd62dc09e93986743915bcbac100b7.zip
bootm: update image OS image size when decompressing
In bootm_load_os() the OS image is decompressed. In later stages of the boot process we need the decompressed size of the image. Update images->os.image_len after decompression. Passing the correct size is necessary if we want to check loaded EFI binararies for file truncation by comparing the loaded size to the header field SizeOfImage. Signed-off-by: Heinrich Schuchardt <xypron.glpk@gmx.de> Reviewed-by: Simon Glass <sjg@chromium.org>
-rw-r--r--common/bootm.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/common/bootm.c b/common/bootm.c
index 247b600d9c..b3377490b3 100644
--- a/common/bootm.c
+++ b/common/bootm.c
@@ -390,6 +390,8 @@ static int bootm_load_os(bootm_headers_t *images, int boot_progress)
bootstage_error(BOOTSTAGE_ID_DECOMP_IMAGE);
return err;
}
+ /* We need the decompressed image size in the next steps */
+ images->os.image_len = load_end - load;
flush_cache(flush_start, ALIGN(load_end, ARCH_DMA_MINALIGN) - flush_start);