Skip to content

Commit

Permalink
sched: Weaken SD_POWERSAVINGS_BALANCE
Browse files Browse the repository at this point in the history
One of the problems of power-saving balancing is that under certain
scenarios it is too slow and allows tons of real work to pile up.

Avoid this by ignoring the powersave stuff when there's real work
to be done.

Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
LKML-Reference: <new-submission>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
  • Loading branch information
Peter Zijlstra authored and Ingo Molnar committed Sep 15, 2009
1 parent c88d591 commit ae154be
Show file tree
Hide file tree
Showing 2 changed files with 38 additions and 23 deletions.
40 changes: 20 additions & 20 deletions kernel/sched.c
Original file line number Diff line number Diff line change
Expand Up @@ -1538,6 +1538,26 @@ static unsigned long target_load(int cpu, int type)
return max(rq->cpu_load[type-1], total);
}

static struct sched_group *group_of(int cpu)
{
struct sched_domain *sd = rcu_dereference(cpu_rq(cpu)->sd);

if (!sd)
return NULL;

return sd->groups;
}

static unsigned long power_of(int cpu)
{
struct sched_group *group = group_of(cpu);

if (!group)
return SCHED_LOAD_SCALE;

return group->cpu_power;
}

static int task_hot(struct task_struct *p, u64 now, struct sched_domain *sd);

static unsigned long cpu_avg_load_per_task(int cpu)
Expand Down Expand Up @@ -3982,26 +4002,6 @@ find_busiest_group(struct sched_domain *sd, int this_cpu,
return NULL;
}

static struct sched_group *group_of(int cpu)
{
struct sched_domain *sd = rcu_dereference(cpu_rq(cpu)->sd);

if (!sd)
return NULL;

return sd->groups;
}

static unsigned long power_of(int cpu)
{
struct sched_group *group = group_of(cpu);

if (!group)
return SCHED_LOAD_SCALE;

return group->cpu_power;
}

/*
* find_busiest_queue - find the busiest runqueue among the cpus in group.
*/
Expand Down
21 changes: 18 additions & 3 deletions kernel/sched_fair.c
Original file line number Diff line number Diff line change
Expand Up @@ -1333,10 +1333,25 @@ static int select_task_rq_fair(struct task_struct *p, int flag, int sync)

for_each_domain(cpu, tmp) {
/*
* If power savings logic is enabled for a domain, stop there.
* If power savings logic is enabled for a domain, see if we
* are not overloaded, if so, don't balance wider.
*/
if (tmp->flags & SD_POWERSAVINGS_BALANCE)
break;
if (tmp->flags & SD_POWERSAVINGS_BALANCE) {
unsigned long power = 0;
unsigned long nr_running = 0;
unsigned long capacity;
int i;

for_each_cpu(i, sched_domain_span(tmp)) {
power += power_of(i);
nr_running += cpu_rq(i)->cfs.nr_running;
}

capacity = DIV_ROUND_CLOSEST(power, SCHED_LOAD_SCALE);

if (nr_running/2 < capacity)
break;
}

switch (flag) {
case SD_BALANCE_WAKE:
Expand Down

0 comments on commit ae154be

Please sign in to comment.