From: Marek Vasut Date: Wed, 28 Jan 2026 19:41:30 +0000 (+0100) Subject: cmd: zip: Use map_sysmem() with buffers in the zip command X-Git-Tag: v2026.04-rc2~15 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=3a76ba66ecb65b892de8b16360a8b0e93415f712;p=thirdparty%2Fu-boot.git cmd: zip: Use map_sysmem() with buffers in the zip command The current implementation casts an address to a pointer. Make it more sandbox-friendly by using map_sysmem(). Use symbolic return value for the command while updating the return value handling. Signed-off-by: Marek Vasut --- diff --git a/cmd/zip.c b/cmd/zip.c index 2d255428822..4bd1179390b 100644 --- a/cmd/zip.c +++ b/cmd/zip.c @@ -7,12 +7,15 @@ #include #include #include +#include #include static int do_zip(struct cmd_tbl *cmdtp, int flag, int argc, char *const argv[]) { unsigned long src, dst; unsigned long src_len, dst_len = ~0UL; + void *srcp, *dstp; + int ret; switch (argc) { case 5: @@ -27,13 +30,21 @@ static int do_zip(struct cmd_tbl *cmdtp, int flag, int argc, char *const argv[]) return cmd_usage(cmdtp); } - if (gzip((void *) dst, &dst_len, (void *) src, src_len) != 0) - return 1; + srcp = map_sysmem(src, src_len); + dstp = map_sysmem(dst, dst_len); + + ret = gzip(dstp, &dst_len, srcp, src_len); + + unmap_sysmem(dstp); + unmap_sysmem(srcp); + + if (ret) + return CMD_RET_FAILURE; printf("Compressed size: %lu = 0x%lX\n", dst_len, dst_len); env_set_hex("filesize", dst_len); - return 0; + return CMD_RET_SUCCESS; } U_BOOT_CMD(