Fix non-stop gdb -p <container>: internal error (pedro Alves, RH BZ 1318049).
This commit is contained in:
parent
c0cbb1aae4
commit
76251d6102
230
gdb-rhbz1318049-gdb-p-container-internal-error.patch
Normal file
230
gdb-rhbz1318049-gdb-p-container-internal-error.patch
Normal file
@ -0,0 +1,230 @@
|
|||||||
|
http://post-office.corp.redhat.com/archives/debug-list/2016-April/msg00003.html
|
||||||
|
|
||||||
|
>From cb8bfeaa21a2df484d3c4c35cc6ea1c4b32cefc8 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Pedro Alves <palves@redhat.com>
|
||||||
|
Date: Wed, 6 Apr 2016 15:07:49 +0100
|
||||||
|
Subject: [PATCH] Fix PR gdb/19828: gdb -p <process from a container>: internal
|
||||||
|
error
|
||||||
|
|
||||||
|
When GDB attaches to a process, it looks at the /proc/PID/task/ dir
|
||||||
|
for all clone threads of that process, and attaches to each of them.
|
||||||
|
|
||||||
|
Usually, if there is more than one clone thread, it means the program
|
||||||
|
is multi threaded and linked with pthreads. Thus when GDB soon after
|
||||||
|
attaching finds and loads a libthread_db matching the process, it'll
|
||||||
|
add a thread to the thread list for each of the initially found
|
||||||
|
lower-level LWPs.
|
||||||
|
|
||||||
|
If, however, GDB fails to find/load a matching libthread_db, nothing
|
||||||
|
is adding the LWPs to the thread list. And because of that, "detach"
|
||||||
|
hits an internal error:
|
||||||
|
|
||||||
|
(gdb) PASS: gdb.threads/clone-attach-detach.exp: fg attach 1: attach
|
||||||
|
info threads
|
||||||
|
Id Target Id Frame
|
||||||
|
* 1 LWP 6891 "clone-attach-de" 0x00007f87e5fd0790 in __nanosleep_nocancel () at ../sysdeps/unix/syscall-template.S:84
|
||||||
|
(gdb) FAIL: gdb.threads/clone-attach-detach.exp: fg attach 1: info threads shows two LWPs
|
||||||
|
detach
|
||||||
|
.../src/gdb/thread.c:1010: internal-error: is_executing: Assertion `tp' failed.
|
||||||
|
A problem internal to GDB has been detected,
|
||||||
|
further debugging may prove unreliable.
|
||||||
|
Quit this debugging session? (y or n)
|
||||||
|
FAIL: gdb.threads/clone-attach-detach.exp: fg attach 1: detach (GDB internal error)
|
||||||
|
|
||||||
|
>From here:
|
||||||
|
|
||||||
|
...
|
||||||
|
#8 0x00000000007ba7cc in internal_error (file=0x98ea68 ".../src/gdb/thread.c", line=1010, fmt=0x98ea30 "%s: Assertion `%s' failed.")
|
||||||
|
at .../src/gdb/common/errors.c:55
|
||||||
|
#9 0x000000000064bb83 in is_executing (ptid=...) at .../src/gdb/thread.c:1010
|
||||||
|
#10 0x00000000004c23bb in get_pending_status (lp=0x12c5cc0, status=0x7fffffffdc0c) at .../src/gdb/linux-nat.c:1235
|
||||||
|
#11 0x00000000004c2738 in detach_callback (lp=0x12c5cc0, data=0x0) at .../src/gdb/linux-nat.c:1317
|
||||||
|
#12 0x00000000004c1a2a in iterate_over_lwps (filter=..., callback=0x4c2599 <detach_callback>, data=0x0) at .../src/gdb/linux-nat.c:899
|
||||||
|
#13 0x00000000004c295c in linux_nat_detach (ops=0xe7bd30, args=0x0, from_tty=1) at .../src/gdb/linux-nat.c:1358
|
||||||
|
#14 0x000000000068284d in delegate_detach (self=0xe7bd30, arg1=0x0, arg2=1) at .../src/gdb/target-delegates.c:34
|
||||||
|
#15 0x0000000000694141 in target_detach (args=0x0, from_tty=1) at .../src/gdb/target.c:2241
|
||||||
|
#16 0x0000000000630582 in detach_command (args=0x0, from_tty=1) at .../src/gdb/infcmd.c:2975
|
||||||
|
...
|
||||||
|
|
||||||
|
Tested on x86-64 Fedora 23. Also confirmed the test passes against
|
||||||
|
gdbserver with with "maint set target-non-stop".
|
||||||
|
|
||||||
|
gdb/ChangeLog:
|
||||||
|
yyyy-mm-dd Pedro Alves <palves@redhat.com>
|
||||||
|
|
||||||
|
* linux-nat.c (attach_proc_task_lwp_callback): Add the thread to
|
||||||
|
GDB's thread list.
|
||||||
|
|
||||||
|
testsuite/ChangeLog:
|
||||||
|
yyyy-mm-dd Pedro Alves <palves@redhat.com>
|
||||||
|
|
||||||
|
* gdb.threads/clone-attach-detach.c: New file.
|
||||||
|
* gdb.threads/clone-attach-detach.exp: New file.
|
||||||
|
---
|
||||||
|
gdb/linux-nat.c | 5 ++
|
||||||
|
gdb/testsuite/gdb.threads/clone-attach-detach.c | 66 +++++++++++++++++++++++
|
||||||
|
gdb/testsuite/gdb.threads/clone-attach-detach.exp | 63 ++++++++++++++++++++++
|
||||||
|
3 files changed, 134 insertions(+)
|
||||||
|
create mode 100644 gdb/testsuite/gdb.threads/clone-attach-detach.c
|
||||||
|
create mode 100644 gdb/testsuite/gdb.threads/clone-attach-detach.exp
|
||||||
|
|
||||||
|
diff --git a/gdb/linux-nat.c b/gdb/linux-nat.c
|
||||||
|
index 0829bcb..2025c19 100644
|
||||||
|
--- a/gdb/linux-nat.c
|
||||||
|
+++ b/gdb/linux-nat.c
|
||||||
|
@@ -1088,6 +1088,11 @@ attach_proc_task_lwp_callback (ptid_t ptid)
|
||||||
|
/* We need to wait for a stop before being able to make the
|
||||||
|
next ptrace call on this LWP. */
|
||||||
|
lp->must_set_ptrace_flags = 1;
|
||||||
|
+
|
||||||
|
+ /* Also add the LWP to gdb's thread list, in case a
|
||||||
|
+ matching libthread_db is not found (or the process uses
|
||||||
|
+ raw clone). */
|
||||||
|
+ add_thread (lp->ptid);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
diff --git a/gdb/testsuite/gdb.threads/clone-attach-detach.c b/gdb/testsuite/gdb.threads/clone-attach-detach.c
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..daa8f1f
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/gdb/testsuite/gdb.threads/clone-attach-detach.c
|
||||||
|
@@ -0,0 +1,66 @@
|
||||||
|
+/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+ Copyright 2016 Free Software Foundation, Inc.
|
||||||
|
+
|
||||||
|
+ This program is free software; you can redistribute it and/or modify
|
||||||
|
+ it under the terms of the GNU General Public License as published by
|
||||||
|
+ the Free Software Foundation; either version 3 of the License, or
|
||||||
|
+ (at your option) any later version.
|
||||||
|
+
|
||||||
|
+ This program is distributed in the hope that it will be useful,
|
||||||
|
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
+ GNU General Public License for more details.
|
||||||
|
+
|
||||||
|
+ You should have received a copy of the GNU General Public License
|
||||||
|
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
+*/
|
||||||
|
+
|
||||||
|
+#define _GNU_SOURCE
|
||||||
|
+#include <sched.h>
|
||||||
|
+#include <assert.h>
|
||||||
|
+#include <stdlib.h>
|
||||||
|
+#include <sys/types.h>
|
||||||
|
+#include <sys/wait.h>
|
||||||
|
+#include <unistd.h>
|
||||||
|
+
|
||||||
|
+#define STACK_SIZE 0x1000
|
||||||
|
+
|
||||||
|
+int clone_pid;
|
||||||
|
+
|
||||||
|
+static int
|
||||||
|
+clone_fn (void *unused)
|
||||||
|
+{
|
||||||
|
+ /* Wait for alarm. */
|
||||||
|
+ while (1)
|
||||||
|
+ sleep (1);
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+int
|
||||||
|
+main (int argc, char **argv)
|
||||||
|
+{
|
||||||
|
+ unsigned char *stack;
|
||||||
|
+ int res;
|
||||||
|
+
|
||||||
|
+ alarm (300);
|
||||||
|
+
|
||||||
|
+ stack = malloc (STACK_SIZE);
|
||||||
|
+ assert (stack != NULL);
|
||||||
|
+
|
||||||
|
+#define CLONE_FLAGS (CLONE_THREAD | CLONE_SIGHAND | CLONE_VM)
|
||||||
|
+
|
||||||
|
+#ifdef __ia64__
|
||||||
|
+ clone_pid = __clone2 (clone_fn, stack, STACK_SIZE, CLONE_FLAGS, NULL);
|
||||||
|
+#else
|
||||||
|
+ clone_pid = clone (clone_fn, stack + STACK_SIZE, CLONE_FLAGS, NULL);
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
+ assert (clone_pid > 0);
|
||||||
|
+
|
||||||
|
+ /* Wait for alarm. */
|
||||||
|
+ while (1)
|
||||||
|
+ sleep (1);
|
||||||
|
+
|
||||||
|
+ return 0;
|
||||||
|
+}
|
||||||
|
diff --git a/gdb/testsuite/gdb.threads/clone-attach-detach.exp b/gdb/testsuite/gdb.threads/clone-attach-detach.exp
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..0652108
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/gdb/testsuite/gdb.threads/clone-attach-detach.exp
|
||||||
|
@@ -0,0 +1,63 @@
|
||||||
|
+# This testcase is part of GDB, the GNU debugger.
|
||||||
|
+
|
||||||
|
+# Copyright 2016 Free Software Foundation, Inc.
|
||||||
|
+
|
||||||
|
+# This program is free software; you can redistribute it and/or modify
|
||||||
|
+# it under the terms of the GNU General Public License as published by
|
||||||
|
+# the Free Software Foundation; either version 3 of the License, or
|
||||||
|
+# (at your option) any later version.
|
||||||
|
+#
|
||||||
|
+# This program is distributed in the hope that it will be useful,
|
||||||
|
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
+# GNU General Public License for more details.
|
||||||
|
+#
|
||||||
|
+# You should have received a copy of the GNU General Public License
|
||||||
|
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
+
|
||||||
|
+# Test attach / detach from a process that uses raw clone. We use raw
|
||||||
|
+# clone as proxy for when libthread_db is not available.
|
||||||
|
+
|
||||||
|
+# This only works on targets with the Linux kernel.
|
||||||
|
+if ![istarget *-*-linux*] {
|
||||||
|
+ return
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+if {![can_spawn_for_attach]} {
|
||||||
|
+ return 0
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+standard_testfile
|
||||||
|
+
|
||||||
|
+if [prepare_for_testing "failed to prepare" $testfile $srcfile {debug}] {
|
||||||
|
+ return -1
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+clean_restart ${binfile}
|
||||||
|
+
|
||||||
|
+set test_spawn_id [spawn_wait_for_attach $binfile]
|
||||||
|
+set testpid [spawn_id_get_pid $test_spawn_id]
|
||||||
|
+
|
||||||
|
+# Native/gdbserver.
|
||||||
|
+set thread_re "(LWP $decimal|Thread )"
|
||||||
|
+
|
||||||
|
+# Try attach / detach a few times, in case GDB ends up with stale
|
||||||
|
+# state after detaching.
|
||||||
|
+
|
||||||
|
+set attempts 3
|
||||||
|
+for {set attempt 1} {$attempt <= $attempts} {incr attempt} {
|
||||||
|
+ with_test_prefix "fg attach $attempt" {
|
||||||
|
+
|
||||||
|
+ gdb_test "attach $testpid" \
|
||||||
|
+ "Attaching to program.*process $testpid.*" \
|
||||||
|
+ "attach"
|
||||||
|
+
|
||||||
|
+ gdb_test "info threads" \
|
||||||
|
+ "1.*${thread_re}.*\r\n.*2.*${thread_re}.*" \
|
||||||
|
+ "info threads shows two LWPs"
|
||||||
|
+
|
||||||
|
+ gdb_test "detach" "Detaching from .*, process $testpid"
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+kill_wait_spawned_process $test_spawn_id
|
||||||
|
--
|
||||||
|
2.5.5
|
||||||
|
|
9
gdb.spec
9
gdb.spec
@ -27,7 +27,7 @@ Version: 7.11
|
|||||||
|
|
||||||
# The release always contains a leading reserved number, start it at 1.
|
# The release always contains a leading reserved number, start it at 1.
|
||||||
# `upstream' is not a part of `name' to stay fully rpm dependencies compatible for the testing.
|
# `upstream' is not a part of `name' to stay fully rpm dependencies compatible for the testing.
|
||||||
Release: 63%{?dist}
|
Release: 64%{?dist}
|
||||||
|
|
||||||
License: GPLv3+ and GPLv3+ with exceptions and GPLv2+ and GPLv2+ with exceptions and GPL+ and LGPLv2+ and BSD and Public Domain and GFDL
|
License: GPLv3+ and GPLv3+ with exceptions and GPLv2+ and GPLv2+ with exceptions and GPL+ and LGPLv2+ and BSD and Public Domain and GFDL
|
||||||
Group: Development/Debuggers
|
Group: Development/Debuggers
|
||||||
@ -554,6 +554,9 @@ Patch1075: gdb-testsuite-readline63-sigint.patch
|
|||||||
#=fedoratest
|
#=fedoratest
|
||||||
Patch1113: gdb-rhbz1261564-aarch64-hw-watchpoint-test.patch
|
Patch1113: gdb-rhbz1261564-aarch64-hw-watchpoint-test.patch
|
||||||
|
|
||||||
|
# Fix non-stop gdb -p <container>: internal error (pedro Alves, RH BZ 1318049).
|
||||||
|
Patch1117: gdb-rhbz1318049-gdb-p-container-internal-error.patch
|
||||||
|
|
||||||
%if 0%{!?rhel:1} || 0%{?rhel} > 6
|
%if 0%{!?rhel:1} || 0%{?rhel} > 6
|
||||||
# RL_STATE_FEDORA_GDB would not be found for:
|
# RL_STATE_FEDORA_GDB would not be found for:
|
||||||
# Patch642: gdb-readline62-ask-more-rh.patch
|
# Patch642: gdb-readline62-ask-more-rh.patch
|
||||||
@ -860,6 +863,7 @@ find -name "*.info*"|xargs rm -f
|
|||||||
%patch331 -p1
|
%patch331 -p1
|
||||||
%patch1075 -p1
|
%patch1075 -p1
|
||||||
%patch1113 -p1
|
%patch1113 -p1
|
||||||
|
%patch1117 -p1
|
||||||
|
|
||||||
%if 0%{?rhel:1} && 0%{?rhel} <= 7
|
%if 0%{?rhel:1} && 0%{?rhel} <= 7
|
||||||
%patch1044 -p1
|
%patch1044 -p1
|
||||||
@ -1377,6 +1381,9 @@ then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Wed Apr 6 2016 Jan Kratochvil <jan.kratochvil@redhat.com> - 7.11-64.fc24
|
||||||
|
- Fix non-stop gdb -p <container>: internal error (pedro Alves, RH BZ 1318049).
|
||||||
|
|
||||||
* Sat Mar 19 2016 Jan Kratochvil <jan.kratochvil@redhat.com> - 7.11-63.fc24
|
* Sat Mar 19 2016 Jan Kratochvil <jan.kratochvil@redhat.com> - 7.11-63.fc24
|
||||||
- .spec cleanup: Drop strict-aliasing GCC bug workaround (from RH BZ 1315191).
|
- .spec cleanup: Drop strict-aliasing GCC bug workaround (from RH BZ 1315191).
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user