diff options
author | Christopher Faylor <me@cgf.cx> | 2003-12-16 23:28:03 +0000 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2003-12-16 23:28:03 +0000 |
commit | 1ed95be609c9af283fe0c1b21b760b3abc0792f8 (patch) | |
tree | f66a56ac47a1bcf0e3fc9090cb96da31f51d0608 /winsup/cygwin/sigproc.cc | |
parent | 0c3966ac4e4452bf2c38385291dfefc70b3f53d5 (diff) | |
download | cygnal-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.cc | 21 |
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; } |