* [PATCH] sched: improve smpnice load balancing when load per task imbalanced
@ 2006-04-04 6:19 Peter Williams
2006-04-04 6:36 ` Ingo Molnar
0 siblings, 1 reply; 2+ messages in thread
From: Peter Williams @ 2006-04-04 6:19 UTC (permalink / raw)
To: Andrew Morton
Cc: Siddha, Suresh B, Con Kolivas, Chen, Kenneth W, Mike Galbraith,
Ingo Molnar, Nick Piggin, Linux Kernel Mailing List
[-- Attachment #1: Type: text/plain, Size: 1207 bytes --]
Problem:
2 CPU system: if the cpu-0 has two high priority and cpu-1 has one
normal priority task, how can the current code detect this imbalance
because imbalance will be always < busiest_load_per_task and max_load -
this_load will be < 2 * busiest_load_per_task and pwr_move will be <=
pwr_now.
Solution:
Modify the assessment of small imbalances to take into account the
relative sizes of busiest_load_per_task and this_load_per_task. This is
exploiting the fact that if the difference between the loads is greater
than busiest_load_per_task and busiest_load_per_task is greater than
this_load_per_task then moving busiest_load_per_task worth of load from
busiest to this will be an improvement in the distribution of weighted load.
Required patches:
sched-prevent-high-load-weight-tasks-suppressing-balancing.patch
sched-improve-stability-of-smpnice-load-balancing.patch
Note: This patch makes no change to load balancing in the case where all
tasks are nice==0.
Signed-off-by: Peter Williams <pwil3058@bigpond.com.au>
--
Peter Williams pwil3058@bigpond.net.au
"Learning, n. The kind of ignorance distinguishing the studious."
-- Ambrose Bierce
[-- Attachment #2: smpnice-handle-unbalanced-load-per-task --]
[-- Type: text/plain, Size: 1176 bytes --]
Index: MM-2.6.X/kernel/sched.c
===================================================================
--- MM-2.6.X.orig/kernel/sched.c 2006-04-04 15:18:19.000000000 +1000
+++ MM-2.6.X/kernel/sched.c 2006-04-04 15:53:48.000000000 +1000
@@ -2252,8 +2252,16 @@ find_busiest_group(struct sched_domain *
if (*imbalance < busiest_load_per_task) {
unsigned long pwr_now = 0, pwr_move = 0;
unsigned long tmp;
+ unsigned int imbn = 2;
- if (max_load - this_load >= busiest_load_per_task*2) {
+ if (this_nr_running) {
+ this_load_per_task /= this_nr_running;
+ if (busiest_load_per_task > this_load_per_task)
+ imbn = 1;
+ } else
+ this_load_per_task = SCHED_LOAD_SCALE;
+
+ if (max_load - this_load >= busiest_load_per_task * imbn) {
*imbalance = busiest_load_per_task;
return busiest;
}
@@ -2266,10 +2274,6 @@ find_busiest_group(struct sched_domain *
pwr_now += busiest->cpu_power *
min(busiest_load_per_task, max_load);
- if (this_nr_running)
- this_load_per_task /= this_nr_running;
- else
- this_load_per_task = SCHED_LOAD_SCALE;
pwr_now += this->cpu_power *
min(this_load_per_task, this_load);
pwr_now /= SCHED_LOAD_SCALE;
^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: [PATCH] sched: improve smpnice load balancing when load per task imbalanced
2006-04-04 6:19 [PATCH] sched: improve smpnice load balancing when load per task imbalanced Peter Williams
@ 2006-04-04 6:36 ` Ingo Molnar
0 siblings, 0 replies; 2+ messages in thread
From: Ingo Molnar @ 2006-04-04 6:36 UTC (permalink / raw)
To: Peter Williams
Cc: Andrew Morton, Siddha, Suresh B, Con Kolivas, Chen, Kenneth W,
Mike Galbraith, Nick Piggin, Linux Kernel Mailing List
* Peter Williams <pwil3058@bigpond.net.au> wrote:
> Problem:
>
> 2 CPU system: if the cpu-0 has two high priority and cpu-1 has one
> normal priority task, how can the current code detect this imbalance
> because imbalance will be always < busiest_load_per_task and max_load
> - this_load will be < 2 * busiest_load_per_task and pwr_move will be
> <= pwr_now.
>
> Solution:
>
> Modify the assessment of small imbalances to take into account the
> relative sizes of busiest_load_per_task and this_load_per_task. This
> is exploiting the fact that if the difference between the loads is
> greater than busiest_load_per_task and busiest_load_per_task is
> greater than this_load_per_task then moving busiest_load_per_task
> worth of load from busiest to this will be an improvement in the
> distribution of weighted load.
>
> Required patches:
>
> sched-prevent-high-load-weight-tasks-suppressing-balancing.patch
> sched-improve-stability-of-smpnice-load-balancing.patch
>
> Note: This patch makes no change to load balancing in the case where
> all tasks are nice==0.
>
> Signed-off-by: Peter Williams <pwil3058@bigpond.com.au>
Acked-by: Ingo Molnar <mingo@elte.hu>
Ingo
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2006-04-04 6:38 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2006-04-04 6:19 [PATCH] sched: improve smpnice load balancing when load per task imbalanced Peter Williams
2006-04-04 6:36 ` Ingo Molnar
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.