Commit d5679bd1 authored by Vaidyanathan Srinivasan's avatar Vaidyanathan Srinivasan Committed by Ingo Molnar

sched: favour lower logical cpu number for sched_mc balance

Impact: change load-balancing direction to match that of irqbalanced

Just in case two groups have identical load, prefer to move load to lower
logical cpu number rather than the present logic of moving to higher logical
number.

find_busiest_group() tries to look for a group_leader that has spare capacity
to take more tasks and freeup an appropriate least loaded group.  Just in case
there is a tie and the load is equal, then the group with higher logical number
is favoured.  This conflicts with user space irqbalance daemon that will move
interrupts to lower logical number if the system utilisation is very low.
Signed-off-by: default avatarVaidyanathan Srinivasan <svaidy@linux.vnet.ibm.com>
Acked-by: default avatarBalbir Singh <balbir@linux.vnet.ibm.com>
Acked-by: default avatarPeter Zijlstra <a.p.zijlstra@chello.nl>
Signed-off-by: default avatarIngo Molnar <mingo@elte.hu>
parent afb8a9b7
...@@ -3241,7 +3241,7 @@ find_busiest_group(struct sched_domain *sd, int this_cpu, ...@@ -3241,7 +3241,7 @@ find_busiest_group(struct sched_domain *sd, int this_cpu,
*/ */
if ((sum_nr_running < min_nr_running) || if ((sum_nr_running < min_nr_running) ||
(sum_nr_running == min_nr_running && (sum_nr_running == min_nr_running &&
cpumask_first(sched_group_cpus(group)) < cpumask_first(sched_group_cpus(group)) >
cpumask_first(sched_group_cpus(group_min)))) { cpumask_first(sched_group_cpus(group_min)))) {
group_min = group; group_min = group;
min_nr_running = sum_nr_running; min_nr_running = sum_nr_running;
...@@ -3257,7 +3257,7 @@ find_busiest_group(struct sched_domain *sd, int this_cpu, ...@@ -3257,7 +3257,7 @@ find_busiest_group(struct sched_domain *sd, int this_cpu,
if (sum_nr_running <= group_capacity - 1) { if (sum_nr_running <= group_capacity - 1) {
if (sum_nr_running > leader_nr_running || if (sum_nr_running > leader_nr_running ||
(sum_nr_running == leader_nr_running && (sum_nr_running == leader_nr_running &&
cpumask_first(sched_group_cpus(group)) > cpumask_first(sched_group_cpus(group)) <
cpumask_first(sched_group_cpus(group_leader)))) { cpumask_first(sched_group_cpus(group_leader)))) {
group_leader = group; group_leader = group;
leader_nr_running = sum_nr_running; leader_nr_running = sum_nr_running;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment