public inbox for gdb-prs@sourceware.org
help / color / mirror / Atom feed
* [Bug gdb/18021] New: Segfault in dwarf2_add_member_fn
@ 2015-02-25 0:20 scott+sware+bugzilla at pakin dot org
2015-02-25 0:40 ` [Bug gdb/18021] " scott+sware+bugzilla at pakin dot org
` (5 more replies)
0 siblings, 6 replies; 7+ messages in thread
From: scott+sware+bugzilla at pakin dot org @ 2015-02-25 0:20 UTC (permalink / raw)
To: gdb-prs
https://sourceware.org/bugzilla/show_bug.cgi?id=18021
Bug ID: 18021
Summary: Segfault in dwarf2_add_member_fn
Product: gdb
Version: 7.9
Status: NEW
Severity: normal
Priority: P2
Component: gdb
Assignee: unassigned at sourceware dot org
Reporter: scott+sware+bugzilla at pakin dot org
Created attachment 8143
--> https://sourceware.org/bugzilla/attachment.cgi?id=8143&action=edit
Backtrace of crashed gdb
gdb is crashing at startup on a big, complex executable I'm trying to debug.
As the attached backtrace shows, something's going haywire in
dwarf2_add_member_fn().
--
You are receiving this mail because:
You are on the CC list for the bug.
^ permalink raw reply [flat|nested] 7+ messages in thread
* [Bug gdb/18021] Segfault in dwarf2_add_member_fn
2015-02-25 0:20 [Bug gdb/18021] New: Segfault in dwarf2_add_member_fn scott+sware+bugzilla at pakin dot org
@ 2015-02-25 0:40 ` scott+sware+bugzilla at pakin dot org
2015-02-25 9:41 ` scott+sware+bugzilla at pakin dot org
` (4 subsequent siblings)
5 siblings, 0 replies; 7+ messages in thread
From: scott+sware+bugzilla at pakin dot org @ 2015-02-25 0:40 UTC (permalink / raw)
To: gdb-prs
https://sourceware.org/bugzilla/show_bug.cgi?id=18021
--- Comment #1 from Scott Pakin <scott+sware+bugzilla at pakin dot org> ---
Created attachment 8144
--> https://sourceware.org/bugzilla/attachment.cgi?id=8144&action=edit
Valgrind run of segfaulting gdb
Output from "valgrind --track-origins=yes" run on gdb. The relevant part is
the stanza right before the SIGSEGV, in which Valgrind complains that gdb is
attempting an "Invalid read of size 8" because "Address 0x10 is not stack'd,
malloc'd or (recently) free'd".
--
You are receiving this mail because:
You are on the CC list for the bug.
^ permalink raw reply [flat|nested] 7+ messages in thread
* [Bug gdb/18021] Segfault in dwarf2_add_member_fn
2015-02-25 0:20 [Bug gdb/18021] New: Segfault in dwarf2_add_member_fn scott+sware+bugzilla at pakin dot org
2015-02-25 0:40 ` [Bug gdb/18021] " scott+sware+bugzilla at pakin dot org
@ 2015-02-25 9:41 ` scott+sware+bugzilla at pakin dot org
2015-03-02 22:58 ` keiths at redhat dot com
` (3 subsequent siblings)
5 siblings, 0 replies; 7+ messages in thread
From: scott+sware+bugzilla at pakin dot org @ 2015-02-25 9:41 UTC (permalink / raw)
To: gdb-prs
https://sourceware.org/bugzilla/show_bug.cgi?id=18021
--- Comment #2 from Scott Pakin <scott+sware+bugzilla at pakin dot org> ---
Created attachment 8145
--> https://sourceware.org/bugzilla/attachment.cgi?id=8145&action=edit
Problematic executable
Attached the x86-64 executable that's crashing gdb. It's a build of NuT
(https://github.com/losalamos/NuT) instrumented with Byfl
(https://github.com/losalamos/Byfl). I built the code with g++ v4.9 on Ubuntu
14.10 (Utopic Unicorn), and here are the program's dependencies:
$ ldd ./export/opt-3-export_x86_scalar/bin/bh-3
linux-vdso.so.1 => (0x00007fffbdbfc000)
libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007fee2364c000)
libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6
(0x00007fee2333c000)
libatomic.so.1 => /usr/lib/x86_64-linux-gnu/libatomic.so.1
(0x00007fee23134000)
libbfd-2.24.90-system.20141014.so =>
/usr/lib/libbfd-2.24.90-system.20141014.so (0x00007fee22dfc000)
libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1
(0x00007fee22be4000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fee2281f000)
/lib64/ld-linux-x86-64.so.2 (0x00007fee2397f000)
libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0
(0x00007fee22601000)
libz.so.1 => /lib/x86_64-linux-gnu/libz.so.1 (0x00007fee223e7000)
libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007fee221e3000)
--
You are receiving this mail because:
You are on the CC list for the bug.
^ permalink raw reply [flat|nested] 7+ messages in thread
* [Bug gdb/18021] Segfault in dwarf2_add_member_fn
2015-02-25 0:20 [Bug gdb/18021] New: Segfault in dwarf2_add_member_fn scott+sware+bugzilla at pakin dot org
2015-02-25 0:40 ` [Bug gdb/18021] " scott+sware+bugzilla at pakin dot org
2015-02-25 9:41 ` scott+sware+bugzilla at pakin dot org
@ 2015-03-02 22:58 ` keiths at redhat dot com
2015-03-04 21:54 ` scott+sware+bugzilla at pakin dot org
` (2 subsequent siblings)
5 siblings, 0 replies; 7+ messages in thread
From: keiths at redhat dot com @ 2015-03-02 22:58 UTC (permalink / raw)
To: gdb-prs
https://sourceware.org/bugzilla/show_bug.cgi?id=18021
Keith Seitz <keiths at redhat dot com> changed:
What |Removed |Added
----------------------------------------------------------------------------
Status|NEW |ASSIGNED
CC| |keiths at redhat dot com
Assignee|unassigned at sourceware dot org |keiths at redhat dot com
--- Comment #3 from Keith Seitz <keiths at redhat dot com> ---
Proposed patch submitted:
https://sourceware.org/ml/gdb-patches/2015-03/msg00047.html
--
You are receiving this mail because:
You are on the CC list for the bug.
^ permalink raw reply [flat|nested] 7+ messages in thread
* [Bug gdb/18021] Segfault in dwarf2_add_member_fn
2015-02-25 0:20 [Bug gdb/18021] New: Segfault in dwarf2_add_member_fn scott+sware+bugzilla at pakin dot org
` (2 preceding siblings ...)
2015-03-02 22:58 ` keiths at redhat dot com
@ 2015-03-04 21:54 ` scott+sware+bugzilla at pakin dot org
2015-03-23 22:17 ` cvs-commit at gcc dot gnu.org
2015-03-24 9:17 ` keiths at redhat dot com
5 siblings, 0 replies; 7+ messages in thread
From: scott+sware+bugzilla at pakin dot org @ 2015-03-04 21:54 UTC (permalink / raw)
To: gdb-prs
https://sourceware.org/bugzilla/show_bug.cgi?id=18021
--- Comment #4 from Scott Pakin <scott+sware+bugzilla at pakin dot org> ---
(In reply to Keith Seitz from comment #3)
> Proposed patch submitted:
> https://sourceware.org/ml/gdb-patches/2015-03/msg00047.html
The segfault seems to have gone away when I applied that patch -- thanks!
--
You are receiving this mail because:
You are on the CC list for the bug.
^ permalink raw reply [flat|nested] 7+ messages in thread
* [Bug gdb/18021] Segfault in dwarf2_add_member_fn
2015-02-25 0:20 [Bug gdb/18021] New: Segfault in dwarf2_add_member_fn scott+sware+bugzilla at pakin dot org
` (3 preceding siblings ...)
2015-03-04 21:54 ` scott+sware+bugzilla at pakin dot org
@ 2015-03-23 22:17 ` cvs-commit at gcc dot gnu.org
2015-03-24 9:17 ` keiths at redhat dot com
5 siblings, 0 replies; 7+ messages in thread
From: cvs-commit at gcc dot gnu.org @ 2015-03-23 22:17 UTC (permalink / raw)
To: gdb-prs
https://sourceware.org/bugzilla/show_bug.cgi?id=18021
--- Comment #5 from cvs-commit at gcc dot gnu.org <cvs-commit at gcc dot gnu.org> ---
The master branch has been updated by Keith Seitz <kseitz@sourceware.org>:
https://sourceware.org/git/gitweb.cgi?p=binutils-gdb.git;h=7e993ebf2343a5b39d6d1df29fdebc2818064ae5
commit 7e993ebf2343a5b39d6d1df29fdebc2818064ae5
Author: Keith Seitz <keiths@redhat.com>
Date: Fri Feb 27 09:55:07 2015 -0800
PR gdb/18021 - defend against "static virtual" methods
This bug appears to be caused by bad debuginfo. The method
causing the sefault in the reporter's test case is marked both static
and virtual.
This patch simply safegaurds against this case in dwarf2_add_member_fn,
where the code assumes that there is a `this' pointer when a virtual method
is seen (more specifically, when DW_AT_vtable_elem is seen).
It previously dereferenced the first formal parameter
(`this' pointer), which in this case doesn't exist. GDB consequently
segfaulted dereferencing a NULL pointer.
gdb/ChangeLog
PR gdb/18021
* dwarf2read.c (dwarf2_add_member_fn): Issue a complaint
if we find a static method with DW_AT_vtable_elem_location.
gdb/testsuite/ChangeLog
PR gdb/18021
* gdb.dwarf2/staticvirtual.exp: New test.
--
You are receiving this mail because:
You are on the CC list for the bug.
^ permalink raw reply [flat|nested] 7+ messages in thread
* [Bug gdb/18021] Segfault in dwarf2_add_member_fn
2015-02-25 0:20 [Bug gdb/18021] New: Segfault in dwarf2_add_member_fn scott+sware+bugzilla at pakin dot org
` (4 preceding siblings ...)
2015-03-23 22:17 ` cvs-commit at gcc dot gnu.org
@ 2015-03-24 9:17 ` keiths at redhat dot com
5 siblings, 0 replies; 7+ messages in thread
From: keiths at redhat dot com @ 2015-03-24 9:17 UTC (permalink / raw)
To: gdb-prs
https://sourceware.org/bugzilla/show_bug.cgi?id=18021
Keith Seitz <keiths at redhat dot com> changed:
What |Removed |Added
----------------------------------------------------------------------------
Status|ASSIGNED |RESOLVED
Resolution|--- |FIXED
--- Comment #6 from Keith Seitz <keiths at redhat dot com> ---
Patch committed. If you have any further issues, please let us/me know.
--
You are receiving this mail because:
You are on the CC list for the bug.
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2015-03-23 22:17 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-02-25 0:20 [Bug gdb/18021] New: Segfault in dwarf2_add_member_fn scott+sware+bugzilla at pakin dot org
2015-02-25 0:40 ` [Bug gdb/18021] " scott+sware+bugzilla at pakin dot org
2015-02-25 9:41 ` scott+sware+bugzilla at pakin dot org
2015-03-02 22:58 ` keiths at redhat dot com
2015-03-04 21:54 ` scott+sware+bugzilla at pakin dot org
2015-03-23 22:17 ` cvs-commit at gcc dot gnu.org
2015-03-24 9:17 ` keiths at redhat dot com
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).