aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--kernel/sched.c55
1 files changed, 43 insertions, 12 deletions
diff --git a/kernel/sched.c b/kernel/sched.c
index 7b389c74f8ff..6aec1e7a72a3 100644
--- a/kernel/sched.c
+++ b/kernel/sched.c
@@ -3189,6 +3189,43 @@ static int move_one_task(struct rq *this_rq, int this_cpu, struct rq *busiest,
3189 3189
3190 return 0; 3190 return 0;
3191} 3191}
3192/********** Helpers for find_busiest_group ************************/
3193
3194/**
3195 * group_first_cpu - Returns the first cpu in the cpumask of a sched_group.
3196 * @group: The group whose first cpu is to be returned.
3197 */
3198static inline unsigned int group_first_cpu(struct sched_group *group)
3199{
3200 return cpumask_first(sched_group_cpus(group));
3201}
3202
3203/**
3204 * get_sd_load_idx - Obtain the load index for a given sched domain.
3205 * @sd: The sched_domain whose load_idx is to be obtained.
3206 * @idle: The Idle status of the CPU for whose sd load_icx is obtained.
3207 */
3208static inline int get_sd_load_idx(struct sched_domain *sd,
3209 enum cpu_idle_type idle)
3210{
3211 int load_idx;
3212
3213 switch (idle) {
3214 case CPU_NOT_IDLE:
3215 load_idx = sd->busy_idx;
3216 break;
3217
3218 case CPU_NEWLY_IDLE:
3219 load_idx = sd->newidle_idx;
3220 break;
3221 default:
3222 load_idx = sd->idle_idx;
3223 break;
3224 }
3225
3226 return load_idx;
3227}
3228/******* find_busiest_group() helpers end here *********************/
3192 3229
3193/* 3230/*
3194 * find_busiest_group finds and returns the busiest CPU group within the 3231 * find_busiest_group finds and returns the busiest CPU group within the
@@ -3217,12 +3254,7 @@ find_busiest_group(struct sched_domain *sd, int this_cpu,
3217 busiest_load_per_task = busiest_nr_running = 0; 3254 busiest_load_per_task = busiest_nr_running = 0;
3218 this_load_per_task = this_nr_running = 0; 3255 this_load_per_task = this_nr_running = 0;
3219 3256
3220 if (idle == CPU_NOT_IDLE) 3257 load_idx = get_sd_load_idx(sd, idle);
3221 load_idx = sd->busy_idx;
3222 else if (idle == CPU_NEWLY_IDLE)
3223 load_idx = sd->newidle_idx;
3224 else
3225 load_idx = sd->idle_idx;
3226 3258
3227 do { 3259 do {
3228 unsigned long load, group_capacity, max_cpu_load, min_cpu_load; 3260 unsigned long load, group_capacity, max_cpu_load, min_cpu_load;
@@ -3238,7 +3270,7 @@ find_busiest_group(struct sched_domain *sd, int this_cpu,
3238 sched_group_cpus(group)); 3270 sched_group_cpus(group));
3239 3271
3240 if (local_group) 3272 if (local_group)
3241 balance_cpu = cpumask_first(sched_group_cpus(group)); 3273 balance_cpu = group_first_cpu(group);
3242 3274
3243 /* Tally up the load of all CPUs in the group */ 3275 /* Tally up the load of all CPUs in the group */
3244 sum_weighted_load = sum_nr_running = avg_load = 0; 3276 sum_weighted_load = sum_nr_running = avg_load = 0;
@@ -3359,8 +3391,7 @@ find_busiest_group(struct sched_domain *sd, int this_cpu,
3359 */ 3391 */
3360 if ((sum_nr_running < min_nr_running) || 3392 if ((sum_nr_running < min_nr_running) ||
3361 (sum_nr_running == min_nr_running && 3393 (sum_nr_running == min_nr_running &&
3362 cpumask_first(sched_group_cpus(group)) > 3394 group_first_cpu(group) > group_first_cpu(group_min))) {
3363 cpumask_first(sched_group_cpus(group_min)))) {
3364 group_min = group; 3395 group_min = group;
3365 min_nr_running = sum_nr_running; 3396 min_nr_running = sum_nr_running;
3366 min_load_per_task = sum_weighted_load / 3397 min_load_per_task = sum_weighted_load /
@@ -3375,8 +3406,8 @@ find_busiest_group(struct sched_domain *sd, int this_cpu,
3375 if (sum_nr_running <= group_capacity - 1) { 3406 if (sum_nr_running <= group_capacity - 1) {
3376 if (sum_nr_running > leader_nr_running || 3407 if (sum_nr_running > leader_nr_running ||
3377 (sum_nr_running == leader_nr_running && 3408 (sum_nr_running == leader_nr_running &&
3378 cpumask_first(sched_group_cpus(group)) < 3409 group_first_cpu(group) <
3379 cpumask_first(sched_group_cpus(group_leader)))) { 3410 group_first_cpu(group_leader))) {
3380 group_leader = group; 3411 group_leader = group;
3381 leader_nr_running = sum_nr_running; 3412 leader_nr_running = sum_nr_running;
3382 } 3413 }
@@ -3504,7 +3535,7 @@ out_balanced:
3504 *imbalance = min_load_per_task; 3535 *imbalance = min_load_per_task;
3505 if (sched_mc_power_savings >= POWERSAVINGS_BALANCE_WAKEUP) { 3536 if (sched_mc_power_savings >= POWERSAVINGS_BALANCE_WAKEUP) {
3506 cpu_rq(this_cpu)->rd->sched_mc_preferred_wakeup_cpu = 3537 cpu_rq(this_cpu)->rd->sched_mc_preferred_wakeup_cpu =
3507 cpumask_first(sched_group_cpus(group_leader)); 3538 group_first_cpu(group_leader);
3508 } 3539 }
3509 return group_min; 3540 return group_min;
3510 } 3541 }