X-Git-Url: https://git.liburcu.org/?p=urcu.git;a=blobdiff_plain;f=include%2Furcu%2Ffutex.h;fp=include%2Furcu%2Ffutex.h;h=e96b6e5fc5b2422e3ace466492ce1a73391f3870;hp=753cf16d9e28d6c79639e915fd633175121c0315;hb=d428afc44ee5aa598c8033939ae1c1ac806f1a15;hpb=fada682f0d6e680f18e3243aa0af607dfafcbd32 diff --git a/include/urcu/futex.h b/include/urcu/futex.h index 753cf16..e96b6e5 100644 --- a/include/urcu/futex.h +++ b/include/urcu/futex.h @@ -30,6 +30,23 @@ #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 @@ -58,14 +75,6 @@ extern int compat_futex_async(int32_t *uaddr, int op, int32_t val, #if (defined(__linux__) && defined(__NR_futex)) -/* For backwards compat */ -#define CONFIG_RCU_HAVE_FUTEX 1 - -#include -#include -#include -#include - static inline int futex(int32_t *uaddr, int op, int32_t val, const struct timespec *timeout, int32_t *uaddr2, int32_t val3) { @@ -111,9 +120,6 @@ 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 __attribute__((unused)),