aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/rcutiny.c
diff options
context:
space:
mode:
authorPaul E. McKenney <paul.mckenney@linaro.org>2012-02-02 18:42:04 -0500
committerPaul E. McKenney <paulmck@linux.vnet.ibm.com>2012-02-21 12:06:13 -0500
commit8a2ecf474d3ee8dd5d001490349e422cec52f39f (patch)
treeaa706d632a059dd10d9305cc6abbea5889a839d9 /kernel/rcutiny.c
parent29e37d814188ac8d60f2120583704d3ef6d634b4 (diff)
rcu: Add RCU_NONIDLE() for idle-loop RCU read-side critical sections
RCU, RCU-bh, and RCU-sched read-side critical sections are forbidden in the inner idle loop, that is, between the rcu_idle_enter() and the rcu_idle_exit() -- RCU will happily ignore any such read-side critical sections. However, things like powertop need tracepoints in the inner idle loop. This commit therefore provides an RCU_NONIDLE() macro that can be used to wrap code in the idle loop that requires RCU read-side critical sections. Suggested-by: Steven Rostedt <rostedt@goodmis.org> Signed-off-by: Paul E. McKenney <paul.mckenney@linaro.org> Signed-off-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com> Reviewed-by: Josh Triplett <josh@joshtriplett.org> Acked-by: Deepthi Dharwar <deepthi@linux.vnet.ibm.com>
Diffstat (limited to 'kernel/rcutiny.c')
-rw-r--r--kernel/rcutiny.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/kernel/rcutiny.c b/kernel/rcutiny.c
index c8b0e1582c04..37a5444204d2 100644
--- a/kernel/rcutiny.c
+++ b/kernel/rcutiny.c
@@ -97,6 +97,7 @@ void rcu_idle_enter(void)
97 rcu_idle_enter_common(oldval); 97 rcu_idle_enter_common(oldval);
98 local_irq_restore(flags); 98 local_irq_restore(flags);
99} 99}
100EXPORT_SYMBOL_GPL(rcu_idle_enter);
100 101
101/* 102/*
102 * Exit an interrupt handler towards idle. 103 * Exit an interrupt handler towards idle.
@@ -153,6 +154,7 @@ void rcu_idle_exit(void)
153 rcu_idle_exit_common(oldval); 154 rcu_idle_exit_common(oldval);
154 local_irq_restore(flags); 155 local_irq_restore(flags);
155} 156}
157EXPORT_SYMBOL_GPL(rcu_idle_exit);
156 158
157/* 159/*
158 * Enter an interrupt handler, moving away from idle. 160 * Enter an interrupt handler, moving away from idle.