X-Git-Url: http://git.lttng.org./?a=blobdiff_plain;f=urcu%2Fstatic%2Furcu.h;h=f2293bca5054db275cd52e413a2e954ecd60af86;hb=8ddd797049f1137f54eb1e2924ee2c91047ab8a8;hp=18e4826a5a31789c7cb408832421cbddb7d83c22;hpb=af7c2dbeac32c663b64ad05e4eca70e18784463b;p=userspace-rcu.git diff --git a/urcu/static/urcu.h b/urcu/static/urcu.h index 18e4826..f2293bc 100644 --- a/urcu/static/urcu.h +++ b/urcu/static/urcu.h @@ -31,28 +31,31 @@ #include #include -#include #include +#include #include #include #include -#include +#include #include -#include +#include #ifdef __cplusplus extern "C" { #endif -/* Default is RCU_MEMBARRIER */ +/* Default is RCU_MEMBARRIER on linux */ #if !defined(RCU_MEMBARRIER) && !defined(RCU_MB) && !defined(RCU_SIGNAL) -#define RCU_MEMBARRIER +# ifdef __linux__ +# define RCU_MEMBARRIER +# else +# define RCU_MB +# endif #endif #ifdef RCU_MEMBARRIER -#include -#include +#include /* If the headers do not support SYS_membarrier, statically use RCU_MB */ #ifdef SYS_membarrier @@ -143,7 +146,7 @@ static inline void debug_yield_write(void) static inline void debug_yield_init(void) { - rand_yield = time(NULL) ^ pthread_self(); + rand_yield = time(NULL) ^ (unsigned long) pthread_self(); } #else static inline void debug_yield_read(void) @@ -228,7 +231,7 @@ struct rcu_reader { extern struct rcu_reader __thread rcu_reader; -extern int gp_futex; +extern int32_t gp_futex; /* * Wake-up waiting synchronize_rcu(). Called from many concurrent threads.