Message ID | 1333570371-1389-11-git-send-email-daniel.lezcano@linaro.org |
---|---|
State | New |
Headers | show |
Daniel Lezcano <daniel.lezcano@linaro.org> writes: > With the previous changes all the states are valid, except > the last state which can be handled by decreasing the number > of states. > > Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org> > Reviewed-by: Jean Pihet <j-pihet@ti.com> > --- > arch/arm/mach-omap2/cpuidle34xx.c | 12 +++--------- > 1 files changed, 3 insertions(+), 9 deletions(-) > > diff --git a/arch/arm/mach-omap2/cpuidle34xx.c b/arch/arm/mach-omap2/cpuidle34xx.c > index 11a2c23..3f46e45 100644 > --- a/arch/arm/mach-omap2/cpuidle34xx.c > +++ b/arch/arm/mach-omap2/cpuidle34xx.c > @@ -67,7 +67,6 @@ static struct cpuidle_params cpuidle_params_table[] = { > struct omap3_idle_statedata { > u32 mpu_state; > u32 core_state; > - u8 valid; > }; > struct omap3_idle_statedata omap3_idle_data[OMAP3_NUM_STATES]; > > @@ -191,8 +190,7 @@ static int next_valid_state(struct cpuidle_device *dev, > } > > /* Check if current state is valid */ > - if ((cx->valid) && > - (cx->mpu_state >= mpu_deepest_state) && > + if ((cx->mpu_state >= mpu_deepest_state) && > (cx->core_state >= core_deepest_state)) { > return index; > } else { > @@ -216,8 +214,7 @@ static int next_valid_state(struct cpuidle_device *dev, > idx--; > for (; idx >= 0; idx--) { > cx = cpuidle_get_statedata(&dev->states_usage[idx]); > - if ((cx->valid) && > - (cx->mpu_state >= mpu_deepest_state) && > + if ((cx->mpu_state >= mpu_deepest_state) && > (cx->core_state >= core_deepest_state)) { > next_index = idx; > break; > @@ -371,7 +368,6 @@ static inline struct omap3_idle_statedata *_fill_cstate_usage( > struct omap3_idle_statedata *cx = &omap3_idle_data[idx]; > struct cpuidle_state_usage *state_usage = &dev->states_usage[idx]; > > - cx->valid = cpuidle_params_table[idx].valid; > cpuidle_set_statedata(state_usage, cx); > > return cx; > @@ -399,7 +395,6 @@ int __init omap3_idle_init(void) > > /* C1 . MPU WFI + Core active */ > cx = _fill_cstate_usage(dev, 0); > - cx->valid = 1; /* C1 is always valid */ > cx->mpu_state = PWRDM_POWER_ON; > cx->core_state = PWRDM_POWER_ON; > > @@ -436,14 +431,13 @@ int __init omap3_idle_init(void) > * We disable C7 state as a result. > */ > if (IS_PM34XX_ERRATUM(PM_SDRC_WAKEUP_ERRATUM_i583)) { > - cx->valid = 0; > + drv->state_count = OMAP3_NUM_STATES - 1; > pr_warn("%s: core off state C7 disabled due to i583\n", > __func__); I'm not too particular about this one, but it might be cleaner to just remove this check all together. This errata already has a check in next_valid_state() so strictly speaking, it's not needed here. Kevin > } > cx->mpu_state = PWRDM_POWER_OFF; > cx->core_state = PWRDM_POWER_OFF; > > - drv->state_count = OMAP3_NUM_STATES; > cpuidle_register_driver(&omap3_idle_driver); > > if (cpuidle_register_device(dev)) {
On 04/10/2012 01:13 AM, Kevin Hilman wrote: > Daniel Lezcano<daniel.lezcano@linaro.org> writes: > >> With the previous changes all the states are valid, except >> the last state which can be handled by decreasing the number >> of states. >> >> Signed-off-by: Daniel Lezcano<daniel.lezcano@linaro.org> >> Reviewed-by: Jean Pihet<j-pihet@ti.com> >> --- [ ... ] >> if (IS_PM34XX_ERRATUM(PM_SDRC_WAKEUP_ERRATUM_i583)) { >> - cx->valid = 0; >> + drv->state_count = OMAP3_NUM_STATES - 1; >> pr_warn("%s: core off state C7 disabled due to i583\n", >> __func__); > > I'm not too particular about this one, but it might be cleaner to just > remove this check all together. This errata already has a check in > next_valid_state() so strictly speaking, it's not needed here. Yes, right. Thanks for pointing this.
diff --git a/arch/arm/mach-omap2/cpuidle34xx.c b/arch/arm/mach-omap2/cpuidle34xx.c index 11a2c23..3f46e45 100644 --- a/arch/arm/mach-omap2/cpuidle34xx.c +++ b/arch/arm/mach-omap2/cpuidle34xx.c @@ -67,7 +67,6 @@ static struct cpuidle_params cpuidle_params_table[] = { struct omap3_idle_statedata { u32 mpu_state; u32 core_state; - u8 valid; }; struct omap3_idle_statedata omap3_idle_data[OMAP3_NUM_STATES]; @@ -191,8 +190,7 @@ static int next_valid_state(struct cpuidle_device *dev, } /* Check if current state is valid */ - if ((cx->valid) && - (cx->mpu_state >= mpu_deepest_state) && + if ((cx->mpu_state >= mpu_deepest_state) && (cx->core_state >= core_deepest_state)) { return index; } else { @@ -216,8 +214,7 @@ static int next_valid_state(struct cpuidle_device *dev, idx--; for (; idx >= 0; idx--) { cx = cpuidle_get_statedata(&dev->states_usage[idx]); - if ((cx->valid) && - (cx->mpu_state >= mpu_deepest_state) && + if ((cx->mpu_state >= mpu_deepest_state) && (cx->core_state >= core_deepest_state)) { next_index = idx; break; @@ -371,7 +368,6 @@ static inline struct omap3_idle_statedata *_fill_cstate_usage( struct omap3_idle_statedata *cx = &omap3_idle_data[idx]; struct cpuidle_state_usage *state_usage = &dev->states_usage[idx]; - cx->valid = cpuidle_params_table[idx].valid; cpuidle_set_statedata(state_usage, cx); return cx; @@ -399,7 +395,6 @@ int __init omap3_idle_init(void) /* C1 . MPU WFI + Core active */ cx = _fill_cstate_usage(dev, 0); - cx->valid = 1; /* C1 is always valid */ cx->mpu_state = PWRDM_POWER_ON; cx->core_state = PWRDM_POWER_ON; @@ -436,14 +431,13 @@ int __init omap3_idle_init(void) * We disable C7 state as a result. */ if (IS_PM34XX_ERRATUM(PM_SDRC_WAKEUP_ERRATUM_i583)) { - cx->valid = 0; + drv->state_count = OMAP3_NUM_STATES - 1; pr_warn("%s: core off state C7 disabled due to i583\n", __func__); } cx->mpu_state = PWRDM_POWER_OFF; cx->core_state = PWRDM_POWER_OFF; - drv->state_count = OMAP3_NUM_STATES; cpuidle_register_driver(&omap3_idle_driver); if (cpuidle_register_device(dev)) {