aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
Diffstat (limited to 'kernel')
-rw-r--r--kernel/sched.c40
1 files changed, 30 insertions, 10 deletions
diff --git a/kernel/sched.c b/kernel/sched.c
index 6d7bf55ec33d..0feeacb91497 100644
--- a/kernel/sched.c
+++ b/kernel/sched.c
@@ -1286,21 +1286,29 @@ static int sched_balance_self(int cpu, int flag)
1286 while (sd) { 1286 while (sd) {
1287 cpumask_t span; 1287 cpumask_t span;
1288 struct sched_group *group; 1288 struct sched_group *group;
1289 int new_cpu; 1289 int new_cpu, weight;
1290 int weight; 1290
1291 if (!(sd->flags & flag)) {
1292 sd = sd->child;
1293 continue;
1294 }
1291 1295
1292 span = sd->span; 1296 span = sd->span;
1293 group = find_idlest_group(sd, t, cpu); 1297 group = find_idlest_group(sd, t, cpu);
1294 if (!group) 1298 if (!group) {
1295 goto nextlevel; 1299 sd = sd->child;
1300 continue;
1301 }
1296 1302
1297 new_cpu = find_idlest_cpu(group, t, cpu); 1303 new_cpu = find_idlest_cpu(group, t, cpu);
1298 if (new_cpu == -1 || new_cpu == cpu) 1304 if (new_cpu == -1 || new_cpu == cpu) {
1299 goto nextlevel; 1305 /* Now try balancing at a lower domain level of cpu */
1306 sd = sd->child;
1307 continue;
1308 }
1300 1309
1301 /* Now try balancing at a lower domain level */ 1310 /* Now try balancing at a lower domain level of new_cpu */
1302 cpu = new_cpu; 1311 cpu = new_cpu;
1303nextlevel:
1304 sd = NULL; 1312 sd = NULL;
1305 weight = cpus_weight(span); 1313 weight = cpus_weight(span);
1306 for_each_domain(cpu, tmp) { 1314 for_each_domain(cpu, tmp) {
@@ -5448,12 +5456,18 @@ static void cpu_attach_domain(struct sched_domain *sd, int cpu)
5448 struct sched_domain *parent = tmp->parent; 5456 struct sched_domain *parent = tmp->parent;
5449 if (!parent) 5457 if (!parent)
5450 break; 5458 break;
5451 if (sd_parent_degenerate(tmp, parent)) 5459 if (sd_parent_degenerate(tmp, parent)) {
5452 tmp->parent = parent->parent; 5460 tmp->parent = parent->parent;
5461 if (parent->parent)
5462 parent->parent->child = tmp;
5463 }
5453 } 5464 }
5454 5465
5455 if (sd && sd_degenerate(sd)) 5466 if (sd && sd_degenerate(sd)) {
5456 sd = sd->parent; 5467 sd = sd->parent;
5468 if (sd)
5469 sd->child = NULL;
5470 }
5457 5471
5458 sched_domain_debug(sd, cpu); 5472 sched_domain_debug(sd, cpu);
5459 5473
@@ -6288,6 +6302,8 @@ static int build_sched_domains(const cpumask_t *cpu_map)
6288 *sd = SD_NODE_INIT; 6302 *sd = SD_NODE_INIT;
6289 sd->span = sched_domain_node_span(cpu_to_node(i)); 6303 sd->span = sched_domain_node_span(cpu_to_node(i));
6290 sd->parent = p; 6304 sd->parent = p;
6305 if (p)
6306 p->child = sd;
6291 cpus_and(sd->span, sd->span, *cpu_map); 6307 cpus_and(sd->span, sd->span, *cpu_map);
6292#endif 6308#endif
6293 6309
@@ -6297,6 +6313,8 @@ static int build_sched_domains(const cpumask_t *cpu_map)
6297 *sd = SD_CPU_INIT; 6313 *sd = SD_CPU_INIT;
6298 sd->span = nodemask; 6314 sd->span = nodemask;
6299 sd->parent = p; 6315 sd->parent = p;
6316 if (p)
6317 p->child = sd;
6300 sd->groups = &sched_group_phys[group]; 6318 sd->groups = &sched_group_phys[group];
6301 6319
6302#ifdef CONFIG_SCHED_MC 6320#ifdef CONFIG_SCHED_MC
@@ -6307,6 +6325,7 @@ static int build_sched_domains(const cpumask_t *cpu_map)
6307 sd->span = cpu_coregroup_map(i); 6325 sd->span = cpu_coregroup_map(i);
6308 cpus_and(sd->span, sd->span, *cpu_map); 6326 cpus_and(sd->span, sd->span, *cpu_map);
6309 sd->parent = p; 6327 sd->parent = p;
6328 p->child = sd;
6310 sd->groups = &sched_group_core[group]; 6329 sd->groups = &sched_group_core[group];
6311#endif 6330#endif
6312 6331
@@ -6318,6 +6337,7 @@ static int build_sched_domains(const cpumask_t *cpu_map)
6318 sd->span = cpu_sibling_map[i]; 6337 sd->span = cpu_sibling_map[i];
6319 cpus_and(sd->span, sd->span, *cpu_map); 6338 cpus_and(sd->span, sd->span, *cpu_map);
6320 sd->parent = p; 6339 sd->parent = p;
6340 p->child = sd;
6321 sd->groups = &sched_group_cpus[group]; 6341 sd->groups = &sched_group_cpus[group];
6322#endif 6342#endif
6323 } 6343 }