From: tpfaff Date: Tue, 14 Jan 2003 20:13:06 +0000 (+0000) Subject: Apply wait_cancel patch X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=5a736aad6d66201f85d6e1f90ffc7e0088760a00;p=pf3gnuchains%2Fsourceware.git Apply wait_cancel patch --- diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index 8ddb86120b..c41395a018 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,5 +1,12 @@ 2003-01-14 Thomas Pfaff + * wait.cc: Include thread.h + (wait4): Add pthread_testcancel call. + Wait for child process and cancellation event. + * thread.cc: Update list of cancellation points. + +2003-01-14 Thomas Pfaff + * signal.cc (sleep): Add pthread_testcancel call. Wait for signal and cancellation event. (usleep): Ditto. diff --git a/winsup/cygwin/thread.cc b/winsup/cygwin/thread.cc index 2d154b4a2b..649a3571b9 100644 --- a/winsup/cygwin/thread.cc +++ b/winsup/cygwin/thread.cc @@ -481,10 +481,10 @@ sigwaitinfo () system () tcdrain () *usleep () -wait () -wait3() +*wait () +*wait3() waitid () -waitpid () +*waitpid () write () writev () diff --git a/winsup/cygwin/wait.cc b/winsup/cygwin/wait.cc index a4e7c60a2d..c66df1b312 100644 --- a/winsup/cygwin/wait.cc +++ b/winsup/cygwin/wait.cc @@ -15,6 +15,7 @@ details. */ #include "cygerrno.h" #include "sigproc.h" #include "perthread.h" +#include "thread.h" /* This is called _wait and not wait because the real wait is defined in libc/syscalls/syswait.c. It calls us. */ @@ -51,6 +52,8 @@ wait4 (int intpid, int *status, int options, struct rusage *r) HANDLE waitfor; bool sawsig; + pthread_testcancel (); + while (1) { sig_dispatch_pending (0); @@ -84,7 +87,7 @@ wait4 (int intpid, int *status, int options, struct rusage *r) if ((waitfor = w->ev) == NULL) goto nochildren; - res = WaitForSingleObject (waitfor, INFINITE); + res = pthread::cancelable_wait (waitfor, INFINITE); sigproc_printf ("%d = WaitForSingleObject (...)", res);