don't expose EAGAIN, etc. from timed futex wait to caller
authorRich Felker <dalias@aerifal.cx>
Wed, 16 Mar 2011 15:35:46 +0000 (11:35 -0400)
committerRich Felker <dalias@aerifal.cx>
Wed, 16 Mar 2011 15:35:46 +0000 (11:35 -0400)
src/thread/__timedwait.c

index 354def2c0f37016ea699fbcf2651dcad7953e582..988eb70ddf93294417442ed9878b7101cf5994d4 100644 (file)
@@ -6,6 +6,7 @@
 #include <stdio.h>
 int __timedwait(volatile int *addr, int val, clockid_t clk, const struct timespec *at, int priv)
 {
+       int r;
        struct timespec to;
        if (at) {
                clock_gettime(clk, &to);
@@ -17,5 +18,7 @@ int __timedwait(volatile int *addr, int val, clockid_t clk, const struct timespe
                if (to.tv_sec < 0) return ETIMEDOUT;
        }
        if (priv) priv = 128; priv=0;
-       return syscall4(__NR_futex, (long)addr, FUTEX_WAIT | priv, val, at ? (long)&to : 0);
+       r = syscall4(__NR_futex, (long)addr, FUTEX_WAIT | priv, val, at ? (long)&to : 0);
+       if (r == ETIMEDOUT) return r;
+       return 0;
 }