[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20061110143214.A25478@unix-os.sc.intel.com>
Date: Fri, 10 Nov 2006 14:32:14 -0800
From: "Siddha, Suresh B" <suresh.b.siddha@...el.com>
To: Christoph Lameter <clameter@....com>
Cc: "Chen, Kenneth W" <kenneth.w.chen@...el.com>,
Ingo Molnar <mingo@...e.hu>,
"Siddha, Suresh B" <suresh.b.siddha@...el.com>, akpm@...l.org,
mm-commits@...r.kernel.org, nickpiggin@...oo.com.au,
linux-kernel@...r.kernel.org
Subject: Re: + sched-use-tasklet-to-call-balancing.patch added to -mm tree
On Fri, Nov 10, 2006 at 10:50:13AM -0800, Christoph Lameter wrote:
> Suresh noted at the Intel OS forum yesterday that we may be able to avoid
> running load balancing of the larger sched domains from all processors.
> That would reduce the overhead of scheduling and reduce the percentage of
> time that load blancing is active even on very large systems.
I brought this up at OLS with Nick too. What happens today is, at a particular
domain, each cpu in the sched group will do a load balance at the frequency
of balance_interval. More the cores and threads, more the cpus will be
in each sched group at SMP and NUMA domain. And we endup spending
quite a bit of time doing load balancing in those domains.
One idea(old patch appended) is to make only one cpu in the sched group do
the load balance at that particular sched domain and this load will slowly
percolate down to the other cpus with in that group(when they do load balancing
at lower domains).
Nick was suggesting another alternative, that we should increase the max
interval and probably make it dependent on number of cpus that
share the group. Today for NUMA domain, we already set max_interval
based on online cpus. Perhaps we need to do that for other domains (SMP, MC)
too and increase the max interval on NUMA for big systems?
---
When busy, only the first cpu in the sched group will do the load balance.
--- linux-2.6.9/kernel/sched.c.1 2006-07-11 16:17:37.000000000 -0700
+++ linux-2.6.9/kernel/sched.c 2006-07-12 10:48:48.000000000 -0700
@@ -2329,12 +2329,15 @@
interval = 1;
if (j - sd->last_balance >= interval) {
- sd->last_balance += interval;
+ sd->last_balance = j;
if (load_balance(this_cpu, this_rq, sd, idle)) {
/* We've pulled tasks over so no longer idle */
idle = NOT_IDLE;
}
}
+
+ if (idle != IDLE && this_cpu != first_cpu(sd->span))
+ break;
}
}
#else
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists