X-Git-Url: http://git.liburcu.org/?a=blobdiff_plain;f=urcu%2Ffutex.h;h=7f175645f2b27d22a5d6358815870a80fc84fd36;hb=74a86b59b670494562bb0fb0ed75c8514ca3ccbd;hp=26303548a2d98d57994dabc3e0ad1e162dc8941d;hpb=2b9d431f93ce4729f14e614d1c30448e720fda75;p=userspace-rcu.git diff --git a/urcu/futex.h b/urcu/futex.h index 2630354..7f17564 100644 --- a/urcu/futex.h +++ b/urcu/futex.h @@ -73,7 +73,16 @@ static inline int futex_noasync(int32_t *uaddr, int op, int32_t val, ret = futex(uaddr, op, val, timeout, uaddr2, val3); if (caa_unlikely(ret < 0 && errno == ENOSYS)) { - return compat_futex_noasync(uaddr, op, val, timeout, + /* + * The fallback on ENOSYS is the async-safe version of + * the compat futex implementation, because the + * async-safe compat implementation allows being used + * concurrently with calls to futex(). Indeed, sys_futex + * FUTEX_WAIT, on some architectures (mips and parisc), + * within a given process, spuriously return ENOSYS due + * to signal restart bugs on some kernel versions. + */ + return compat_futex_async(uaddr, op, val, timeout, uaddr2, val3); } return ret;