From 40367aa404bbe375c0d192c00bd375d4638f929e Mon Sep 17 00:00:00 2001 From: Peter Korsgaard Date: Fri, 17 Apr 2009 18:17:33 +0000 Subject: [PATCH] busybox: 1.14.0 fix for move_to_unaligned32 / dnsd.c on !x86 --- .../busybox-1.14.0-unaligned-fix.patch | 28 +++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 package/busybox/busybox-1.14.0-unaligned-fix.patch diff --git a/package/busybox/busybox-1.14.0-unaligned-fix.patch b/package/busybox/busybox-1.14.0-unaligned-fix.patch new file mode 100644 index 0000000000..33ebd4a4a0 --- /dev/null +++ b/package/busybox/busybox-1.14.0-unaligned-fix.patch @@ -0,0 +1,28 @@ +[PATCH] fix move_to_unaligned32() for !x86 + +get_unaligned() got changed into move_{from,to}_unaligned() in r24334, but +the temporary variabled used to make sure we can take the address of the +source argument for memcpy() got removed. Later on in r26068 dnsd.c got +changed to call move_to_unaligned with htons/htonl as source breaking +the build for !x86. + +Fix it by reintroducing the temporary variable. + +Signed-off-by: Peter Korsgaard +--- + include/platform.h | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +Index: busybox-1.14.0/include/platform.h +=================================================================== +--- busybox-1.14.0.orig/include/platform.h ++++ busybox-1.14.0/include/platform.h +@@ -173,7 +173,7 @@ + /* performs reasonably well (gcc usually inlines memcpy here) */ + #define move_from_unaligned16(v, u16p) (memcpy(&(v), (u16p), 2)) + #define move_from_unaligned32(v, u32p) (memcpy(&(v), (u32p), 4)) +-#define move_to_unaligned32(u32p, v) (memcpy((u32p), &(v), 4)) ++#define move_to_unaligned32(u32p, v) do { uint32_t __t = (v); memcpy((u32p), &__t, 4); } while (0) + #endif + + /* ---- Networking ------------------------------------------ */ -- 2.30.2