X-Git-Url: https://git.liburcu.org/?p=urcu.git;a=blobdiff_plain;f=urcu%2Fstatic%2Furcu-qsbr.h;h=8d5fd03107373b5cee0d51273624da5c05552bdb;hp=143d75a7e1e047f0ec2f81709f3ca39175debdab;hb=67ecffc0f530a7b5c4dd5111ea7dd3213da8eb91;hpb=b0a841b4ff807dd29fe0cdbfe24900312f0e627b diff --git a/urcu/static/urcu-qsbr.h b/urcu/static/urcu-qsbr.h index 143d75a..8d5fd03 100644 --- a/urcu/static/urcu-qsbr.h +++ b/urcu/static/urcu-qsbr.h @@ -31,7 +31,6 @@ #include #include -#include #include #include #include @@ -43,10 +42,11 @@ #include #include #include +#include #ifdef __cplusplus extern "C" { -#endif +#endif /* * This code section can only be included in LGPL 2.1 compatible source code. @@ -56,12 +56,6 @@ extern "C" { * This is required to permit relinking with newer versions of the library. */ -#ifdef DEBUG_RCU -#define rcu_assert(args...) assert(args) -#else -#define rcu_assert(args...) -#endif - enum rcu_state { RCU_READER_ACTIVE_CURRENT, RCU_READER_ACTIVE_OLD, @@ -91,6 +85,8 @@ struct rcu_reader { struct cds_list_head node __attribute__((aligned(CAA_CACHE_LINE_SIZE))); int waiting; pthread_t tid; + /* Reader registered flag, for internal checks. */ + unsigned int registered:1; }; extern DECLARE_URCU_TLS(struct rcu_reader, rcu_reader); @@ -137,7 +133,7 @@ static inline enum rcu_state rcu_reader_state(unsigned long *ctr) */ static inline void _rcu_read_lock(void) { - rcu_assert(URCU_TLS(rcu_reader).ctr); + urcu_assert(URCU_TLS(rcu_reader).ctr); } /* @@ -149,6 +145,7 @@ static inline void _rcu_read_lock(void) */ static inline void _rcu_read_unlock(void) { + urcu_assert(URCU_TLS(rcu_reader).ctr); } /* @@ -197,6 +194,7 @@ static inline void _rcu_quiescent_state(void) { unsigned long gp_ctr; + urcu_assert(URCU_TLS(rcu_reader).registered); if ((gp_ctr = CMM_LOAD_SHARED(rcu_gp.ctr)) == URCU_TLS(rcu_reader).ctr) return; _rcu_quiescent_state_update_and_wakeup(gp_ctr); @@ -212,6 +210,7 @@ static inline void _rcu_quiescent_state(void) */ static inline void _rcu_thread_offline(void) { + urcu_assert(URCU_TLS(rcu_reader).registered); cmm_smp_mb(); CMM_STORE_SHARED(URCU_TLS(rcu_reader).ctr, 0); cmm_smp_mb(); /* write URCU_TLS(rcu_reader).ctr before read futex */ @@ -229,12 +228,13 @@ static inline void _rcu_thread_offline(void) */ static inline void _rcu_thread_online(void) { + urcu_assert(URCU_TLS(rcu_reader).registered); cmm_barrier(); /* Ensure the compiler does not reorder us with mutex */ _CMM_STORE_SHARED(URCU_TLS(rcu_reader).ctr, CMM_LOAD_SHARED(rcu_gp.ctr)); cmm_smp_mb(); } -#ifdef __cplusplus +#ifdef __cplusplus } #endif