aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/sched.c
diff options
context:
space:
mode:
authorVaidyanathan Srinivasan <svaidy@linux.vnet.ibm.com>2008-12-18 12:56:22 -0500
committerIngo Molnar <mingo@elte.hu>2008-12-19 03:21:50 -0500
commit7a09b1a27b1e5a4957e4af9951420fea02c44fba (patch)
tree8b13c8025bbf2bd8fc60e6590e54c1036709b0da /kernel/sched.c
parentd5679bd11916eba5c8ee9033003e1a5ce56ece9a (diff)
sched: nominate preferred wakeup cpu
Impact: extend load-balancing code (no change in behavior yet) When the system utilisation is low and more cpus are idle, then the process waking up from sleep should prefer to wakeup an idle cpu from semi-idle cpu package (multi core package) rather than a completely idle cpu package which would waste power. Use the sched_mc balance logic in find_busiest_group() to nominate a preferred wakeup cpu. This info can be stored in appropriate sched_domain, but updating this info in all copies of sched_domain is not practical. Hence this information is stored in root_domain struct which is one copy per partitioned sched domain. The root_domain can be accessed from each cpu's runqueue and there is one copy per partitioned sched domain. Signed-off-by: Vaidyanathan Srinivasan <svaidy@linux.vnet.ibm.com> Acked-by: Balbir Singh <balbir@linux.vnet.ibm.com> Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl> Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/sched.c')
-rw-r--r--kernel/sched.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/kernel/sched.c b/kernel/sched.c
index 94b9d11e3312..c1b8b3031eb2 100644
--- a/kernel/sched.c
+++ b/kernel/sched.c
@@ -509,6 +509,14 @@ struct root_domain {
509#ifdef CONFIG_SMP 509#ifdef CONFIG_SMP
510 struct cpupri cpupri; 510 struct cpupri cpupri;
511#endif 511#endif
512#if defined(CONFIG_SCHED_MC) || defined(CONFIG_SCHED_SMT)
513 /*
514 * Preferred wake up cpu nominated by sched_mc balance that will be
515 * used when most cpus are idle in the system indicating overall very
516 * low system utilisation. Triggered at POWERSAVINGS_BALANCE_WAKEUP(2)
517 */
518 unsigned int sched_mc_preferred_wakeup_cpu;
519#endif
512}; 520};
513 521
514/* 522/*
@@ -3384,6 +3392,10 @@ out_balanced:
3384 3392
3385 if (this == group_leader && group_leader != group_min) { 3393 if (this == group_leader && group_leader != group_min) {
3386 *imbalance = min_load_per_task; 3394 *imbalance = min_load_per_task;
3395 if (sched_mc_power_savings >= POWERSAVINGS_BALANCE_WAKEUP) {
3396 cpu_rq(this_cpu)->rd->sched_mc_preferred_wakeup_cpu =
3397 first_cpu(group_leader->cpumask);
3398 }
3387 return group_min; 3399 return group_min;
3388 } 3400 }
3389#endif 3401#endif