From: Mark Kettenis Date: Sat, 11 Dec 2004 21:53:58 +0000 (+0000) Subject: * inf-ttrace.c (inf_ttrace_him): Set TTEVT_BPT_SSTEP if available. X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=e901213603570d135d8fde4e79031f04f931dad1;p=pf3gnuchains%2Fpf3gnuchains3x.git * inf-ttrace.c (inf_ttrace_him): Set TTEVT_BPT_SSTEP if available. (inf_ttrace_attach): Likewise. (inf_ttrace_resume_callback): New function. (inf_ttrace_resume): Don't use TT_PROC_CONTINUE. Iterate over all lwps and call inf_ttrace_resume_callback instead. (inf_ttrace_wait): Handle TTEVT_BPT_SSTEP. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index dc253330a8..471704c62e 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,5 +1,12 @@ 2004-12-11 Mark Kettenis + * inf-ttrace.c (inf_ttrace_him): Set TTEVT_BPT_SSTEP if available. + (inf_ttrace_attach): Likewise. + (inf_ttrace_resume_callback): New function. + (inf_ttrace_resume): Don't use TT_PROC_CONTINUE. Iterate over all + lwps and call inf_ttrace_resume_callback instead. + (inf_ttrace_wait): Handle TTEVT_BPT_SSTEP. + * inf-ttrace.c (_initialize_inf_ttrace): Unconditionially compile. 2004-12-10 Michael Snyder diff --git a/gdb/inf-ttrace.c b/gdb/inf-ttrace.c index ea0bacd664..e560e58a6e 100644 --- a/gdb/inf-ttrace.c +++ b/gdb/inf-ttrace.c @@ -465,6 +465,9 @@ inf_ttrace_him (int pid) memset (&tte, 0, sizeof (tte)); tte.tte_events |= TTEVT_EXEC | TTEVT_EXIT; tte.tte_events |= TTEVT_LWP_CREATE | TTEVT_LWP_EXIT | TTEVT_LWP_TERMINATE; +#ifdef TTEVT_BPT_SSTEP + tte.tte_events |= TTEVT_BPT_SSTEP; +#endif tte.tte_opts = TTEO_NOSTRCCHLD; if (ttrace (TT_PROC_SET_EVENT_MASK, pid, 0, (uintptr_t)&tte, sizeof tte, 0) == -1) @@ -600,6 +603,9 @@ inf_ttrace_attach (char *args, int from_tty) memset (&tte, 0, sizeof (tte)); tte.tte_events |= TTEVT_EXEC | TTEVT_EXIT; tte.tte_events |= TTEVT_LWP_CREATE | TTEVT_LWP_EXIT | TTEVT_LWP_TERMINATE; +#ifdef TTEVT_BPT_SSTEP + tte.tte_events |= TTEVT_BPT_SSTEP; +#endif tte.tte_opts = TTEO_NOSTRCCHLD; if (ttrace (TT_PROC_SET_EVENT_MASK, pid, 0, (uintptr_t)&tte, sizeof tte, 0) == -1) @@ -643,6 +649,21 @@ inf_ttrace_detach (char *args, int from_tty) inferior_ptid = null_ptid; } +static int +inf_ttrace_resume_callback (struct thread_info *info, void *arg) +{ + if (!ptid_equal (info->ptid, inferior_ptid)) + { + pid_t pid = ptid_get_pid (info->ptid); + lwpid_t lwpid = ptid_get_lwp (info->ptid); + + if (ttrace (TT_LWP_CONTINUE, pid, lwpid, TT_NOPC, 0, 0) == -1) + perror_with_name ("ttrace"); + } + + return 0; +} + static void inf_ttrace_resume (ptid_t ptid, int step, enum target_signal signal) { @@ -660,11 +681,10 @@ inf_ttrace_resume (ptid_t ptid, int step, enum target_signal signal) if (ttrace (request, pid, lwpid, TT_NOPC, sig, 0) == -1) perror_with_name ("ttrace"); - if (ptid_equal (ptid, minus_one_ptid)) + if (ptid_equal (ptid, minus_one_ptid) && inf_ttrace_num_lwps > 0) { /* Let all the other threads run too. */ - if (ttrace (TT_PROC_CONTINUE, pid, 0, 0, 0, 0) == -1) - perror_with_name ("ttrace"); + iterate_over_threads (inf_ttrace_resume_callback, NULL); } } @@ -708,6 +728,14 @@ inf_ttrace_wait (ptid_t ptid, struct target_waitstatus *ourstatus) switch (tts.tts_event) { +#ifdef TTEVT_BPT_SSTEP + case TTEVT_BPT_SSTEP: + /* Make it look like a breakpoint. */ + ourstatus->kind = TARGET_WAITKIND_STOPPED; + ourstatus->value.sig = TARGET_SIGNAL_TRAP; + break; +#endif + case TTEVT_EXEC: /* Make it look like a breakpoint. */ ourstatus->kind = TARGET_WAITKIND_STOPPED;