From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 63812 invoked by alias); 21 May 2015 23:19:19 -0000 Mailing-List: contact gdb-patches-help@sourceware.org; run by ezmlm Precedence: bulk List-Id: List-Subscribe: List-Archive: List-Post: List-Help: , Sender: gdb-patches-owner@sourceware.org Received: (qmail 63800 invoked by uid 89); 21 May 2015 23:19:18 -0000 Authentication-Results: sourceware.org; auth=none X-Virus-Found: No X-Spam-SWARE-Status: No, score=-0.1 required=5.0 tests=AWL,BAYES_50,KAM_LAZY_DOMAIN_SECURITY,SPF_HELO_PASS,T_RP_MATCHES_RCVD autolearn=no version=3.3.2 X-HELO: mx1.redhat.com Received: from mx1.redhat.com (HELO mx1.redhat.com) (209.132.183.28) by sourceware.org (qpsmtpd/0.93/v0.84-503-g423c35a) with (AES256-GCM-SHA384 encrypted) ESMTPS; Thu, 21 May 2015 23:19:17 +0000 Received: from int-mx13.intmail.prod.int.phx2.redhat.com (int-mx13.intmail.prod.int.phx2.redhat.com [10.5.11.26]) by mx1.redhat.com (8.14.4/8.14.4) with ESMTP id t4LNJGm5000775 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=FAIL) for ; Thu, 21 May 2015 19:19:16 -0400 Received: from brno.lan (ovpn01.gateway.prod.ext.ams2.redhat.com [10.39.146.11]) by int-mx13.intmail.prod.int.phx2.redhat.com (8.14.4/8.14.4) with ESMTP id t4LNJEIw027592 for ; Thu, 21 May 2015 19:19:15 -0400 From: Pedro Alves To: gdb-patches@sourceware.org Subject: [PATCH v4 00/18] All-stop on top of non-stop Date: Thu, 21 May 2015 23:19:00 -0000 Message-Id: <1432250354-2721-1-git-send-email-palves@redhat.com> X-SW-Source: 2015-05/txt/msg00564.txt.bz2 v3: https://sourceware.org/ml/gdb-patches/2015-04/msg00662.html v2: https://sourceware.org/ml/gdb-patches/2015-04/msg00198.html v1: https://sourceware.org/ml/gdb-patches/2015-04/msg00073.html Compared to v3, a set of minor changes accumulated, to address review comments and discussions (i.e., no major functional/design changes), plus fixes to a patch that touched all targets (that I noticed converted a couple wrong). I believe I addressed all review comments thus far. Barring comments, I'd like to push this in, and expose it to the build bots. I tried to mention the differences to v3 in each patch that had changes, if any (scroll past ChangeLog). Documentation changes have not changed, and have already been approved. Note most of these patches could go in without the final bits that actually do all-stop-on-top-of-non-stop, as they fix problems that exist e.g., with "set non-stop on" or "set displaced-stepping on" too. I've again (force) pushed this to users/palves/all-stop-non-stop for review and testing convenience. As nothing major changed, I retested the whole series on x86-64 only. v3 was tested on: x86-64 GNU/Linux x86-64 GNU/Linux on top of software single-step branch PPC64 GNU/Linux S/390 GNU/Linux ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Series-intro proper follows: This series implements user-visible all-stop mode running with the target_ops backend always in non-stop mode. This is a stepping stone towards finer-grained control of threads, being able to do interesting things like inferior and thread groups/sets (itsets), associating groups with breakpoints (which threads cause a stop, which threads are implicitly paused when a breakpoint triggers), etc. From the user's perspective, all-stop mode is really just a special case of being able to stop and resume specific sets of threads, so it makes sense to do this step first. After this series, even in all-stop mode ("set non-stop off", the default) the target is no longer in charge of stopping all threads before reporting an event to the core -- the core takes care of it when it sees fit. For example, when "next"- or "step"-ing, we can avoid stopping and resuming all threads at each internal single-step, and instead only stop all threads when we're about to present the stop to the user. In order to get there, the series teaches GDB to do non-stop mode even without displaced stepping (stop all threads, step over breakpoint, restart threads), as displaced stepping isn't implemented everywhere, and doesn't work in some scenarios (as in, we can't use it, not that it's buggy). And then it fixes all testsuite regressions (on native x86-64, ppc64 and s390 GNU/Linux) this new mode causes, compared to all-stop ("set non-stop off") with the target backend in all-stop mode too (i.e., the current default). Making "target remote" work in always non-stop mode is deferred for later (this will be even more useful for remote as the all-stop mode RSP variant can't really do asynchronous debugging). Tested on x86_64 Fedora 20, native, with and without "set displaced off", and with and without "maint set target-non-stop on"; and also against gdbserver. Tested on x86-64 GNU/Linux native on top of x86 software single-step branch. Tested on PPC64 Fedora 18. Tested on S/390 RHEL 7.1. Pedro Alves (18): Fix and test "checkpoint" in non-stop mode Change adjust_pc_after_break's prototype remote.c/all-stop: Implement TARGET_WAITKIND_NO_RESUMED and TARGET_WNOHANG Make thread_still_needs_step_over consider stepping_over_watchpoint too Embed the pending step-over chain in thread_info objects Use keep_going in proceed and start_step_over too Misc switch_back_to_stepped_thread cleanups Add comments to currently_stepping and target_resume Factor out code to re-resume stepped thread Teach non-stop to do in-line step-overs (stop all, step, restart) Implement all-stop on top of a target running non-stop mode Fix signal-while-stepping-over-bp-other-thread.exp on targets always in non-stop Fix interrupt-noterm.exp on targets always in non-stop Fix step-over-{trips-on-watchpoint|lands-on-breakpoint}.exp race Disable displaced stepping if trying it fails PPC64: Fix gdb.arch/ppc64-atomic-inst.exp with displaced stepping S/390: displaced stepping and PC-relative RIL-b/RIL-c instructions native Linux: enable always non-stop by default gdb/ChangeLog | 18 + gdb/testsuite/ChangeLog | 6 + gdb/NEWS | 6 + gdb/breakpoint.c | 11 +- gdb/darwin-nat.c | 6 +- gdb/doc/gdb.texinfo | 24 + gdb/gdbarch.h | 6 +- gdb/gdbarch.sh | 4 + gdb/gdbthread.h | 61 +- gdb/inf-ptrace.c | 6 +- gdb/infcmd.c | 6 +- gdb/infrun.c | 2330 +++++++++++++++----- gdb/infrun.h | 7 + gdb/linux-nat.c | 33 +- gdb/nto-procfs.c | 16 +- gdb/procfs.c | 6 +- gdb/remote-m32r-sdi.c | 6 +- gdb/remote-sim.c | 20 +- gdb/remote.c | 57 +- gdb/rs6000-tdep.c | 68 +- gdb/s390-linux-tdep.c | 115 +- gdb/target-delegates.c | 59 + gdb/target.c | 92 + gdb/target.h | 28 +- gdb/target/waitstatus.h | 5 +- gdb/testsuite/gdb.arch/ppc64-atomic-inst.exp | 50 +- gdb/testsuite/gdb.base/checkpoint-ns.exp | 26 + gdb/testsuite/gdb.base/checkpoint.exp | 6 +- gdb/testsuite/gdb.base/valgrind-disp-step.c | 32 + gdb/testsuite/gdb.base/valgrind-disp-step.exp | 131 ++ .../signal-while-stepping-over-bp-other-thread.exp | 2 +- .../gdb.threads/step-over-lands-on-breakpoint.c | 17 +- .../gdb.threads/step-over-lands-on-breakpoint.exp | 6 +- .../gdb.threads/step-over-trips-on-watchpoint.c | 17 +- .../gdb.threads/step-over-trips-on-watchpoint.exp | 9 +- gdb/thread.c | 197 +- gdb/windows-nat.c | 6 +- 37 files changed, 2793 insertions(+), 702 deletions(-) create mode 100644 gdb/testsuite/gdb.base/checkpoint-ns.exp create mode 100644 gdb/testsuite/gdb.base/valgrind-disp-step.c create mode 100644 gdb/testsuite/gdb.base/valgrind-disp-step.exp -- 1.9.3