Commit dc7ff76e authored by Vincent Guittot's avatar Vincent Guittot Committed by Ingo Molnar

sched: Remove unused struct sched_group_capacity::capacity_orig

The 'struct sched_group_capacity::capacity_orig' field is no longer used
in the scheduler so we can remove it.
Signed-off-by: default avatarVincent Guittot <vincent.guittot@linaro.org>
Signed-off-by: default avatarPeter Zijlstra (Intel) <peterz@infradead.org>
Cc: Morten.Rasmussen@arm.com
Cc: dietmar.eggemann@arm.com
Cc: efault@gmx.de
Cc: kamalesh@linux.vnet.ibm.com
Cc: linaro-kernel@lists.linaro.org
Cc: nicolas.pitre@linaro.org
Cc: preeti@linux.vnet.ibm.com
Cc: riel@redhat.com
Link: http://lkml.kernel.org/r/1425378903-5349-1-git-send-email-vincent.guittot@linaro.orgSigned-off-by: default avatarIngo Molnar <mingo@kernel.org>
parent ea67821b
...@@ -5447,17 +5447,6 @@ static int sched_domain_debug_one(struct sched_domain *sd, int cpu, int level, ...@@ -5447,17 +5447,6 @@ static int sched_domain_debug_one(struct sched_domain *sd, int cpu, int level,
break; break;
} }
/*
* Even though we initialize ->capacity to something semi-sane,
* we leave capacity_orig unset. This allows us to detect if
* domain iteration is still funny without causing /0 traps.
*/
if (!group->sgc->capacity_orig) {
printk(KERN_CONT "\n");
printk(KERN_ERR "ERROR: domain->cpu_capacity not set\n");
break;
}
if (!cpumask_weight(sched_group_cpus(group))) { if (!cpumask_weight(sched_group_cpus(group))) {
printk(KERN_CONT "\n"); printk(KERN_CONT "\n");
printk(KERN_ERR "ERROR: empty group\n"); printk(KERN_ERR "ERROR: empty group\n");
...@@ -5941,7 +5930,6 @@ build_overlap_sched_groups(struct sched_domain *sd, int cpu) ...@@ -5941,7 +5930,6 @@ build_overlap_sched_groups(struct sched_domain *sd, int cpu)
* die on a /0 trap. * die on a /0 trap.
*/ */
sg->sgc->capacity = SCHED_CAPACITY_SCALE * cpumask_weight(sg_span); sg->sgc->capacity = SCHED_CAPACITY_SCALE * cpumask_weight(sg_span);
sg->sgc->capacity_orig = sg->sgc->capacity;
/* /*
* Make sure the first group of this domain contains the * Make sure the first group of this domain contains the
......
...@@ -6073,7 +6073,6 @@ static void update_cpu_capacity(struct sched_domain *sd, int cpu) ...@@ -6073,7 +6073,6 @@ static void update_cpu_capacity(struct sched_domain *sd, int cpu)
capacity >>= SCHED_CAPACITY_SHIFT; capacity >>= SCHED_CAPACITY_SHIFT;
cpu_rq(cpu)->cpu_capacity_orig = capacity; cpu_rq(cpu)->cpu_capacity_orig = capacity;
sdg->sgc->capacity_orig = capacity;
capacity *= scale_rt_capacity(cpu); capacity *= scale_rt_capacity(cpu);
capacity >>= SCHED_CAPACITY_SHIFT; capacity >>= SCHED_CAPACITY_SHIFT;
...@@ -6089,7 +6088,7 @@ void update_group_capacity(struct sched_domain *sd, int cpu) ...@@ -6089,7 +6088,7 @@ void update_group_capacity(struct sched_domain *sd, int cpu)
{ {
struct sched_domain *child = sd->child; struct sched_domain *child = sd->child;
struct sched_group *group, *sdg = sd->groups; struct sched_group *group, *sdg = sd->groups;
unsigned long capacity, capacity_orig; unsigned long capacity;
unsigned long interval; unsigned long interval;
interval = msecs_to_jiffies(sd->balance_interval); interval = msecs_to_jiffies(sd->balance_interval);
...@@ -6101,7 +6100,7 @@ void update_group_capacity(struct sched_domain *sd, int cpu) ...@@ -6101,7 +6100,7 @@ void update_group_capacity(struct sched_domain *sd, int cpu)
return; return;
} }
capacity_orig = capacity = 0; capacity = 0;
if (child->flags & SD_OVERLAP) { if (child->flags & SD_OVERLAP) {
/* /*
...@@ -6121,19 +6120,15 @@ void update_group_capacity(struct sched_domain *sd, int cpu) ...@@ -6121,19 +6120,15 @@ void update_group_capacity(struct sched_domain *sd, int cpu)
* Use capacity_of(), which is set irrespective of domains * Use capacity_of(), which is set irrespective of domains
* in update_cpu_capacity(). * in update_cpu_capacity().
* *
* This avoids capacity/capacity_orig from being 0 and * This avoids capacity from being 0 and
* causing divide-by-zero issues on boot. * causing divide-by-zero issues on boot.
*
* Runtime updates will correct capacity_orig.
*/ */
if (unlikely(!rq->sd)) { if (unlikely(!rq->sd)) {
capacity_orig += capacity_orig_of(cpu);
capacity += capacity_of(cpu); capacity += capacity_of(cpu);
continue; continue;
} }
sgc = rq->sd->groups->sgc; sgc = rq->sd->groups->sgc;
capacity_orig += sgc->capacity_orig;
capacity += sgc->capacity; capacity += sgc->capacity;
} }
} else { } else {
...@@ -6144,13 +6139,11 @@ void update_group_capacity(struct sched_domain *sd, int cpu) ...@@ -6144,13 +6139,11 @@ void update_group_capacity(struct sched_domain *sd, int cpu)
group = child->groups; group = child->groups;
do { do {
capacity_orig += group->sgc->capacity_orig;
capacity += group->sgc->capacity; capacity += group->sgc->capacity;
group = group->next; group = group->next;
} while (group != child->groups); } while (group != child->groups);
} }
sdg->sgc->capacity_orig = capacity_orig;
sdg->sgc->capacity = capacity; sdg->sgc->capacity = capacity;
} }
......
...@@ -826,7 +826,7 @@ struct sched_group_capacity { ...@@ -826,7 +826,7 @@ struct sched_group_capacity {
* CPU capacity of this group, SCHED_LOAD_SCALE being max capacity * CPU capacity of this group, SCHED_LOAD_SCALE being max capacity
* for a single CPU. * for a single CPU.
*/ */
unsigned int capacity, capacity_orig; unsigned int capacity;
unsigned long next_update; unsigned long next_update;
int imbalance; /* XXX unrelated to capacity but shared group state */ int imbalance; /* XXX unrelated to capacity but shared group state */
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment