From: Vincent Stehlé Date: Mon, 7 Apr 2025 17:05:27 +0000 (+0200) Subject: arm64: versal: fix dfu alt buffer clearing X-Git-Tag: v2025.07-rc1~52^2~25 X-Git-Url: http://git.openpandora.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=282a6424488afb35dc557e7fb2004f9b81732b12;p=pandora-u-boot.git arm64: versal: fix dfu alt buffer clearing The set_dfu_alt_info() function calls the ALLOC_CACHE_ALIGN_BUFFER() macro to declare a `buf' variable pointer into an array allocated on the stack. It then calls the memset() function to clear the useable portion of the array using the idiomatic expression `sizeof(buf)'. While this would indeed work fine for an array, in the present case we end up clearing only the size of a pointer. Fix this by specifying the explicit size `DFU_ALT_BUF_LEN' instead. Fixes: 064c8978b44f ("arm64: versal: Enable capsule update (SD)") Signed-off-by: Vincent Stehlé Cc: Michal Simek Cc: Tom Rini Acked-by: Padmarao Begari Link: https://lore.kernel.org/r/20250407170529.893307-4-vincent.stehle@arm.com --- diff --git a/board/xilinx/versal/board.c b/board/xilinx/versal/board.c index 8ea9eee9a1f..f0ac3fbadb1 100644 --- a/board/xilinx/versal/board.c +++ b/board/xilinx/versal/board.c @@ -406,7 +406,7 @@ void configure_capsule_updates(void) ALLOC_CACHE_ALIGN_BUFFER(char, buf, DFU_ALT_BUF_LEN); - memset(buf, 0, sizeof(buf)); + memset(buf, 0, DFU_ALT_BUF_LEN); multiboot = env_get_hex("multiboot", multiboot);