X-Git-Url: http://git.lttng.org/?a=blobdiff_plain;f=include%2Furcu%2Ffutex.h;h=e96b6e5fc5b2422e3ace466492ce1a73391f3870;hb=d428afc44ee5aa598c8033939ae1c1ac806f1a15;hp=f720cdc0db52ed41cd391bec9b570464492a026e;hpb=3214608619eac09e9c0ab1ea9a1a36bd1b85c18d;p=userspace-rcu.git diff --git a/include/urcu/futex.h b/include/urcu/futex.h index f720cdc..e96b6e5 100644 --- a/include/urcu/futex.h +++ b/include/urcu/futex.h @@ -24,10 +24,29 @@ */ #include +#include + #include #include #include +#if (defined(__linux__) && defined(__NR_futex)) + +/* For backwards compat */ +#define CONFIG_RCU_HAVE_FUTEX 1 + +#include +#include +#include +#include + +#elif defined(__FreeBSD__) + +#include +#include + +#endif + #ifdef __cplusplus extern "C" { #endif @@ -54,12 +73,7 @@ extern int compat_futex_noasync(int32_t *uaddr, int op, int32_t val, extern int compat_futex_async(int32_t *uaddr, int op, int32_t val, const struct timespec *timeout, int32_t *uaddr2, int32_t val3); -#ifdef CONFIG_RCU_HAVE_FUTEX - -#include -#include -#include -#include +#if (defined(__linux__) && defined(__NR_futex)) static inline int futex(int32_t *uaddr, int op, int32_t val, const struct timespec *timeout, int32_t *uaddr2, int32_t val3) @@ -106,11 +120,10 @@ static inline int futex_async(int32_t *uaddr, int op, int32_t val, #elif defined(__FreeBSD__) -#include -#include - static inline int futex_async(int32_t *uaddr, int op, int32_t val, - const struct timespec *timeout, int32_t *uaddr2, int32_t val3) + const struct timespec *timeout, + int32_t *uaddr2 __attribute__((unused)), + int32_t val3 __attribute__((unused))) { int umtx_op; void *umtx_uaddr = NULL, *umtx_uaddr2 = NULL;