diff options
author | Peter Zijlstra <a.p.zijlstra@chello.nl> | 2009-09-10 07:50:02 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-09-15 10:01:05 -0400 |
commit | c88d5910890ad35af283344417891344604f0438 (patch) | |
tree | 4e2025d569c3e03a7ec5163f0a9bc159114ee14e /arch | |
parent | e9c8431185d6c406887190519f6dbdd112641686 (diff) |
sched: Merge select_task_rq_fair() and sched_balance_self()
The problem with wake_idle() is that is doesn't respect things like
cpu_power, which means it doesn't deal well with SMT nor the recent
RT interaction.
To cure this, it needs to do what sched_balance_self() does, which
leads to the possibility of merging select_task_rq_fair() and
sched_balance_self().
Modify sched_balance_self() to:
- update_shares() when walking up the domain tree,
(it only called it for the top domain, but it should
have done this anyway), which allows us to remove
this ugly bit from try_to_wake_up().
- do wake_affine() on the smallest domain that contains
both this (the waking) and the prev (the wakee) cpu for
WAKE invocations.
Then use the top-down balance steps it had to replace wake_idle().
This leads to the dissapearance of SD_WAKE_BALANCE and
SD_WAKE_IDLE_FAR, with SD_WAKE_IDLE replaced with SD_BALANCE_WAKE.
SD_WAKE_AFFINE needs SD_BALANCE_WAKE to be effective.
Touch all topology bits to replace the old with new SD flags --
platforms might need re-tuning, enabling SD_BALANCE_WAKE
conditionally on a NUMA distance seems like a good additional
feature, magny-core and small nehalem systems would want this
enabled, systems with slow interconnects would not.
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
LKML-Reference: <new-submission>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/ia64/include/asm/topology.h | 5 | ||||
-rw-r--r-- | arch/mips/include/asm/mach-ip27/topology.h | 2 | ||||
-rw-r--r-- | arch/powerpc/include/asm/topology.h | 5 | ||||
-rw-r--r-- | arch/sh/include/asm/topology.h | 4 | ||||
-rw-r--r-- | arch/sparc/include/asm/topology_64.h | 4 | ||||
-rw-r--r-- | arch/x86/include/asm/topology.h | 4 |
6 files changed, 11 insertions, 13 deletions
diff --git a/arch/ia64/include/asm/topology.h b/arch/ia64/include/asm/topology.h index 7b4c8c70b2d1..cf6053b226c3 100644 --- a/arch/ia64/include/asm/topology.h +++ b/arch/ia64/include/asm/topology.h | |||
@@ -67,6 +67,7 @@ void build_cpu_to_node_map(void); | |||
67 | .flags = SD_LOAD_BALANCE \ | 67 | .flags = SD_LOAD_BALANCE \ |
68 | | SD_BALANCE_NEWIDLE \ | 68 | | SD_BALANCE_NEWIDLE \ |
69 | | SD_BALANCE_EXEC \ | 69 | | SD_BALANCE_EXEC \ |
70 | | SD_BALANCE_WAKE \ | ||
70 | | SD_WAKE_AFFINE, \ | 71 | | SD_WAKE_AFFINE, \ |
71 | .last_balance = jiffies, \ | 72 | .last_balance = jiffies, \ |
72 | .balance_interval = 1, \ | 73 | .balance_interval = 1, \ |
@@ -91,8 +92,8 @@ void build_cpu_to_node_map(void); | |||
91 | .flags = SD_LOAD_BALANCE \ | 92 | .flags = SD_LOAD_BALANCE \ |
92 | | SD_BALANCE_EXEC \ | 93 | | SD_BALANCE_EXEC \ |
93 | | SD_BALANCE_FORK \ | 94 | | SD_BALANCE_FORK \ |
94 | | SD_SERIALIZE \ | 95 | | SD_BALANCE_WAKE \ |
95 | | SD_WAKE_BALANCE, \ | 96 | | SD_SERIALIZE, \ |
96 | .last_balance = jiffies, \ | 97 | .last_balance = jiffies, \ |
97 | .balance_interval = 64, \ | 98 | .balance_interval = 64, \ |
98 | .nr_balance_failed = 0, \ | 99 | .nr_balance_failed = 0, \ |
diff --git a/arch/mips/include/asm/mach-ip27/topology.h b/arch/mips/include/asm/mach-ip27/topology.h index 07547231e078..d8332398f5be 100644 --- a/arch/mips/include/asm/mach-ip27/topology.h +++ b/arch/mips/include/asm/mach-ip27/topology.h | |||
@@ -48,7 +48,7 @@ extern unsigned char __node_distances[MAX_COMPACT_NODES][MAX_COMPACT_NODES]; | |||
48 | .cache_nice_tries = 1, \ | 48 | .cache_nice_tries = 1, \ |
49 | .flags = SD_LOAD_BALANCE \ | 49 | .flags = SD_LOAD_BALANCE \ |
50 | | SD_BALANCE_EXEC \ | 50 | | SD_BALANCE_EXEC \ |
51 | | SD_WAKE_BALANCE, \ | 51 | | SD_BALANCE_WAKE, \ |
52 | .last_balance = jiffies, \ | 52 | .last_balance = jiffies, \ |
53 | .balance_interval = 1, \ | 53 | .balance_interval = 1, \ |
54 | .nr_balance_failed = 0, \ | 54 | .nr_balance_failed = 0, \ |
diff --git a/arch/powerpc/include/asm/topology.h b/arch/powerpc/include/asm/topology.h index 054a16d68082..c6343313ff59 100644 --- a/arch/powerpc/include/asm/topology.h +++ b/arch/powerpc/include/asm/topology.h | |||
@@ -62,9 +62,8 @@ static inline int pcibus_to_node(struct pci_bus *bus) | |||
62 | .flags = SD_LOAD_BALANCE \ | 62 | .flags = SD_LOAD_BALANCE \ |
63 | | SD_BALANCE_EXEC \ | 63 | | SD_BALANCE_EXEC \ |
64 | | SD_BALANCE_NEWIDLE \ | 64 | | SD_BALANCE_NEWIDLE \ |
65 | | SD_WAKE_IDLE \ | 65 | | SD_BALANCE_WAKE \ |
66 | | SD_SERIALIZE \ | 66 | | SD_SERIALIZE, \ |
67 | | SD_WAKE_BALANCE, \ | ||
68 | .last_balance = jiffies, \ | 67 | .last_balance = jiffies, \ |
69 | .balance_interval = 1, \ | 68 | .balance_interval = 1, \ |
70 | .nr_balance_failed = 0, \ | 69 | .nr_balance_failed = 0, \ |
diff --git a/arch/sh/include/asm/topology.h b/arch/sh/include/asm/topology.h index b69ee850906d..dc1531e2f25f 100644 --- a/arch/sh/include/asm/topology.h +++ b/arch/sh/include/asm/topology.h | |||
@@ -21,8 +21,8 @@ | |||
21 | .flags = SD_LOAD_BALANCE \ | 21 | .flags = SD_LOAD_BALANCE \ |
22 | | SD_BALANCE_FORK \ | 22 | | SD_BALANCE_FORK \ |
23 | | SD_BALANCE_EXEC \ | 23 | | SD_BALANCE_EXEC \ |
24 | | SD_SERIALIZE \ | 24 | | SD_BALANCE_WAKE \ |
25 | | SD_WAKE_BALANCE, \ | 25 | | SD_SERIALIZE, \ |
26 | .last_balance = jiffies, \ | 26 | .last_balance = jiffies, \ |
27 | .balance_interval = 1, \ | 27 | .balance_interval = 1, \ |
28 | .nr_balance_failed = 0, \ | 28 | .nr_balance_failed = 0, \ |
diff --git a/arch/sparc/include/asm/topology_64.h b/arch/sparc/include/asm/topology_64.h index e5ea8d332421..1d091abd2d13 100644 --- a/arch/sparc/include/asm/topology_64.h +++ b/arch/sparc/include/asm/topology_64.h | |||
@@ -57,8 +57,8 @@ static inline int pcibus_to_node(struct pci_bus *pbus) | |||
57 | .flags = SD_LOAD_BALANCE \ | 57 | .flags = SD_LOAD_BALANCE \ |
58 | | SD_BALANCE_FORK \ | 58 | | SD_BALANCE_FORK \ |
59 | | SD_BALANCE_EXEC \ | 59 | | SD_BALANCE_EXEC \ |
60 | | SD_SERIALIZE \ | 60 | | SD_BALANCE_WAKE \ |
61 | | SD_WAKE_BALANCE, \ | 61 | | SD_SERIALIZE, \ |
62 | .last_balance = jiffies, \ | 62 | .last_balance = jiffies, \ |
63 | .balance_interval = 1, \ | 63 | .balance_interval = 1, \ |
64 | } | 64 | } |
diff --git a/arch/x86/include/asm/topology.h b/arch/x86/include/asm/topology.h index 26d06e052a18..966d58dc6274 100644 --- a/arch/x86/include/asm/topology.h +++ b/arch/x86/include/asm/topology.h | |||
@@ -145,14 +145,12 @@ extern unsigned long node_remap_size[]; | |||
145 | | 1*SD_BALANCE_NEWIDLE \ | 145 | | 1*SD_BALANCE_NEWIDLE \ |
146 | | 1*SD_BALANCE_EXEC \ | 146 | | 1*SD_BALANCE_EXEC \ |
147 | | 1*SD_BALANCE_FORK \ | 147 | | 1*SD_BALANCE_FORK \ |
148 | | 0*SD_WAKE_IDLE \ | 148 | | 1*SD_BALANCE_WAKE \ |
149 | | 1*SD_WAKE_AFFINE \ | 149 | | 1*SD_WAKE_AFFINE \ |
150 | | 1*SD_WAKE_BALANCE \ | ||
151 | | 0*SD_SHARE_CPUPOWER \ | 150 | | 0*SD_SHARE_CPUPOWER \ |
152 | | 0*SD_POWERSAVINGS_BALANCE \ | 151 | | 0*SD_POWERSAVINGS_BALANCE \ |
153 | | 0*SD_SHARE_PKG_RESOURCES \ | 152 | | 0*SD_SHARE_PKG_RESOURCES \ |
154 | | 1*SD_SERIALIZE \ | 153 | | 1*SD_SERIALIZE \ |
155 | | 1*SD_WAKE_IDLE_FAR \ | ||
156 | | 0*SD_PREFER_SIBLING \ | 154 | | 0*SD_PREFER_SIBLING \ |
157 | , \ | 155 | , \ |
158 | .last_balance = jiffies, \ | 156 | .last_balance = jiffies, \ |