aboutsummaryrefslogtreecommitdiff
path: root/gdb
diff options
context:
space:
mode:
authorStu Grossman <grossman@cygnus>1992-11-05 03:54:01 +0000
committerStu Grossman <grossman@cygnus>1992-11-05 03:54:01 +0000
commit1549918a3f39110f41e78ab4ebbd022b4fe3da7d (patch)
tree268319c4dee1d6db77ca70dda30efa999645a13c /gdb
parentdf93a6c142231bdc1243bd65869b46e9e0045ac6 (diff)
downloadgdb-1549918a3f39110f41e78ab4ebbd022b4fe3da7d.zip
gdb-1549918a3f39110f41e78ab4ebbd022b4fe3da7d.tar.gz
gdb-1549918a3f39110f41e78ab4ebbd022b4fe3da7d.tar.bz2
* inflow.c (pass_signal, set_sigint_trap, clear_sigint_trap): Add
new routines to deal with sending SIGINTs to attached processes when the user interrupts the controlling GDB. * inftarg.c (child_wait), procfs.c (procfs_wait): Add calls to the aforementioned routines when waiting for the attached process.
Diffstat (limited to 'gdb')
-rw-r--r--gdb/ChangeLog6
-rw-r--r--gdb/procfs.c7
2 files changed, 13 insertions, 0 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index 7a23f15..8fe65bc 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,5 +1,11 @@
Wed Nov 4 15:27:31 1992 Stu Grossman (grossman at cygnus.com)
+ * inflow.c (pass_signal, set_sigint_trap, clear_sigint_trap): Add
+ new routines to deal with sending SIGINTs to attached processes
+ when the user interrupts the controlling GDB.
+ * inftarg.c (child_wait), procfs.c (procfs_wait): Add calls to
+ the aforementioned routines when waiting for the attached process.
+
* elfread.c, mipsread.c: Include <string.h>.
* i386-stub.c: Include "ansidecl.h" to deal with prototypes.
* serial.h: Add prototype for serial_restore().
diff --git a/gdb/procfs.c b/gdb/procfs.c
index 1a694e0..86885cc 100644
--- a/gdb/procfs.c
+++ b/gdb/procfs.c
@@ -1956,10 +1956,17 @@ procfs_wait (statloc)
}
else if (!(pi.prstatus.pr_flags & (PR_STOPPED | PR_ISTOP)))
{
+ if (attach_flag)
+ set_sigint_trap(); /* Causes SIGINT to be passed on to the
+ attached process. */
+
if (ioctl (pi.fd, PIOCWSTOP, &pi.prstatus) < 0)
{
checkerr++;
}
+
+ if (attach_flag)
+ clear_sigint_trap();
}
if (checkerr)
{