PM / cpuidle: Make ladder governor use the "disabled" state flag
authorRafael J. Wysocki <rjw@sisk.pl>
Wed, 15 Aug 2012 18:28:52 +0000 (20:28 +0200)
committerRafael J. Wysocki <rjw@sisk.pl>
Mon, 3 Sep 2012 23:35:45 +0000 (01:35 +0200)
For the mechanism introduced by commit cbc9ef0 (PM / Domains: Add
preliminary support for cpuidle, v2) to work with the ladder
governor, that governor should respect the "disabled" state flag
added by that commit.  Change the ladder governor accordingly.

Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl>
drivers/cpuidle/governors/ladder.c

index 2aef26c520bb88e1f78e1ebd84b206c0ae6ce81f..9b784051ec12b47564b3d07429096556b2fc2035 100644 (file)
@@ -88,6 +88,7 @@ static int ladder_select_state(struct cpuidle_driver *drv,
 
        /* consider promotion */
        if (last_idx < drv->state_count - 1 &&
+           !drv->states[last_idx + 1].disabled &&
            !dev->states_usage[last_idx + 1].disable &&
            last_residency > last_state->threshold.promotion_time &&
            drv->states[last_idx + 1].exit_latency <= latency_req) {
@@ -101,7 +102,8 @@ static int ladder_select_state(struct cpuidle_driver *drv,
 
        /* consider demotion */
        if (last_idx > CPUIDLE_DRIVER_STATE_START &&
-           (dev->states_usage[last_idx].disable ||
+           (drv->states[last_idx].disabled ||
+           dev->states_usage[last_idx].disable ||
            drv->states[last_idx].exit_latency > latency_req)) {
                int i;