diff options
author | Pedro Alves <palves@redhat.com> | 2015-08-07 17:23:57 +0100 |
---|---|---|
committer | Pedro Alves <palves@redhat.com> | 2015-08-07 17:23:57 +0100 |
commit | 6c4cfb244b408f980be24ea2175bc58baf74a6f9 (patch) | |
tree | 452e3d92b8d2dfe5b0ed1a28795e9bb694b76560 /gdb | |
parent | 567420d10895611e03d5ee65e6b24c16a69a6e99 (diff) | |
download | gdb-6c4cfb244b408f980be24ea2175bc58baf74a6f9.zip gdb-6c4cfb244b408f980be24ea2175bc58baf74a6f9.tar.gz gdb-6c4cfb244b408f980be24ea2175bc58baf74a6f9.tar.bz2 |
Make thread_still_needs_step_over consider stepping_over_watchpoint too
I noticed that even though keep_going knows to start a step over for a
watchpoint, thread_still_needs_step_over forgets it.
gdb/ChangeLog:
2015-08-07 Pedro Alves <palves@redhat.com>
* infrun.c (thread_still_needs_step_over): Rename to ...
(thread_still_needs_step_over_bp): ... this.
(enum step_over_what): New.
(thread_still_needs_step_over): Reimplement.
Diffstat (limited to 'gdb')
-rw-r--r-- | gdb/ChangeLog | 7 | ||||
-rw-r--r-- | gdb/infrun.c | 43 |
2 files changed, 46 insertions, 4 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 5bf3d75..5054402 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,5 +1,12 @@ 2015-08-07 Pedro Alves <palves@redhat.com> + * infrun.c (thread_still_needs_step_over): Rename to ... + (thread_still_needs_step_over_bp): ... this. + (enum step_over_what): New. + (thread_still_needs_step_over): Reimplement. + +2015-08-07 Pedro Alves <palves@redhat.com> + * remote.c (remote_wait_as): If not waiting for a stop reply, return TARGET_WAITKIND_NO_RESUMED. If TARGET_WNOHANG is requested, don't block waiting forever. diff --git a/gdb/infrun.c b/gdb/infrun.c index 7116961..d3cd0ae 100644 --- a/gdb/infrun.c +++ b/gdb/infrun.c @@ -1221,6 +1221,19 @@ follow_exec (ptid_t ptid, char *execd_pathname) matically get reset there in the new process.). */ } +/* Bit flags indicating what the thread needs to step over. */ + +enum step_over_what + { + /* Step over a breakpoint. */ + STEP_OVER_BREAKPOINT = 1, + + /* Step past a non-continuable watchpoint, in order to let the + instruction execute so we can evaluate the watchpoint + expression. */ + STEP_OVER_WATCHPOINT = 2 + }; + /* Info about an instruction that is being stepped over. */ struct step_over_info @@ -2506,7 +2519,7 @@ clear_proceed_status (int step) meanwhile, we can skip the whole step-over dance. */ static int -thread_still_needs_step_over (struct thread_info *tp) +thread_still_needs_step_over_bp (struct thread_info *tp) { if (tp->stepping_over_breakpoint) { @@ -2523,6 +2536,26 @@ thread_still_needs_step_over (struct thread_info *tp) return 0; } +/* Check whether thread TP still needs to start a step-over in order + to make progress when resumed. Returns an bitwise or of enum + step_over_what bits, indicating what needs to be stepped over. */ + +static int +thread_still_needs_step_over (struct thread_info *tp) +{ + struct inferior *inf = find_inferior_ptid (tp->ptid); + int what = 0; + + if (thread_still_needs_step_over_bp (tp)) + what |= STEP_OVER_BREAKPOINT; + + if (tp->stepping_over_watchpoint + && !target_have_steppable_watchpoint) + what |= STEP_OVER_WATCHPOINT; + + return what; +} + /* Returns true if scheduler locking applies. STEP indicates whether we're about to do a step/next-like command to a thread. */ @@ -6281,6 +6314,7 @@ keep_going (struct execution_control_state *ecs) struct regcache *regcache = get_current_regcache (); int remove_bp; int remove_wps; + enum step_over_what step_what; /* Either the trap was not expected, but we are continuing anyway (if we got a signal, the user asked it be passed to @@ -6301,10 +6335,11 @@ keep_going (struct execution_control_state *ecs) instruction, and then re-insert the breakpoint when that step is finished. */ + step_what = thread_still_needs_step_over (ecs->event_thread); + remove_bp = (ecs->hit_singlestep_breakpoint - || thread_still_needs_step_over (ecs->event_thread)); - remove_wps = (ecs->event_thread->stepping_over_watchpoint - && !target_have_steppable_watchpoint); + || (step_what & STEP_OVER_BREAKPOINT)); + remove_wps = (step_what & STEP_OVER_WATCHPOINT); /* We can't use displaced stepping if we need to step past a watchpoint. The instruction copied to the scratch pad would |