From: Rich Felker Date: Wed, 3 Aug 2011 12:36:13 +0000 (-0400) Subject: timedwait: play it safe for now X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=commitdiff_plain;h=8aeee8db21858becb45a8e9f6b5bc23109638bcb timedwait: play it safe for now it's unclear whether EINVAL or ENOSYS is used when the operation is not supported, so check for both... --- diff --git a/src/thread/__timedwait.c b/src/thread/__timedwait.c index 0444d39f..e15e2d0a 100644 --- a/src/thread/__timedwait.c +++ b/src/thread/__timedwait.c @@ -16,7 +16,7 @@ static int do_wait(volatile int *addr, int val, clockid_t clk, const struct time if (clk == CLOCK_REALTIME) flag = FUTEX_CLOCK_REALTIME; if (cp) r = -__syscall_cp(SYS_futex, addr, FUTEX_WAIT_BITSET|flag, val, at, 0, -1); else r = -__syscall(SYS_futex, addr, FUTEX_WAIT_BITSET|flag, val, at, 0, -1); - if (r != EINVAL) goto done; + if (r != EINVAL && r != ENOSYS) goto done; } if (clock_gettime(clk, &to)) return EINVAL; to.tv_sec = at->tv_sec - to.tv_sec;