X-Git-Url: http://git.lttng.org./?a=blobdiff_plain;f=urcu-static.h;h=f2c452a64edd4c2aa781e5dd867276f8e2f46525;hb=25cc6d18cb2fc9964adf2c1edb53c5539e279382;hp=44bcd073710e3e98d760c667eb7aa787238bb3ff;hpb=f0708810fe66d7fdcf52903c607ed65c9fa664c7;p=urcu.git diff --git a/urcu-static.h b/urcu-static.h index 44bcd07..f2c452a 100644 --- a/urcu-static.h +++ b/urcu-static.h @@ -56,8 +56,9 @@ extern "C" { /* If the headers do not support SYS_membarrier, statically use RCU_MB */ #ifdef SYS_membarrier -# define MEMBARRIER_EXPEDITED (1 << 0) -# define MEMBARRIER_DELAYED (1 << 1) +# define MEMBARRIER_EXPEDITED (1 << 0) +# define MEMBARRIER_DELAYED (1 << 1) +# define MEMBARRIER_QUERY (1 << 16) # define membarrier(...) syscall(__NR_membarrier, __VA_ARGS__) #else # undef RCU_MEMBARRIER @@ -76,7 +77,12 @@ extern "C" { /* * The signal number used by the RCU library can be overridden with * -DSIGRCU= when compiling the library. + * Provide backward compatibility for liburcu 0.3.x SIGURCU. */ +#ifdef SIGURCU +#define SIGRCU SIGURCU +#endif + #ifndef SIGRCU #define SIGRCU SIGUSR1 #endif @@ -154,10 +160,25 @@ static inline void debug_yield_init(void) } #endif +/* + * RCU memory barrier broadcast group. Currently, only broadcast to all process + * threads is supported (group 0). + * + * Slave barriers are only guaranteed to be ordered wrt master barriers. + * + * The pair ordering is detailed as (O: ordered, X: not ordered) : + * slave master + * slave X O + * master O O + */ + +#define MB_GROUP_ALL 0 +#define RCU_MB_GROUP MB_GROUP_ALL + #ifdef RCU_MEMBARRIER extern int has_sys_membarrier; -static inline void smp_mb_light() +static inline void smp_mb_slave(int group) { if (likely(has_sys_membarrier)) barrier(); @@ -167,14 +188,14 @@ static inline void smp_mb_light() #endif #ifdef RCU_MB -static inline void smp_mb_light() +static inline void smp_mb_slave(int group) { smp_mb(); } #endif #ifdef RCU_SIGNAL -static inline void smp_mb_light() +static inline void smp_mb_slave(int group) { barrier(); } @@ -249,9 +270,9 @@ static inline void _rcu_read_lock(void) _STORE_SHARED(rcu_reader.ctr, _LOAD_SHARED(rcu_gp_ctr)); /* * Set active readers count for outermost nesting level before - * accessing the pointer. See smp_mb_heavy(). + * accessing the pointer. See smp_mb_master(). */ - smp_mb_light(); + smp_mb_slave(RCU_MB_GROUP); } else { _STORE_SHARED(rcu_reader.ctr, tmp + RCU_GP_COUNT); } @@ -264,13 +285,13 @@ static inline void _rcu_read_unlock(void) tmp = rcu_reader.ctr; /* * Finish using rcu before decrementing the pointer. - * See smp_mb_heavy(). + * See smp_mb_master(). */ if (likely((tmp & RCU_GP_CTR_NEST_MASK) == RCU_GP_COUNT)) { - smp_mb_light(); + smp_mb_slave(RCU_MB_GROUP); _STORE_SHARED(rcu_reader.ctr, rcu_reader.ctr - RCU_GP_COUNT); /* write rcu_reader.ctr before read futex */ - smp_mb_light(); + smp_mb_slave(RCU_MB_GROUP); wake_up_gp(); } else { _STORE_SHARED(rcu_reader.ctr, rcu_reader.ctr - RCU_GP_COUNT);