3.16.1-19 - Add valgrind-3.16.1-readdwarf-line.patch
This commit is contained in:
parent
694bfef4aa
commit
800b3249fc
53
valgrind-3.16.1-readdwarf-line.patch
Normal file
53
valgrind-3.16.1-readdwarf-line.patch
Normal file
@ -0,0 +1,53 @@
|
||||
commit 67363912e9cdba83869a72ff8c4084e7a7e4ab85
|
||||
Author: Mark Wielaard <mark@klomp.org>
|
||||
Date: Sun Feb 21 22:45:51 2021 +0100
|
||||
|
||||
Fix typo in DWARF 5 line table readers
|
||||
|
||||
This typo meant the directory entry was most often zero, which
|
||||
happened to be sometimes correct anyway (since zero is the compdir).
|
||||
So for simple testcases it looked correct. But it would be wrong for
|
||||
compilation units not in the current compdir. Like files compiled with
|
||||
a relative of absolute path.
|
||||
|
||||
The same typo was in both readdwarf.c (read_dwarf2_lineblock) and
|
||||
readdwarf3.c (read_filename_table). read_dwarf2_lineblock also had
|
||||
an extra "dwarf" string in the debug-line output.
|
||||
|
||||
https://bugzilla.redhat.com/show_bug.cgi?id=1927153
|
||||
|
||||
diff --git a/coregrind/m_debuginfo/readdwarf.c b/coregrind/m_debuginfo/readdwarf.c
|
||||
index 88d5d99f1..3996623ed 100644
|
||||
--- a/coregrind/m_debuginfo/readdwarf.c
|
||||
+++ b/coregrind/m_debuginfo/readdwarf.c
|
||||
@@ -683,7 +683,7 @@ void read_dwarf2_lineblock ( struct _DebugInfo* di,
|
||||
directories_count = step_leb128U(&data);
|
||||
/* Read the contents of the Directory table. */
|
||||
if (di->ddump_line)
|
||||
- VG_(printf)(" dwarf The Directory Table%s\n",
|
||||
+ VG_(printf)(" The Directory Table%s\n",
|
||||
directories_count == 0 ? " is empty." : ":" );
|
||||
|
||||
for (n = 0; n < directories_count; n++) {
|
||||
@@ -796,7 +796,7 @@ void read_dwarf2_lineblock ( struct _DebugInfo* di,
|
||||
if (f == p_ndx)
|
||||
name = get_line_str (di, ui, &data, form,
|
||||
debugstr_img, debuglinestr_img);
|
||||
- else if (n == d_ndx)
|
||||
+ else if (f == d_ndx)
|
||||
diridx = get_line_ndx (di, &data, form);
|
||||
else
|
||||
data = skip_line_form (di, ui, data, form);
|
||||
diff --git a/coregrind/m_debuginfo/readdwarf3.c b/coregrind/m_debuginfo/readdwarf3.c
|
||||
index 82bc8f241..60fc40244 100644
|
||||
--- a/coregrind/m_debuginfo/readdwarf3.c
|
||||
+++ b/coregrind/m_debuginfo/readdwarf3.c
|
||||
@@ -2323,7 +2323,7 @@ void read_filename_table( /*MOD*/XArray* /* of UInt* */ fndn_ix_Table,
|
||||
if (f == p_ndx)
|
||||
str = get_line_str (cc->di, cc->is_dw64, &c, form,
|
||||
debugstr_img, debuglinestr_img);
|
||||
- else if (n == d_ndx)
|
||||
+ else if (f == d_ndx)
|
||||
dir_xa_ix = get_line_ndx (cc->di, &c, form);
|
||||
else
|
||||
skip_line_form (cc->di, cc->is_dw64, &c, form);
|
@ -3,7 +3,7 @@
|
||||
Summary: Tool for finding memory management bugs in programs
|
||||
Name: %{?scl_prefix}valgrind
|
||||
Version: 3.16.1
|
||||
Release: 18%{?dist}
|
||||
Release: 19%{?dist}
|
||||
Epoch: 1
|
||||
License: GPLv2+
|
||||
URL: http://www.valgrind.org/
|
||||
@ -151,6 +151,9 @@ Patch23: valgrind-3.16.0-shmctl.patch
|
||||
# RHBZ#1925786 valgrind appears to only interject readlink on /proc/self/exe
|
||||
Patch24: valgrind-3.16.1-open-proc-self-exe.patch
|
||||
|
||||
# RHBZ#1927153 -flto makes valgrind report non-existing paths to source files
|
||||
Patch25: valgrind-3.16.1-readdwarf-line.patch
|
||||
|
||||
BuildRequires: make
|
||||
BuildRequires: glibc-devel
|
||||
|
||||
@ -304,6 +307,7 @@ Valgrind User Manual for details.
|
||||
%patch22 -p1
|
||||
%patch23 -p1
|
||||
%patch24 -p1
|
||||
%patch25 -p1
|
||||
|
||||
%build
|
||||
# LTO triggers undefined symbols in valgrind. Valgrind has a --enable-lto
|
||||
@ -528,6 +532,9 @@ fi
|
||||
%endif
|
||||
|
||||
%changelog
|
||||
* Sun Feb 21 2021 Mark Wielaard <mjw@fedoraproject.org> - 3.16.1-19
|
||||
- Add valgrind-3.16.1-readdwarf-line.patch
|
||||
|
||||
* Sat Feb 6 2021 Mark Wielaard <mjw@fedoraproject.org> - 3.16.1-18
|
||||
- Update valgrind-3.16.1-open-proc-self-exe.patch to handle openat
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user