Commit 7f04ac06 authored by Josh Triplett's avatar Josh Triplett Committed by Linus Torvalds

[PATCH] rcu: Add lock annotations to RCU locking primitives

Add __acquire annotations to rcu_read_lock and rcu_read_lock_bh, and add
__release annotations to rcu_read_unlock and rcu_read_unlock_bh.  This
allows sparse to detect improperly paired calls to these functions.
Signed-off-by: default avatarJosh Triplett <josh@freedesktop.org>
Acked-by: default avatarPaul E. McKenney <paulmck@us.ibm.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 7adc28ae
...@@ -163,14 +163,22 @@ extern int rcu_needs_cpu(int cpu); ...@@ -163,14 +163,22 @@ extern int rcu_needs_cpu(int cpu);
* *
* It is illegal to block while in an RCU read-side critical section. * It is illegal to block while in an RCU read-side critical section.
*/ */
#define rcu_read_lock() preempt_disable() #define rcu_read_lock() \
do { \
preempt_disable(); \
__acquire(RCU); \
} while(0)
/** /**
* rcu_read_unlock - marks the end of an RCU read-side critical section. * rcu_read_unlock - marks the end of an RCU read-side critical section.
* *
* See rcu_read_lock() for more information. * See rcu_read_lock() for more information.
*/ */
#define rcu_read_unlock() preempt_enable() #define rcu_read_unlock() \
do { \
__release(RCU); \
preempt_enable(); \
} while(0)
/* /*
* So where is rcu_write_lock()? It does not exist, as there is no * So where is rcu_write_lock()? It does not exist, as there is no
...@@ -193,14 +201,22 @@ extern int rcu_needs_cpu(int cpu); ...@@ -193,14 +201,22 @@ extern int rcu_needs_cpu(int cpu);
* can use just rcu_read_lock(). * can use just rcu_read_lock().
* *
*/ */
#define rcu_read_lock_bh() local_bh_disable() #define rcu_read_lock_bh() \
do { \
local_bh_disable(); \
__acquire(RCU_BH); \
} while(0)
/* /*
* rcu_read_unlock_bh - marks the end of a softirq-only RCU critical section * rcu_read_unlock_bh - marks the end of a softirq-only RCU critical section
* *
* See rcu_read_lock_bh() for more information. * See rcu_read_lock_bh() for more information.
*/ */
#define rcu_read_unlock_bh() local_bh_enable() #define rcu_read_unlock_bh() \
do { \
__release(RCU_BH); \
local_bh_enable(); \
} while(0)
/** /**
* rcu_dereference - fetch an RCU-protected pointer in an * rcu_dereference - fetch an RCU-protected pointer in an
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment