summaryrefslogtreecommitdiffstats
path: root/winsup/cygwin/sigproc.cc
diff options
context:
space:
mode:
authorChristopher Faylor <me@cgf.cx>2003-12-16 23:28:03 +0000
committerChristopher Faylor <me@cgf.cx>2003-12-16 23:28:03 +0000
commit1ed95be609c9af283fe0c1b21b760b3abc0792f8 (patch)
treef66a56ac47a1bcf0e3fc9090cb96da31f51d0608 /winsup/cygwin/sigproc.cc
parent0c3966ac4e4452bf2c38385291dfefc70b3f53d5 (diff)
downloadcygnal-1ed95be609c9af283fe0c1b21b760b3abc0792f8.tar.gz
cygnal-1ed95be609c9af283fe0c1b21b760b3abc0792f8.tar.bz2
cygnal-1ed95be609c9af283fe0c1b21b760b3abc0792f8.zip
* exceptions.cc (set_signal_mask): Report on input argument rather than
getsigmask. * fhandler.h (fhandler_base): Make friends with close_all_files. * pinfo.cc (_pinfo::set_ctty): Add more debugging. * sigproc.cc (proc_can_be_signalled): Detect state when signal handler thread is gone in target process as an EPERM situation. Set errno to ESRCH if process doesn't exist. (sigproc_terminate): Set sendsig to illegal value when closed. (sig_send): Rely on proc_can_be_signalled setting the proper errno. * syscalls.cc (close_all_files): Detect when all ttys are closed prior to calling close_all_files. The ctty needs to be closed explicitly in this case.
Diffstat (limited to 'winsup/cygwin/sigproc.cc')
-rw-r--r--winsup/cygwin/sigproc.cc21
1 files changed, 16 insertions, 5 deletions
diff --git a/winsup/cygwin/sigproc.cc b/winsup/cygwin/sigproc.cc
index 026e847d1..5150e54df 100644
--- a/winsup/cygwin/sigproc.cc
+++ b/winsup/cygwin/sigproc.cc
@@ -248,9 +248,19 @@ proc_can_be_signalled (_pinfo *p)
return true;
}
- return ISSTATE (p, PID_INITIALIZING) ||
- (((p)->process_state & (PID_ACTIVE | PID_IN_USE)) ==
- (PID_ACTIVE | PID_IN_USE));
+ if (p->sendsig == INVALID_HANDLE_VALUE)
+ {
+ set_errno (EPERM);
+ return false;
+ }
+
+ if (ISSTATE (p, PID_INITIALIZING) ||
+ (((p)->process_state & (PID_ACTIVE | PID_IN_USE)) ==
+ (PID_ACTIVE | PID_IN_USE)))
+ return true;
+
+ set_errno (ESRCH);
+ return false;
}
bool __stdcall
@@ -638,7 +648,9 @@ sigproc_terminate (void)
sig_loop_wait = 0; // Tell wait_sig to exit when it is
// finished with anything it is doing
ForceCloseHandle (sigcomplete_main);
- CloseHandle (myself->sendsig);
+ HANDLE sendsig = myself->sendsig;
+ myself->sendsig = INVALID_HANDLE_VALUE;
+ CloseHandle (sendsig);
}
proc_terminate (); // Terminate process handling thread
@@ -679,7 +691,6 @@ sig_send (_pinfo *p, int sig, void *tls)
{
sigproc_printf ("invalid pid %d(%x), signal %d",
p->pid, p->process_state, sig);
- set_errno (ESRCH);
goto out;
}