summaryrefslogtreecommitdiffstats
path: root/winsup/cygwin/sigproc.cc
diff options
context:
space:
mode:
authorChristopher Faylor <me@cgf.cx>2003-02-21 04:33:53 +0000
committerChristopher Faylor <me@cgf.cx>2003-02-21 04:33:53 +0000
commit5cd8241242bc4635d4bf06fb65c8071ca8802c5d (patch)
treea4cef03932730e67c521a8165007fb06b4bdb751 /winsup/cygwin/sigproc.cc
parentd4806224b6a673a9d7a73d7849721852b7b77f47 (diff)
downloadcygnal-5cd8241242bc4635d4bf06fb65c8071ca8802c5d.tar.gz
cygnal-5cd8241242bc4635d4bf06fb65c8071ca8802c5d.tar.bz2
cygnal-5cd8241242bc4635d4bf06fb65c8071ca8802c5d.zip
* fhandler.cc (fhandler_base::open): Move some filesystem specific stuff.
(fhandler_disk_file::open): Accept some filesystem specific stuff. * sigproc.cc (wait_for_sigthread): Become slightly more thread safe. (sig_send): Don't assume that signal thread is ready.
Diffstat (limited to 'winsup/cygwin/sigproc.cc')
-rw-r--r--winsup/cygwin/sigproc.cc11
1 files changed, 7 insertions, 4 deletions
diff --git a/winsup/cygwin/sigproc.cc b/winsup/cygwin/sigproc.cc
index b453e8f03..5261c64d8 100644
--- a/winsup/cygwin/sigproc.cc
+++ b/winsup/cygwin/sigproc.cc
@@ -170,10 +170,12 @@ out:
void __stdcall
wait_for_sigthread ()
{
- assert (wait_sig_inited);
- (void) WaitForSingleObject (wait_sig_inited, INFINITE);
- (void) ForceCloseHandle (wait_sig_inited);
+ sigproc_printf ("wait_sig_inited %p", wait_sig_inited);
+ HANDLE hsig_inited = wait_sig_inited;
+ assert (hsig_inited);
+ (void) WaitForSingleObject (hsig_inited, INFINITE);
wait_sig_inited = NULL;
+ (void) ForceCloseHandle1 (hsig_inited, wait_sig_inited);
}
/* Get the sync_proc_subproc muto to control access to
@@ -654,7 +656,8 @@ sig_send (_pinfo *p, int sig, DWORD ebp, bool exception)
{
if (no_signals_available ())
goto out; // Either exiting or not yet initializing
- assert (!wait_sig_inited);
+ if (wait_sig_inited)
+ wait_for_sigthread ();
wait_for_completion = p != myself_nowait;
p = myself;
}