aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPedro Alves <palves@redhat.com>2014-10-15 20:18:32 +0100
committerPedro Alves <palves@redhat.com>2014-10-15 20:18:32 +0100
commit36728e82bd9bb5b472eb569dc11b8f2296d5e3df (patch)
treed3a2371140f40b269e215fd232cb4b32e5f93a44
parent34b7e8a6ad0a735ecc0a953c8b65846d4776c88e (diff)
downloadgdb-36728e82bd9bb5b472eb569dc11b8f2296d5e3df.zip
gdb-36728e82bd9bb5b472eb569dc11b8f2296d5e3df.tar.gz
gdb-36728e82bd9bb5b472eb569dc11b8f2296d5e3df.tar.bz2
Non-stop + software single-step archs: don't force displaced-stepping for all single-steps
This finally reverts this bit of commit 929dfd4f: 2009-07-31 Pedro Alves <pedro@codesourcery.com> Julian Brown <julian@codesourcery.com> ... (resume): If this is a software single-stepping arch, and displaced-stepping is enabled, use it for all single-step requests. ... That means that in non-stop (or really displaced-stepping) mode, on software single-step archs - even those that only use sss breakpoints to deal with atomic sequences, like PPC - if we have more than one thread single-stepping, we'll always serialize the threads' single-steps, as only one thread may be displaced stepping at a given time, because there's only one scratch pad. We originally did that because GDB didn't support having multiple threads software-single-stepping simultaneously. The previous patches fixed that limitation, so we can now finally revert this too. Tested on: - x86_64 Fedora 20, on top of the 'software single-step on x86' series. gdb/ 2014-10-15 Pedro Alves <palves@redhat.com> * infrun.c (resume): Don't force displaced-stepping for all single-steps on software single-stepping archs.
-rw-r--r--gdb/ChangeLog5
-rw-r--r--gdb/infrun.c3
2 files changed, 6 insertions, 2 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index a2b197c..d4827d6 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,5 +1,10 @@
2014-10-15 Pedro Alves <palves@redhat.com>
+ * infrun.c (resume): Don't force displaced-stepping for all
+ single-steps on software single-stepping archs.
+
+2014-10-15 Pedro Alves <palves@redhat.com>
+
* breakpoint.c (single_step_breakpoints): Delete global.
(insert_single_step_breakpoint): Adjust to store the breakpoint
pointer in the current thread.
diff --git a/gdb/infrun.c b/gdb/infrun.c
index 0f30a62..23c79f2 100644
--- a/gdb/infrun.c
+++ b/gdb/infrun.c
@@ -2089,8 +2089,7 @@ a command like `return' or `jump' to continue execution."));
event, displaced stepping breaks the vfork child similarly as single
step software breakpoint. */
if (use_displaced_stepping (gdbarch)
- && (tp->control.trap_expected
- || (step && gdbarch_software_single_step_p (gdbarch)))
+ && tp->control.trap_expected
&& sig == GDB_SIGNAL_0
&& !current_inferior ()->waiting_for_vfork_done)
{