diff options
author | Peter Zijlstra <a.p.zijlstra@chello.nl> | 2012-04-17 09:49:36 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2012-05-09 09:00:55 -0400 |
commit | cb83b629bae0327cf9f44f096adc38d150ceb913 (patch) | |
tree | 13f7da07ee150a97c21aace57eaa817a30df9539 /arch/ia64 | |
parent | bd939f45da24e25e08a8f5c993c50b1afada0fef (diff) |
sched/numa: Rewrite the CONFIG_NUMA sched domain support
The current code groups up to 16 nodes in a level and then puts an
ALLNODES domain spanning the entire tree on top of that. This doesn't
reflect the numa topology and esp for the smaller not-fully-connected
machines out there today this might make a difference.
Therefore, build a proper numa topology based on node_distance().
Since there's no fixed numa layers anymore, the static SD_NODE_INIT
and SD_ALLNODES_INIT aren't usable anymore, the new code tries to
construct something similar and scales some values either on the
number of cpus in the domain and/or the node_distance() ratio.
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Anton Blanchard <anton@samba.org>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Chris Metcalf <cmetcalf@tilera.com>
Cc: David Howells <dhowells@redhat.com>
Cc: "David S. Miller" <davem@davemloft.net>
Cc: Fenghua Yu <fenghua.yu@intel.com>
Cc: "H. Peter Anvin" <hpa@zytor.com>
Cc: Ivan Kokshaysky <ink@jurassic.park.msu.ru>
Cc: linux-alpha@vger.kernel.org
Cc: linux-ia64@vger.kernel.org
Cc: linux-kernel@vger.kernel.org
Cc: linux-mips@linux-mips.org
Cc: linuxppc-dev@lists.ozlabs.org
Cc: linux-sh@vger.kernel.org
Cc: Matt Turner <mattst88@gmail.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Paul Mundt <lethal@linux-sh.org>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: Richard Henderson <rth@twiddle.net>
Cc: sparclinux@vger.kernel.org
Cc: Tony Luck <tony.luck@intel.com>
Cc: x86@kernel.org
Cc: Dimitri Sivanich <sivanich@sgi.com>
Cc: Greg Pearson <greg.pearson@hp.com>
Cc: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
Cc: bob.picco@oracle.com
Cc: chris.mason@oracle.com
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Andrew Morton <akpm@linux-foundation.org>
Link: http://lkml.kernel.org/n/tip-r74n3n8hhuc2ynbrnp3vt954@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'arch/ia64')
-rw-r--r-- | arch/ia64/include/asm/topology.h | 25 |
1 files changed, 0 insertions, 25 deletions
diff --git a/arch/ia64/include/asm/topology.h b/arch/ia64/include/asm/topology.h index 09f646753d1a..a2496e449b75 100644 --- a/arch/ia64/include/asm/topology.h +++ b/arch/ia64/include/asm/topology.h | |||
@@ -70,31 +70,6 @@ void build_cpu_to_node_map(void); | |||
70 | .nr_balance_failed = 0, \ | 70 | .nr_balance_failed = 0, \ |
71 | } | 71 | } |
72 | 72 | ||
73 | /* sched_domains SD_NODE_INIT for IA64 NUMA machines */ | ||
74 | #define SD_NODE_INIT (struct sched_domain) { \ | ||
75 | .parent = NULL, \ | ||
76 | .child = NULL, \ | ||
77 | .groups = NULL, \ | ||
78 | .min_interval = 8, \ | ||
79 | .max_interval = 8*(min(num_online_cpus(), 32U)), \ | ||
80 | .busy_factor = 64, \ | ||
81 | .imbalance_pct = 125, \ | ||
82 | .cache_nice_tries = 2, \ | ||
83 | .busy_idx = 3, \ | ||
84 | .idle_idx = 2, \ | ||
85 | .newidle_idx = 0, \ | ||
86 | .wake_idx = 0, \ | ||
87 | .forkexec_idx = 0, \ | ||
88 | .flags = SD_LOAD_BALANCE \ | ||
89 | | SD_BALANCE_NEWIDLE \ | ||
90 | | SD_BALANCE_EXEC \ | ||
91 | | SD_BALANCE_FORK \ | ||
92 | | SD_SERIALIZE, \ | ||
93 | .last_balance = jiffies, \ | ||
94 | .balance_interval = 64, \ | ||
95 | .nr_balance_failed = 0, \ | ||
96 | } | ||
97 | |||
98 | #endif /* CONFIG_NUMA */ | 73 | #endif /* CONFIG_NUMA */ |
99 | 74 | ||
100 | #ifdef CONFIG_SMP | 75 | #ifdef CONFIG_SMP |