diff options
author | Christopher Faylor <me@cgf.cx> | 2011-12-16 05:27:15 +0000 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2011-12-16 05:27:15 +0000 |
commit | 08e4b6acb7c26e77fd1b52b063838459207d1708 (patch) | |
tree | 3642704eb095f8264deb093957ece77a7678e39d /winsup/cygwin/fhandler.cc | |
parent | e553b822e2eacd12285f30fd89b5738e7f4dbb20 (diff) | |
download | cygnal-08e4b6acb7c26e77fd1b52b063838459207d1708.tar.gz cygnal-08e4b6acb7c26e77fd1b52b063838459207d1708.tar.bz2 cygnal-08e4b6acb7c26e77fd1b52b063838459207d1708.zip |
* exceptions.cc (_cygtls::call_signal_handler): Fix debugging to not go to
console.
* fhandler.cc (fhandler_base_overlapped::wait_overlapped): Add temporary kludge
to work around problem of make closing a handler while it is being read.
* gendef (sigdelayed): Don't call a function if sig has been cleared.
* sigproc.h (cygwait): Simplify slightly.
Diffstat (limited to 'winsup/cygwin/fhandler.cc')
-rw-r--r-- | winsup/cygwin/fhandler.cc | 32 |
1 files changed, 19 insertions, 13 deletions
diff --git a/winsup/cygwin/fhandler.cc b/winsup/cygwin/fhandler.cc index c6388cc64..b6c719ccd 100644 --- a/winsup/cygwin/fhandler.cc +++ b/winsup/cygwin/fhandler.cc @@ -1925,25 +1925,31 @@ fhandler_base_overlapped::wait_overlapped (bool inres, bool writing, DWORD *byte } if (res == overlapped_unknown) { - HANDLE h = writing ? get_output_handle () : get_handle (); DWORD wfres = cygwait (get_overlapped ()->hEvent); - /* Cancelling here to prevent races. It's possible that the I/O has - completed already, in which case this is a no-op. Otherwise, - WFMO returned because 1) This is a non-blocking call, 2) a signal - arrived, or 3) the operation was cancelled. These cases may be - overridden by the return of GetOverlappedResult which could detect - that I/O completion occurred. */ - CancelIo (h); - BOOL wores = GetOverlappedResult (h, get_overlapped (), bytes, false); - err = GetLastError (); - ResetEvent (get_overlapped ()->hEvent); /* Probably not needed but CYA */ - debug_printf ("wfres %d, wores %d, bytes %u", wfres, wores, *bytes); + HANDLE h = writing ? get_output_handle () : get_handle (); + BOOL wores; + if (wfres == WAIT_OBJECT_0 + 1 && !get_overlapped ()) + wores = 0; + else + { + /* Cancelling here to prevent races. It's possible that the I/O has + completed already, in which case this is a no-op. Otherwise, + WFMO returned because 1) This is a non-blocking call, 2) a signal + arrived, or 3) the operation was cancelled. These cases may be + overridden by the return of GetOverlappedResult which could detect + that I/O completion occurred. */ + CancelIo (h); + BOOL wores = GetOverlappedResult (h, get_overlapped (), bytes, false); + err = GetLastError (); + ResetEvent (get_overlapped ()->hEvent); /* Probably not needed but CYA */ + debug_printf ("wfres %d, wores %d, bytes %u", wfres, wores, *bytes); + } if (wores) res = overlapped_success; /* operation succeeded */ else if (wfres == WAIT_OBJECT_0 + 1) { err = ERROR_INVALID_AT_INTERRUPT_TIME; /* forces an EINTR below */ - debug_printf ("unhandled signal"); + debug_printf ("signal"); res = overlapped_error; } else if (nonblocking) |