X-Git-Url: https://git.liburcu.org/?a=blobdiff_plain;ds=sidebyside;f=urcu-bp-static.h;h=394476b232d5aff5e52aeb1c283627e1249c1f4a;hb=5481ddb381061bda64aebc039900d21cac6a6caf;hp=dabf4c30a00cc30dd93ee688eb1364913d8f3b26;hpb=18c3778a6e548f0926cada96db00f8da7cc81454;p=urcu.git diff --git a/urcu-bp-static.h b/urcu-bp-static.h index dabf4c3..394476b 100644 --- a/urcu-bp-static.h +++ b/urcu-bp-static.h @@ -9,7 +9,7 @@ * TO BE INCLUDED ONLY IN LGPL-COMPATIBLE CODE. See urcu.h for linking * dynamically with the userspace rcu library. * - * Copyright (c) 2009 Mathieu Desnoyers + * Copyright (c) 2009 Mathieu Desnoyers * Copyright (c) 2009 Paul E. McKenney, IBM Corporation. * * This library is free software; you can redistribute it and/or @@ -175,6 +175,7 @@ static inline void _rcu_read_lock(void) if (unlikely(!rcu_reader)) rcu_bp_register(); + cmm_barrier(); /* Ensure the compiler does not reorder us with mutex */ tmp = rcu_reader->ctr; /* * rcu_gp_ctr is @@ -186,7 +187,7 @@ static inline void _rcu_read_lock(void) * Set active readers count for outermost nesting level before * accessing the pointer. */ - smp_mb(); + cmm_smp_mb(); } else { _STORE_SHARED(rcu_reader->ctr, tmp + RCU_GP_COUNT); } @@ -197,8 +198,9 @@ static inline void _rcu_read_unlock(void) /* * Finish using rcu before decrementing the pointer. */ - smp_mb(); + cmm_smp_mb(); _STORE_SHARED(rcu_reader->ctr, rcu_reader->ctr - RCU_GP_COUNT); + cmm_barrier(); /* Ensure the compiler does not reorder us with mutex */ } #ifdef __cplusplus