From 7ae6b1b7ad14a18d0925c019c4bf0b6dfe2d06eb Mon Sep 17 00:00:00 2001 From: Mark Wielaard Date: Sat, 14 May 2022 00:50:33 +0200 Subject: [PATCH] 3.19.0-2 - Add valgrind-3.19.0-ld-so-strncmp.patch --- valgrind-3.19.0-ld-so-strncmp.patch | 25 +++++++++++++++++++++++++ valgrind.spec | 9 ++++++++- 2 files changed, 33 insertions(+), 1 deletion(-) create mode 100644 valgrind-3.19.0-ld-so-strncmp.patch diff --git a/valgrind-3.19.0-ld-so-strncmp.patch b/valgrind-3.19.0-ld-so-strncmp.patch new file mode 100644 index 0000000..91007ef --- /dev/null +++ b/valgrind-3.19.0-ld-so-strncmp.patch @@ -0,0 +1,25 @@ +commit 947388eb043ea1c44b37df94046e1eee790ad776 +Author: Mike Crowe +Date: Mon Sep 9 14:16:16 2019 +0100 + + Intercept strncmp for glibc ld.so v2.28+ + + In glibc 5aad5f617892e75d91d4c8fb7594ff35b610c042 (first released in + v2.28) a call to strncmp was added to dl-load.c:is_dst. This causes + valgrind to complain about glibc's highly-optimised strncmp performing + sixteen-byte reads on short strings in ld.so. Let's intercept strncmp in + ld.so too so we use valgrind's simple version to avoid this problem. + +diff --git a/shared/vg_replace_strmem.c b/shared/vg_replace_strmem.c +index 3b42b3a87..5396e83be 100644 +--- a/shared/vg_replace_strmem.c ++++ b/shared/vg_replace_strmem.c +@@ -710,6 +710,8 @@ static inline void my_exit ( int x ) + STRNCMP(VG_Z_LIBC_SONAME, __GI_strncmp) + STRNCMP(VG_Z_LIBC_SONAME, __strncmp_sse2) + STRNCMP(VG_Z_LIBC_SONAME, __strncmp_sse42) ++ STRNCMP(VG_Z_LD_LINUX_SO_2, strncmp) ++ STRNCMP(VG_Z_LD_LINUX_X86_64_SO_2, strncmp) + + #elif defined(VGO_freebsd) + STRNCMP(VG_Z_LIBC_SONAME, strncmp) diff --git a/valgrind.spec b/valgrind.spec index fdf40bd..f454f5c 100644 --- a/valgrind.spec +++ b/valgrind.spec @@ -3,7 +3,7 @@ Summary: Dynamic analysis tools to detect memory or thread bugs and profile Name: %{?scl_prefix}valgrind Version: 3.19.0 -Release: 1%{?dist} +Release: 2%{?dist} Epoch: 1 License: GPLv2+ URL: https://www.valgrind.org/ @@ -85,6 +85,9 @@ Patch3: valgrind-3.16.0-some-stack-protector.patch # Add some -Wl,z,now. Patch4: valgrind-3.16.0-some-Wl-z-now.patch +# KDE#434764 # iconv_open causes ld.so v2.28+ to execute optimised strncmp +Patch5: valgrind-3.19.0-ld-so-strncmp.patch + BuildRequires: make BuildRequires: glibc-devel @@ -222,6 +225,7 @@ Valgrind User Manual for details. %patch4 -p1 %endif +%patch5 -p1 %build # LTO triggers undefined symbols in valgrind. Valgrind has a --enable-lto @@ -451,6 +455,9 @@ fi %endif %changelog +* Fri May 13 2022 Mark Wielaard - 3.19.0-2 +- Add valgrind-3.19.0-ld-so-strncmp.patch + * Tue Apr 12 2022 Mark Wielaard - 3.19.0-1 - Upgrade to valgrind 3.19.0. Drop old patches.