mirror of
https://github.com/espressif/binutils-gdb.git
synced 2025-06-26 22:07:58 +08:00
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.
This commit is contained in:
@ -1,3 +1,10 @@
|
|||||||
|
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>
|
2015-08-07 Pedro Alves <palves@redhat.com>
|
||||||
|
|
||||||
* remote.c (remote_wait_as): If not waiting for a stop reply,
|
* remote.c (remote_wait_as): If not waiting for a stop reply,
|
||||||
|
43
gdb/infrun.c
43
gdb/infrun.c
@ -1221,6 +1221,19 @@ follow_exec (ptid_t ptid, char *execd_pathname)
|
|||||||
matically get reset there in the new process.). */
|
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. */
|
/* Info about an instruction that is being stepped over. */
|
||||||
|
|
||||||
struct step_over_info
|
struct step_over_info
|
||||||
@ -2506,7 +2519,7 @@ clear_proceed_status (int step)
|
|||||||
meanwhile, we can skip the whole step-over dance. */
|
meanwhile, we can skip the whole step-over dance. */
|
||||||
|
|
||||||
static int
|
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)
|
if (tp->stepping_over_breakpoint)
|
||||||
{
|
{
|
||||||
@ -2523,6 +2536,26 @@ thread_still_needs_step_over (struct thread_info *tp)
|
|||||||
return 0;
|
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
|
/* Returns true if scheduler locking applies. STEP indicates whether
|
||||||
we're about to do a step/next-like command to a thread. */
|
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 ();
|
struct regcache *regcache = get_current_regcache ();
|
||||||
int remove_bp;
|
int remove_bp;
|
||||||
int remove_wps;
|
int remove_wps;
|
||||||
|
enum step_over_what step_what;
|
||||||
|
|
||||||
/* Either the trap was not expected, but we are continuing
|
/* Either the trap was not expected, but we are continuing
|
||||||
anyway (if we got a signal, the user asked it be passed to
|
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
|
instruction, and then re-insert the breakpoint when that step
|
||||||
is finished. */
|
is finished. */
|
||||||
|
|
||||||
|
step_what = thread_still_needs_step_over (ecs->event_thread);
|
||||||
|
|
||||||
remove_bp = (ecs->hit_singlestep_breakpoint
|
remove_bp = (ecs->hit_singlestep_breakpoint
|
||||||
|| thread_still_needs_step_over (ecs->event_thread));
|
|| (step_what & STEP_OVER_BREAKPOINT));
|
||||||
remove_wps = (ecs->event_thread->stepping_over_watchpoint
|
remove_wps = (step_what & STEP_OVER_WATCHPOINT);
|
||||||
&& !target_have_steppable_watchpoint);
|
|
||||||
|
|
||||||
/* We can't use displaced stepping if we need to step past a
|
/* We can't use displaced stepping if we need to step past a
|
||||||
watchpoint. The instruction copied to the scratch pad would
|
watchpoint. The instruction copied to the scratch pad would
|
||||||
|
Reference in New Issue
Block a user