rcu: Add RCU_FAST_NO_HZ tracing for idle exit
authorPaul E. McKenney <paul.mckenney@linaro.org>
Thu, 23 Feb 2012 23:58:29 +0000 (15:58 -0800)
committerPaul E. McKenney <paulmck@linux.vnet.ibm.com>
Wed, 25 Apr 2012 03:55:19 +0000 (20:55 -0700)
Traces of rcu_prep_idle events can be confusing because
rcu_cleanup_after_idle() does no tracing.  This commit therefore adds
this tracing.

Signed-off-by: Paul E. McKenney <paul.mckenney@linaro.org>
Signed-off-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
include/trace/events/rcu.h
kernel/rcutree_plugin.h

index 337099783f3735542f7418de22f9c3adc6ae39e7..aaa55e1b8c482b0297e5022f351204203ecd801c 100644 (file)
@@ -292,6 +292,7 @@ TRACE_EVENT(rcu_dyntick,
  *     "More callbacks": Still more callbacks, try again to clear them out.
  *     "Callbacks drained": All callbacks processed, off to dyntick idle!
  *     "Timer": Timer fired to cause CPU to continue processing callbacks.
+ *     "Cleanup after idle": Idle exited, timer canceled.
  */
 TRACE_EVENT(rcu_prep_idle,
 
index c023464816bede2d7e5ec6f85b47d56b959119d1..1e561ab952a3b428d1e5f7ef8fddf434b232b30d 100644 (file)
@@ -2085,6 +2085,7 @@ static void rcu_prepare_for_idle_init(int cpu)
 static void rcu_cleanup_after_idle(int cpu)
 {
        hrtimer_cancel(&per_cpu(rcu_idle_gp_timer, cpu));
+       trace_rcu_prep_idle("Cleanup after idle");
 }
 
 /*