summaryrefslogtreecommitdiff
path: root/gdb/lin-lwp.c
diff options
context:
space:
mode:
authorMichael Snyder <msnyder@specifix.com>2001-05-30 18:15:45 +0000
committerMichael Snyder <msnyder@specifix.com>2001-05-30 18:15:45 +0000
commitdd45e34d4ea8f28ad6f2e3d98ed2d7f9e4f792a2 (patch)
treee5ebb61a3a81ba705b650068aef76f6de2207d23 /gdb/lin-lwp.c
parent1413c584d9ce5135e1c2f6daa085df575ec7d3dc (diff)
downloadgdb-dd45e34d4ea8f28ad6f2e3d98ed2d7f9e4f792a2.tar.gz
2001-05-25 Michael Snyder <msnyder@redhat.com>
* lin-lwp.c (stop_wait_callback): Discard redundant SIGINT events.
Diffstat (limited to 'gdb/lin-lwp.c')
-rw-r--r--gdb/lin-lwp.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/gdb/lin-lwp.c b/gdb/lin-lwp.c
index 2d2a2b6d9f5..923d43b393f 100644
--- a/gdb/lin-lwp.c
+++ b/gdb/lin-lwp.c
@@ -610,6 +610,15 @@ stop_wait_callback (struct lwp_info *lp, void *data)
- DECR_PC_AFTER_BREAK,
pid_to_ptid (pid));
}
+ else if (WSTOPSIG (status) == SIGINT &&
+ signal_pass_state (SIGINT) == 0)
+ {
+ /* Since SIGINT gets forwarded to the entire process group
+ (in the case where ^C/BREAK is typed at the tty/console),
+ just ignore all SIGINT events from all lwp's except for
+ the one that was caught by lin_lwp_wait. */
+ ; /* Don't save. Signal will disappear into oblivion. */
+ }
else
{
if (debug_lin_lwp)
@@ -618,7 +627,7 @@ stop_wait_callback (struct lwp_info *lp, void *data)
strsignal (WSTOPSIG (status)), pid);
/* The thread was stopped with a signal other than
- SIGSTOP, and didn't accidentiliy trip a breakpoint.
+ SIGSTOP, and didn't accidentally trip a breakpoint.
Record the wait status. */
lp->status = status;
}