File busybox-1.37.0-hexdump-fix-regression-for-uint16-on-big-endian-syst.patch of Package busybox

From ede2cd43610fbf99678c9989f88013652225da5d Mon Sep 17 00:00:00 2001
From: Radoslav Kolev <radoslav.kolev@suse.com>
Date: Wed, 23 Apr 2025 20:42:01 +0300
Subject: [PATCH 1/3] hexdump: fix regression for uint16 on big endian systems

Commit 34751d8bf introduced a bug in the handling of uint16
values on big endian systems not considered safe for unaligned
access when falling back to memcpy.

Signed-off-by: Radoslav Kolev <radoslav.kolev@suse.com>
---
 libbb/dump.c | 10 ++++++++--
 1 file changed, 8 insertions(+), 2 deletions(-)

diff --git a/libbb/dump.c b/libbb/dump.c
index 2ca9919da..b8e8f4f0a 100644
--- a/libbb/dump.c
+++ b/libbb/dump.c
@@ -667,15 +667,21 @@ static NOINLINE void display(priv_dumper_t* dumper)
 							conv_u(pr, bp);
 							break;
 						case F_UINT: {
+							union {
+								uint16_t uval16;
+								uint32_t uval32;
+							} u;
 							unsigned value = (unsigned char)*bp;
 							switch (pr->bcnt) {
 							case 1:
 								break;
 							case 2:
-								move_from_unaligned16(value, bp);
+								move_from_unaligned16(u.uval16, bp);
+								value=u.uval16;
 								break;
 							case 4:
-								move_from_unaligned32(value, bp);
+								move_from_unaligned32(u.uval32, bp);
+								value=u.uval32;
 								break;
 							/* case 8: no users yet */
 							}
-- 
2.47.1

openSUSE Build Service is sponsored by