diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2015-10-30 16:05:43 +0100 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2015-10-30 16:05:43 +0100 |
commit | 8f97c045b8e65784071fd097fc32a1f16b855b3b (patch) | |
tree | 396d30de65dba1a54afe97023f37ad1dd8fe1184 /winsup/cygwin | |
parent | ff3c4a7d2fd686543140b0d39177c3464d1444e1 (diff) | |
download | newlib-8f97c045b8e65784071fd097fc32a1f16b855b3b.zip newlib-8f97c045b8e65784071fd097fc32a1f16b855b3b.tar.gz newlib-8f97c045b8e65784071fd097fc32a1f16b855b3b.tar.bz2 |
Fix sigwait and pthread_kill return values in case of error
* signal.cc (sigwait): Fix return value to reflect errno in case of
error according to POSIX. Never return EINTR.
* thread.cc (pthread_kill): Return errno if sig_send failed.
Signed-off-by: Corinna Vinschen <corinna@vinschen.de>
Diffstat (limited to 'winsup/cygwin')
-rw-r--r-- | winsup/cygwin/ChangeLog | 6 | ||||
-rw-r--r-- | winsup/cygwin/release/2.3.0 | 4 | ||||
-rw-r--r-- | winsup/cygwin/signal.cc | 10 | ||||
-rw-r--r-- | winsup/cygwin/thread.cc | 6 |
4 files changed, 23 insertions, 3 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index 337a1d2..3fb4372 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,9 @@ +2015-10-30 Corinna Vinschen <corinna@vinschen.de> + + * signal.cc (sigwait): Fix return value to reflect errno in case of + error according to POSIX. Never return EINTR. + * thread.cc (pthread_kill): Return errno if sig_send failed. + 2015-10-29 Qian Hong <qhong@codeweavers.com> * init.cc (munge_threadfunc): Check that we're actually replacing diff --git a/winsup/cygwin/release/2.3.0 b/winsup/cygwin/release/2.3.0 index c6f70aa..1cad81b 100644 --- a/winsup/cygwin/release/2.3.0 +++ b/winsup/cygwin/release/2.3.0 @@ -53,3 +53,7 @@ Bug Fixes - Fix a potential SEGV on (at least) Wine. Addresses: https://cygwin.com/ml/cygwin/2015-10/msg00018.html + +- Fix sigwait(3) to return errno instead of -1 and never to return with EINTR. + +- Fix pthread_kill(3) to return errno instead of -1. diff --git a/winsup/cygwin/signal.cc b/winsup/cygwin/signal.cc index 4897417..8dfd4ab 100644 --- a/winsup/cygwin/signal.cc +++ b/winsup/cygwin/signal.cc @@ -557,10 +557,16 @@ siginterrupt (int sig, int flag) extern "C" int sigwait (const sigset_t *set, int *sig_ptr) { - int sig = sigwaitinfo (set, NULL); + int sig; + + do + { + sig = sigwaitinfo (set, NULL); + } + while (sig == -1 && get_errno () == EINTR); if (sig > 0) *sig_ptr = sig; - return sig > 0 ? 0 : -1; + return sig > 0 ? 0 : get_errno (); } extern "C" int diff --git a/winsup/cygwin/thread.cc b/winsup/cygwin/thread.cc index d9b6211..ff84590 100644 --- a/winsup/cygwin/thread.cc +++ b/winsup/cygwin/thread.cc @@ -3056,7 +3056,11 @@ pthread_kill (pthread_t thread, int sig) if (!thread->valid) rval = ESRCH; else if (sig) - rval = sig_send (NULL, si, thread->cygtls); + { + rval = sig_send (NULL, si, thread->cygtls); + if (rval == -1) + rval = get_errno (); + } else switch (WaitForSingleObject (thread->win32_obj_id, 0)) { |