sched: Try to deal with low capacity, fix update_sd_power_savings_stats()
authorGautham R Shenoy <ego@in.ibm.com>
Wed, 2 Sep 2009 11:29:10 +0000 (16:59 +0530)
committerIngo Molnar <mingo@elte.hu>
Fri, 4 Sep 2009 08:09:56 +0000 (10:09 +0200)
sgs.group_capacity can now be 0, if for some reason
group->__cpu_power happens to be less than SCHED_LOAD_SCALE/2.

In that case, we need the following fix to make it work for
update_sd_power_savings_stats(). That's because both
sum_nr_running and group_capacity are unsigned longs.

Cc: Gautham R Shenoy <ego@in.ibm.com>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Andreas Herrmann <andreas.herrmann3@amd.com>
Cc: Balbir Singh <balbir@in.ibm.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
kernel/sched.c

index 5f5b359b01b85b0b52b9c93ef28d2916f45decff..e1ebf9b00f5d4af776c131f5101d5b04c1e445b5 100644 (file)
@@ -3668,7 +3668,7 @@ static inline void update_sd_power_savings_stats(struct sched_group *group,
         * capacity but still has some space to pick up some load
         * from other group and save more power
         */
-       if (sgs->sum_nr_running > sgs->group_capacity - 1)
+       if (sgs->sum_nr_running + 1 > sgs->group_capacity)
                return;
 
        if (sgs->sum_nr_running > sds->leader_nr_running ||