diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index 8ddb86120..c41395a01 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,10 @@ +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. diff --git a/winsup/cygwin/thread.cc b/winsup/cygwin/thread.cc index 2d154b4a2..649a3571b 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 a4e7c60a2..c66df1b31 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);