aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/rcu/srcu.c
diff options
context:
space:
mode:
authorShaibal Dutta <shaibal.dutta@broadcom.com>2014-01-31 14:53:06 -0500
committerPaul E. McKenney <paulmck@linux.vnet.ibm.com>2014-02-17 18:02:14 -0500
commitae1670339c95c3ff96ab10582506cf827c5fecc8 (patch)
tree65f8d452bd742cf8942abdfb1a427ab20310dd81 /kernel/rcu/srcu.c
parent52e2bb958ac4f9b3c4bdd78606d279852fd72922 (diff)
rcu: Move SRCU grace period work to power efficient workqueue
For better use of CPU idle time, allow the scheduler to select the CPU on which the SRCU grace period work would be scheduled. This improves idle residency time and conserves power. This functionality is enabled when CONFIG_WQ_POWER_EFFICIENT is selected. Cc: Lai Jiangshan <laijs@cn.fujitsu.com> Cc: "Paul E. McKenney" <paulmck@linux.vnet.ibm.com> Cc: Dipankar Sarma <dipankar@in.ibm.com> Signed-off-by: Shaibal Dutta <shaibal.dutta@broadcom.com> [zoran.markovic@linaro.org: Rebased to latest kernel version. Added commit message. Fixed code alignment.] Signed-off-by: Zoran Markovic <zoran.markovic@linaro.org> Signed-off-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com> Reviewed-by: Josh Triplett <josh@joshtriplett.org>
Diffstat (limited to 'kernel/rcu/srcu.c')
-rw-r--r--kernel/rcu/srcu.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/kernel/rcu/srcu.c b/kernel/rcu/srcu.c
index 5db7e9272d37..2359779e1daa 100644
--- a/kernel/rcu/srcu.c
+++ b/kernel/rcu/srcu.c
@@ -398,7 +398,7 @@ void call_srcu(struct srcu_struct *sp, struct rcu_head *head,
398 rcu_batch_queue(&sp->batch_queue, head); 398 rcu_batch_queue(&sp->batch_queue, head);
399 if (!sp->running) { 399 if (!sp->running) {
400 sp->running = true; 400 sp->running = true;
401 schedule_delayed_work(&sp->work, 0); 401 queue_delayed_work(system_power_efficient_wq, &sp->work, 0);
402 } 402 }
403 spin_unlock_irqrestore(&sp->queue_lock, flags); 403 spin_unlock_irqrestore(&sp->queue_lock, flags);
404} 404}
@@ -674,7 +674,8 @@ static void srcu_reschedule(struct srcu_struct *sp)
674 } 674 }
675 675
676 if (pending) 676 if (pending)
677 schedule_delayed_work(&sp->work, SRCU_INTERVAL); 677 queue_delayed_work(system_power_efficient_wq,
678 &sp->work, SRCU_INTERVAL);
678} 679}
679 680
680/* 681/*