dd_rescue/dd_rescue-md5-unaligned-armv7.diff
Dirk Mueller c503629574 Accepting request 1154455 from home:garloff:branches:Base:System
- dd_rescue-md5-unaligned-armv7.diff: gcc-12 does make unaligned
  accesses on armv7 work sometimes, which breaks a configure test
  and then makes the make check fail with SIGBUS when using hash
  after lzo compression. Hardcode knowledge about armv7.
- Drop %setup (not needed if using %autosetup, thanks Valentin!)
- Mention [bsc#1219882], as suggested by Valentin Lefebvre.

- Fix openssl version detection for 3.0.x. 
- dd_rescue-ossl3-evpcipherctx.diff: There's an additional field
  in the (private) struct _evp_cipher_ctx_st in openssl-3 since
  3.0.6, which makes a difference on 32bit. (On 64bit, the effect
  is hidden by the compiler's alignment rules.)

- Specify libopenssl-devel as BuildRequirements. This will select
  openssl-3 on new distributions. 
  This fixes [bsc#1219882].

OBS-URL: https://build.opensuse.org/request/show/1154455
OBS-URL: https://build.opensuse.org/package/show/Base:System/dd_rescue?expand=0&rev=76
2024-03-05 08:54:24 +00:00

45 lines
1.4 KiB
Diff

commit 19da344403f9d340d7343e99df6ec3e4b79684d9
Author: Kurt Garloff <kurt@garloff.de>
Date: Sun Mar 3 21:53:21 2024 +0100
Trouble is that we don't detect that ARMv7 requires extra buffering
is md5 input is not properly aligned. gcc-12 apparently is clever enough
to handle unlaigned memory access for us, which makes us succeed in the
testcase. It's not clever enough to also succeed in md5_64() :-O
Signed-off-by: Kurt Garloff <kurt@garloff.de>
diff --git a/configure.ac b/configure.ac
index d99387c..7a7dccf 100644
--- a/configure.ac
+++ b/configure.ac
@@ -60,7 +60,7 @@ AC_RUN_IFELSE([AC_LANG_SOURCE([[
AC_DEFINE_UNQUOTED([HAVE_REP_NOP], 1,
[check whether asm rep nop works])
],[
- AC_MSG_RESULT(yes)
+ AC_MSG_RESULT(no)
],[
AC_MSG_RESULT(no -- cross compiling)
])
@@ -79,7 +79,7 @@ AC_RUN_IFELSE([AC_LANG_SOURCE([[
AC_DEFINE_UNQUOTED([HAVE_LFENCE], 1,
[check whether asm lfence works])
],[
- AC_MSG_RESULT(yes)
+ AC_MSG_RESULT(no)
],[
AC_MSG_RESULT(no -- cross compiling)
])
@@ -171,6 +171,10 @@ AC_RUN_IFELSE([AC_LANG_SOURCE([[
fprintf(stderr, "Debug: Off %i, Ptr %08lx\n", off, (unsigned long)ptr);
copy((int*)b2, (const int*)ptr, 4);
fprintf(stderr, "Ints: %08x %08x %08x %08x\n", *(int*)b2, *(int*)(b2+4), *(int*)(b2+8), *(int*)(b2+12));
+ /* HACK: Somehow this test does no longer trigger with gcc-12 on armhf, but it should */
+ #ifdef __arm__
+ return 1;
+ #endif
return 0;
}
]])],[