diff mbox

[2/2] OMAP3: PM: Configure CPUidle latencies/thresholds from board files

Message ID 1246286113-21197-2-git-send-email-rnayak@ti.com (mailing list archive)
State Changes Requested
Delegated to: Kevin Hilman
Headers show

Commit Message

Rajendra Nayak June 29, 2009, 2:35 p.m. UTC
The CPUidle C state latencies and thresholds are dependent
on various board specific details.
Hence this patch makes it possible to configure these values from the
respective board files.

Signed-off-by: Rajendra Nayak <rnayak@ti.com>
---
 arch/arm/mach-omap2/board-3430sdp.c     |   22 ++++++-
 arch/arm/mach-omap2/board-apollon.c     |    2 +-
 arch/arm/mach-omap2/board-generic.c     |    2 +-
 arch/arm/mach-omap2/board-h4.c          |    2 +-
 arch/arm/mach-omap2/board-ldp.c         |    2 +-
 arch/arm/mach-omap2/board-omap3beagle.c |    2 +-
 arch/arm/mach-omap2/board-omap3evm.c    |    2 +-
 arch/arm/mach-omap2/board-overo.c       |    3 +-
 arch/arm/mach-omap2/board-rx51.c        |    2 +-
 arch/arm/mach-omap2/board-zoom2.c       |    2 +-
 arch/arm/mach-omap2/cpuidle34xx.c       |  105 ++++++++++++++++++++++++------
 arch/arm/mach-omap2/io.c                |    5 +-
 arch/arm/mach-omap2/pm.c                |    7 ++-
 arch/arm/mach-omap2/pm.h                |   12 +++-
 arch/arm/plat-omap/include/mach/io.h    |    4 +-
 15 files changed, 136 insertions(+), 38 deletions(-)

Comments

Mike Chan June 29, 2009, 8:18 p.m. UTC | #1
On Mon, Jun 29, 2009 at 7:35 AM, Rajendra Nayak<rnayak@ti.com> wrote:
> The CPUidle C state latencies and thresholds are dependent
> on various board specific details.
> Hence this patch makes it possible to configure these values from the
> respective board files.
>
> Signed-off-by: Rajendra Nayak <rnayak@ti.com>
> ---

I think cpufreq could probably use something similar. The transition
latency set in the policy is set in cpu-omap.c and is a hard-coded
value. I wonder if its reasonable to piggyback off these values for
the transition latencies, or extend the struct to include those?

-- Mike

>  arch/arm/mach-omap2/board-3430sdp.c     |   22 ++++++-
>  arch/arm/mach-omap2/board-apollon.c     |    2 +-
>  arch/arm/mach-omap2/board-generic.c     |    2 +-
>  arch/arm/mach-omap2/board-h4.c          |    2 +-
>  arch/arm/mach-omap2/board-ldp.c         |    2 +-
>  arch/arm/mach-omap2/board-omap3beagle.c |    2 +-
>  arch/arm/mach-omap2/board-omap3evm.c    |    2 +-
>  arch/arm/mach-omap2/board-overo.c       |    3 +-
>  arch/arm/mach-omap2/board-rx51.c        |    2 +-
>  arch/arm/mach-omap2/board-zoom2.c       |    2 +-
>  arch/arm/mach-omap2/cpuidle34xx.c       |  105 ++++++++++++++++++++++++------
>  arch/arm/mach-omap2/io.c                |    5 +-
>  arch/arm/mach-omap2/pm.c                |    7 ++-
>  arch/arm/mach-omap2/pm.h                |   12 +++-
>  arch/arm/plat-omap/include/mach/io.h    |    4 +-
>  15 files changed, 136 insertions(+), 38 deletions(-)
>
> diff --git a/arch/arm/mach-omap2/board-3430sdp.c b/arch/arm/mach-omap2/board-3430sdp.c
> index b43cf94..750d841 100644
> --- a/arch/arm/mach-omap2/board-3430sdp.c
> +++ b/arch/arm/mach-omap2/board-3430sdp.c
> @@ -75,6 +75,24 @@ static struct prm_setup_vc omap3_setuptime_table = {
>        .vdd1_off = 0x00,
>  };
>
> +/* FIXME: These values need to be updated based on more profiling on 3430sdp*/
> +static struct cpuidle_params omap3_cpuidle_params_table[] = {
> +       /* C1 */
> +       {2, 2, 5},
> +       /* C2 */
> +       {10, 10, 30},
> +       /* C3 */
> +       {50, 50, 300},
> +       /* C4 */
> +       {1500, 1800, 4000},
> +       /* C5 */
> +       {2500, 7500, 12000},
> +       /* C6 */
> +       {3000, 8500, 15000},
> +       /* C7 */
> +       {10000, 30000, 300000},
> +};
> +
>  static int sdp3430_keymap[] = {
>        KEY(0, 0, KEY_LEFT),
>        KEY(0, 1, KEY_RIGHT),
> @@ -191,8 +209,8 @@ static struct platform_device *sdp3430_devices[] __initdata = {
>  static void __init omap_3430sdp_init_irq(void)
>  {
>        omap2_init_common_hw(hyb18m512160af6_sdrc_params, omap3_mpu_rate_table,
> -                            omap3_dsp_rate_table, omap3_l3_rate_table,
> -                            &omap3_setuptime_table);
> +                       omap3_dsp_rate_table, omap3_l3_rate_table,
> +                       &omap3_setuptime_table, omap3_cpuidle_params_table);
>        omap_init_irq();
>        omap_gpio_init();
>  }
> diff --git a/arch/arm/mach-omap2/board-apollon.c b/arch/arm/mach-omap2/board-apollon.c
> index 293a9b2..fe625a9 100644
> --- a/arch/arm/mach-omap2/board-apollon.c
> +++ b/arch/arm/mach-omap2/board-apollon.c
> @@ -250,7 +250,7 @@ out:
>
>  static void __init omap_apollon_init_irq(void)
>  {
> -       omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL);
> +       omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL, NULL);
>        omap_init_irq();
>        omap_gpio_init();
>        apollon_init_smc91x();
> diff --git a/arch/arm/mach-omap2/board-generic.c b/arch/arm/mach-omap2/board-generic.c
> index dfc1b49..ecf2c45 100644
> --- a/arch/arm/mach-omap2/board-generic.c
> +++ b/arch/arm/mach-omap2/board-generic.c
> @@ -33,7 +33,7 @@
>
>  static void __init omap_generic_init_irq(void)
>  {
> -       omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL);
> +       omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL, NULL);
>        omap_init_irq();
>  }
>
> diff --git a/arch/arm/mach-omap2/board-h4.c b/arch/arm/mach-omap2/board-h4.c
> index af0ebaf..365bc69 100644
> --- a/arch/arm/mach-omap2/board-h4.c
> +++ b/arch/arm/mach-omap2/board-h4.c
> @@ -270,7 +270,7 @@ static void __init h4_init_flash(void)
>
>  static void __init omap_h4_init_irq(void)
>  {
> -       omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL);
> +       omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL, NULL);
>        omap_init_irq();
>        omap_gpio_init();
>        h4_init_flash();
> diff --git a/arch/arm/mach-omap2/board-ldp.c b/arch/arm/mach-omap2/board-ldp.c
> index eb5e2e0..1265a12 100644
> --- a/arch/arm/mach-omap2/board-ldp.c
> +++ b/arch/arm/mach-omap2/board-ldp.c
> @@ -270,7 +270,7 @@ static inline void __init ldp_init_smsc911x(void)
>
>  static void __init omap_ldp_init_irq(void)
>  {
> -       omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL);
> +       omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL, NULL);
>        omap_init_irq();
>        omap_gpio_init();
>        ldp_init_smsc911x();
> diff --git a/arch/arm/mach-omap2/board-omap3beagle.c b/arch/arm/mach-omap2/board-omap3beagle.c
> index e0be6bd..da1f3f6 100644
> --- a/arch/arm/mach-omap2/board-omap3beagle.c
> +++ b/arch/arm/mach-omap2/board-omap3beagle.c
> @@ -289,7 +289,7 @@ static int __init omap3_beagle_i2c_init(void)
>  static void __init omap3_beagle_init_irq(void)
>  {
>        omap2_init_common_hw(mt46h32m32lf6_sdrc_params, omap3_mpu_rate_table,
> -                            omap3_dsp_rate_table, omap3_l3_rate_table, NULL);
> +                       omap3_dsp_rate_table, omap3_l3_rate_table, NULL, NULL);
>        omap_init_irq();
>  #ifdef CONFIG_OMAP_32K_TIMER
>        omap2_gp_clockevent_set_gptimer(12);
> diff --git a/arch/arm/mach-omap2/board-omap3evm.c b/arch/arm/mach-omap2/board-omap3evm.c
> index eaab39b..4a287b9 100644
> --- a/arch/arm/mach-omap2/board-omap3evm.c
> +++ b/arch/arm/mach-omap2/board-omap3evm.c
> @@ -284,7 +284,7 @@ struct spi_board_info omap3evm_spi_board_info[] = {
>  static void __init omap3_evm_init_irq(void)
>  {
>        omap2_init_common_hw(mt46h32m32lf6_sdrc_params, omap3_mpu_rate_table,
> -                       omap3_dsp_rate_table, omap3_l3_rate_table, NULL);
> +                       omap3_dsp_rate_table, omap3_l3_rate_table, NULL, NULL);
>        omap_init_irq();
>        omap_gpio_init();
>        omap3evm_init_smc911x();
> diff --git a/arch/arm/mach-omap2/board-overo.c b/arch/arm/mach-omap2/board-overo.c
> index f159e18..a673921 100644
> --- a/arch/arm/mach-omap2/board-overo.c
> +++ b/arch/arm/mach-omap2/board-overo.c
> @@ -360,7 +360,8 @@ static int __init overo_i2c_init(void)
>
>  static void __init overo_init_irq(void)
>  {
> -       omap2_init_common_hw(mt46h32m32lf6_sdrc_params, NULL, NULL, NULL, NULL);
> +       omap2_init_common_hw(mt46h32m32lf6_sdrc_params,
> +                                NULL, NULL, NULL, NULL, NULL);
>        omap_init_irq();
>        omap_gpio_init();
>  }
> diff --git a/arch/arm/mach-omap2/board-rx51.c b/arch/arm/mach-omap2/board-rx51.c
> index 3629a0e..6cb8715 100644
> --- a/arch/arm/mach-omap2/board-rx51.c
> +++ b/arch/arm/mach-omap2/board-rx51.c
> @@ -66,7 +66,7 @@ static struct omap_board_config_kernel rx51_config[] = {
>  static void __init rx51_init_irq(void)
>  {
>        omap2_init_common_hw(rx51_get_sdram_timings(), omap3_mpu_rate_table,
> -                            omap3_dsp_rate_table, omap3_l3_rate_table, NULL);
> +               omap3_dsp_rate_table, omap3_l3_rate_table, NULL, NULL);
>        omap_init_irq();
>        omap_gpio_init();
>  }
> diff --git a/arch/arm/mach-omap2/board-zoom2.c b/arch/arm/mach-omap2/board-zoom2.c
> index e63bfa0..0fcd0ff 100644
> --- a/arch/arm/mach-omap2/board-zoom2.c
> +++ b/arch/arm/mach-omap2/board-zoom2.c
> @@ -27,7 +27,7 @@
>  static void __init omap_zoom2_init_irq(void)
>  {
>        omap2_init_common_hw(NULL, omap3_mpu_rate_table,
> -                       omap3_dsp_rate_table, omap3_l3_rate_table, NULL);
> +                       omap3_dsp_rate_table, omap3_l3_rate_table, NULL, NULL);
>        omap_init_irq();
>        omap_gpio_init();
>  }
> diff --git a/arch/arm/mach-omap2/cpuidle34xx.c b/arch/arm/mach-omap2/cpuidle34xx.c
> index 7bbec90..3d6c55a 100644
> --- a/arch/arm/mach-omap2/cpuidle34xx.c
> +++ b/arch/arm/mach-omap2/cpuidle34xx.c
> @@ -60,6 +60,30 @@ struct omap3_processor_cx omap3_power_states[OMAP3_MAX_STATES];
>  struct omap3_processor_cx current_cx_state;
>  struct powerdomain *mpu_pd, *core_pd, *per_pd;
>
> +/*
> + * The latencies/thresholds for various C states have
> + * to be configured from the respective board files.
> + * These are some default values (which might not provide
> + * the best power savings) used on boards which do not
> + * pass these details from the board file.
> + */
> +static struct cpuidle_params cpuidle_params_table[] = {
> +       /* C1 */
> +       {2, 2, 5},
> +       /* C2 */
> +       {10, 10, 30},
> +       /* C3 */
> +       {50, 50, 300},
> +       /* C4 */
> +       {1500, 1800, 4000},
> +       /* C5 */
> +       {2500, 7500, 12000},
> +       /* C6 */
> +       {3000, 8500, 15000},
> +       /* C7 */
> +       {10000, 30000, 300000},
> +};
> +
>  static int omap3_idle_bm_check(void)
>  {
>        if (!omap3_can_sleep())
> @@ -165,6 +189,24 @@ static int omap3_enter_idle_bm(struct cpuidle_device *dev,
>
>  DEFINE_PER_CPU(struct cpuidle_device, omap3_idle_dev);
>
> +void omap3_set_idle_params(struct cpuidle_params *cpuidle_board_params)
> +{
> +       int i;
> +
> +       if (!cpuidle_board_params)
> +               return;
> +
> +       for (i = OMAP3_STATE_C1; i < OMAP3_MAX_STATES; i++) {
> +               cpuidle_params_table[i].sleep_latency =
> +                                       cpuidle_board_params[i].sleep_latency;
> +               cpuidle_params_table[i].wake_latency =
> +                                       cpuidle_board_params[i].wake_latency;
> +               cpuidle_params_table[i].threshold =
> +                                       cpuidle_board_params[i].threshold;
> +       }
> +       return;
> +}
> +
>  /* omap3_init_power_states - Initialises the OMAP3 specific C states.
>  *
>  * Below is the desciption of each C state.
> @@ -181,9 +223,12 @@ void omap_init_power_states(void)
>        /* C1 . MPU WFI + Core active */
>        omap3_power_states[OMAP3_STATE_C1].valid = 1;
>        omap3_power_states[OMAP3_STATE_C1].type = OMAP3_STATE_C1;
> -       omap3_power_states[OMAP3_STATE_C1].sleep_latency = 2;
> -       omap3_power_states[OMAP3_STATE_C1].wakeup_latency = 2;
> -       omap3_power_states[OMAP3_STATE_C1].threshold = 5;
> +       omap3_power_states[OMAP3_STATE_C1].sleep_latency =
> +                       cpuidle_params_table[OMAP3_STATE_C1].sleep_latency;
> +       omap3_power_states[OMAP3_STATE_C1].wakeup_latency =
> +                       cpuidle_params_table[OMAP3_STATE_C1].wake_latency;
> +       omap3_power_states[OMAP3_STATE_C1].threshold =
> +                       cpuidle_params_table[OMAP3_STATE_C1].threshold;
>        omap3_power_states[OMAP3_STATE_C1].mpu_state = PWRDM_POWER_ON;
>        omap3_power_states[OMAP3_STATE_C1].core_state = PWRDM_POWER_ON;
>        omap3_power_states[OMAP3_STATE_C1].flags = CPUIDLE_FLAG_TIME_VALID;
> @@ -191,9 +236,12 @@ void omap_init_power_states(void)
>        /* C2 . MPU WFI + Core inactive */
>        omap3_power_states[OMAP3_STATE_C2].valid = 1;
>        omap3_power_states[OMAP3_STATE_C2].type = OMAP3_STATE_C2;
> -       omap3_power_states[OMAP3_STATE_C2].sleep_latency = 10;
> -       omap3_power_states[OMAP3_STATE_C2].wakeup_latency = 10;
> -       omap3_power_states[OMAP3_STATE_C2].threshold = 30;
> +       omap3_power_states[OMAP3_STATE_C2].sleep_latency =
> +                       cpuidle_params_table[OMAP3_STATE_C2].sleep_latency;;
> +       omap3_power_states[OMAP3_STATE_C2].wakeup_latency =
> +                       cpuidle_params_table[OMAP3_STATE_C2].wake_latency;;
> +       omap3_power_states[OMAP3_STATE_C2].threshold =
> +                       cpuidle_params_table[OMAP3_STATE_C2].threshold;;
>        omap3_power_states[OMAP3_STATE_C2].mpu_state = PWRDM_POWER_ON;
>        omap3_power_states[OMAP3_STATE_C2].core_state = PWRDM_POWER_ON;
>        omap3_power_states[OMAP3_STATE_C2].flags = CPUIDLE_FLAG_TIME_VALID;
> @@ -201,9 +249,12 @@ void omap_init_power_states(void)
>        /* C3 . MPU CSWR + Core inactive */
>        omap3_power_states[OMAP3_STATE_C3].valid = 1;
>        omap3_power_states[OMAP3_STATE_C3].type = OMAP3_STATE_C3;
> -       omap3_power_states[OMAP3_STATE_C3].sleep_latency = 50;
> -       omap3_power_states[OMAP3_STATE_C3].wakeup_latency = 50;
> -       omap3_power_states[OMAP3_STATE_C3].threshold = 300;
> +       omap3_power_states[OMAP3_STATE_C3].sleep_latency =
> +                       cpuidle_params_table[OMAP3_STATE_C3].sleep_latency;
> +       omap3_power_states[OMAP3_STATE_C3].wakeup_latency =
> +                       cpuidle_params_table[OMAP3_STATE_C3].wake_latency;
> +       omap3_power_states[OMAP3_STATE_C3].threshold =
> +                       cpuidle_params_table[OMAP3_STATE_C3].threshold;
>        omap3_power_states[OMAP3_STATE_C3].mpu_state = PWRDM_POWER_RET;
>        omap3_power_states[OMAP3_STATE_C3].core_state = PWRDM_POWER_ON;
>        omap3_power_states[OMAP3_STATE_C3].flags = CPUIDLE_FLAG_TIME_VALID |
> @@ -212,9 +263,12 @@ void omap_init_power_states(void)
>        /* C4 . MPU OFF + Core inactive */
>        omap3_power_states[OMAP3_STATE_C4].valid = 1;
>        omap3_power_states[OMAP3_STATE_C4].type = OMAP3_STATE_C4;
> -       omap3_power_states[OMAP3_STATE_C4].sleep_latency = 1500;
> -       omap3_power_states[OMAP3_STATE_C4].wakeup_latency = 1800;
> -       omap3_power_states[OMAP3_STATE_C4].threshold = 4000;
> +       omap3_power_states[OMAP3_STATE_C4].sleep_latency =
> +                       cpuidle_params_table[OMAP3_STATE_C4].sleep_latency;
> +       omap3_power_states[OMAP3_STATE_C4].wakeup_latency =
> +                       cpuidle_params_table[OMAP3_STATE_C4].wake_latency;
> +       omap3_power_states[OMAP3_STATE_C4].threshold =
> +                       cpuidle_params_table[OMAP3_STATE_C4].threshold;
>        omap3_power_states[OMAP3_STATE_C4].mpu_state = PWRDM_POWER_OFF;
>        omap3_power_states[OMAP3_STATE_C4].core_state = PWRDM_POWER_ON;
>        omap3_power_states[OMAP3_STATE_C4].flags = CPUIDLE_FLAG_TIME_VALID |
> @@ -223,9 +277,12 @@ void omap_init_power_states(void)
>        /* C5 . MPU CSWR + Core CSWR*/
>        omap3_power_states[OMAP3_STATE_C5].valid = 1;
>        omap3_power_states[OMAP3_STATE_C5].type = OMAP3_STATE_C5;
> -       omap3_power_states[OMAP3_STATE_C5].sleep_latency = 2500;
> -       omap3_power_states[OMAP3_STATE_C5].wakeup_latency = 7500;
> -       omap3_power_states[OMAP3_STATE_C5].threshold = 12000;
> +       omap3_power_states[OMAP3_STATE_C5].sleep_latency =
> +                       cpuidle_params_table[OMAP3_STATE_C5].sleep_latency;
> +       omap3_power_states[OMAP3_STATE_C5].wakeup_latency =
> +                       cpuidle_params_table[OMAP3_STATE_C5].wake_latency;
> +       omap3_power_states[OMAP3_STATE_C5].threshold =
> +                       cpuidle_params_table[OMAP3_STATE_C5].threshold;
>        omap3_power_states[OMAP3_STATE_C5].mpu_state = PWRDM_POWER_RET;
>        omap3_power_states[OMAP3_STATE_C5].core_state = PWRDM_POWER_RET;
>        omap3_power_states[OMAP3_STATE_C5].flags = CPUIDLE_FLAG_TIME_VALID |
> @@ -234,9 +291,12 @@ void omap_init_power_states(void)
>        /* C6 . MPU OFF + Core CSWR */
>        omap3_power_states[OMAP3_STATE_C6].valid = 1;
>        omap3_power_states[OMAP3_STATE_C6].type = OMAP3_STATE_C6;
> -       omap3_power_states[OMAP3_STATE_C6].sleep_latency = 3000;
> -       omap3_power_states[OMAP3_STATE_C6].wakeup_latency = 8500;
> -       omap3_power_states[OMAP3_STATE_C6].threshold = 15000;
> +       omap3_power_states[OMAP3_STATE_C6].sleep_latency =
> +                       cpuidle_params_table[OMAP3_STATE_C6].sleep_latency;
> +       omap3_power_states[OMAP3_STATE_C6].wakeup_latency =
> +                       cpuidle_params_table[OMAP3_STATE_C6].wake_latency;
> +       omap3_power_states[OMAP3_STATE_C6].threshold =
> +                       cpuidle_params_table[OMAP3_STATE_C6].threshold;
>        omap3_power_states[OMAP3_STATE_C6].mpu_state = PWRDM_POWER_OFF;
>        omap3_power_states[OMAP3_STATE_C6].core_state = PWRDM_POWER_RET;
>        omap3_power_states[OMAP3_STATE_C6].flags = CPUIDLE_FLAG_TIME_VALID |
> @@ -245,9 +305,12 @@ void omap_init_power_states(void)
>        /* C7 . MPU OFF + Core OFF */
>        omap3_power_states[OMAP3_STATE_C7].valid = 1;
>        omap3_power_states[OMAP3_STATE_C7].type = OMAP3_STATE_C7;
> -       omap3_power_states[OMAP3_STATE_C7].sleep_latency = 10000;
> -       omap3_power_states[OMAP3_STATE_C7].wakeup_latency = 30000;
> -       omap3_power_states[OMAP3_STATE_C7].threshold = 300000;
> +       omap3_power_states[OMAP3_STATE_C7].sleep_latency =
> +                       cpuidle_params_table[OMAP3_STATE_C7].sleep_latency;
> +       omap3_power_states[OMAP3_STATE_C7].wakeup_latency =
> +                       cpuidle_params_table[OMAP3_STATE_C7].wake_latency;
> +       omap3_power_states[OMAP3_STATE_C7].threshold =
> +                       cpuidle_params_table[OMAP3_STATE_C7].threshold;
>        omap3_power_states[OMAP3_STATE_C7].mpu_state = PWRDM_POWER_OFF;
>        omap3_power_states[OMAP3_STATE_C7].core_state = PWRDM_POWER_OFF;
>        omap3_power_states[OMAP3_STATE_C7].flags = CPUIDLE_FLAG_TIME_VALID |
> diff --git a/arch/arm/mach-omap2/io.c b/arch/arm/mach-omap2/io.c
> index 266a5a1..d8d10aa 100644
> --- a/arch/arm/mach-omap2/io.c
> +++ b/arch/arm/mach-omap2/io.c
> @@ -283,13 +283,14 @@ void __init omap2_init_common_hw(struct omap_sdrc_params *sp,
>                                 struct omap_opp *mpu_opps,
>                                 struct omap_opp *dsp_opps,
>                                 struct omap_opp *l3_opps,
> -                                struct prm_setup_vc *setup_times)
> +                                struct prm_setup_vc *setup_times,
> +                                struct cpuidle_params *idle_params)
>  {
>        omap2_mux_init();
>  #ifndef CONFIG_ARCH_OMAP4 /* FIXME: Remove this once the clkdev is ready */
>        /* The OPP tables have to be registered before a clk init */
>        omap_pm_if_early_init(mpu_opps, dsp_opps, l3_opps);
> -       omap_pm_early_init(setup_times);
> +       omap_pm_early_init(setup_times, idle_params);
>        pwrdm_init(powerdomains_omap);
>        clkdm_init(clockdomains_omap, clkdm_pwrdm_autodeps);
>        omapdev_init(omapdevs);
> diff --git a/arch/arm/mach-omap2/pm.c b/arch/arm/mach-omap2/pm.c
> index b81ba3b..5c5c59e 100644
> --- a/arch/arm/mach-omap2/pm.c
> +++ b/arch/arm/mach-omap2/pm.c
> @@ -236,10 +236,13 @@ unsigned get_last_off_on_transaction_id(struct device *dev)
>        return 0;
>  }
>
> -void __init omap_pm_early_init(struct prm_setup_vc *setup_times)
> +void __init omap_pm_early_init(struct prm_setup_vc *setup_times,
> +                                       struct cpuidle_params *idle_params)
>  {
> -       if (cpu_is_omap34xx())
> +       if (cpu_is_omap34xx()) {
>                omap3_set_prm_setup_vc(setup_times);
> +               omap3_set_idle_params(idle_params);
> +       }
>        return;
>  }
>
> diff --git a/arch/arm/mach-omap2/pm.h b/arch/arm/mach-omap2/pm.h
> index 0beb32d..8759053 100644
> --- a/arch/arm/mach-omap2/pm.h
> +++ b/arch/arm/mach-omap2/pm.h
> @@ -31,6 +31,12 @@ struct prm_setup_vc {
>        u16 vdd1_off;
>  };
>
> +struct cpuidle_params {
> +       u32 sleep_latency;
> +       u32 wake_latency;
> +       u32 threshold;
> +};
> +
>  #ifdef CONFIG_ARCH_OMAP3
>  extern unsigned short enable_dyn_sleep;
>  extern unsigned short enable_off_mode;
> @@ -43,6 +49,7 @@ extern int set_pwrdm_state(struct powerdomain *pwrdm, u32 state);
>  extern int omap3_pm_get_suspend_state(struct powerdomain *pwrdm);
>  extern int omap3_pm_set_suspend_state(struct powerdomain *pwrdm, int state);
>  extern void omap3_set_prm_setup_vc(struct prm_setup_vc *setup_vc);
> +extern void omap3_set_idle_params(struct cpuidle_params *cpuidle_board_params);
>  #ifdef CONFIG_CPU_IDLE
>  int omap3_idle_init(void);
>  #else
> @@ -51,8 +58,10 @@ static inline int omap3_idle_init(void) { return 0; }
>
>  #else /* CONFIG_ARCH_OMAP3 */
>  #define omap3_set_prm_setup_vc(setup_vc) do {} while (0);
> +#define omap3_set_idle_params(parmas, board_params) do {} while (0);
>
>  #endif /* CONFIG_ARCH_OMAP3 */
> +
>  extern int resource_set_opp_level(int res, u32 target_level, int flags);
>  extern int resource_access_opp_lock(int res, int delta);
>  #define resource_lock_opp(res) resource_access_opp_lock(res, 1)
> @@ -91,6 +100,7 @@ extern unsigned int omap34xx_suspend_sz;
>  extern unsigned int save_secure_ram_context_sz;
>  extern unsigned int omap24xx_cpu_suspend_sz;
>  extern unsigned int omap34xx_cpu_suspend_sz;
> -void __init omap_pm_early_init(struct prm_setup_vc *setup_times);
> +void __init omap_pm_early_init(struct prm_setup_vc *setup_times,
> +                                       struct cpuidle_params *idle_params);
>
>  #endif
> diff --git a/arch/arm/plat-omap/include/mach/io.h b/arch/arm/plat-omap/include/mach/io.h
> index 3582bef..d143bd9 100644
> --- a/arch/arm/plat-omap/include/mach/io.h
> +++ b/arch/arm/plat-omap/include/mach/io.h
> @@ -225,6 +225,7 @@
>  struct omap_sdrc_params;
>  struct omap_opp;
>  struct prm_setup_vc;
> +struct cpuidle_params;
>
>  extern void omap1_map_common_io(void);
>  extern void omap1_init_common_hw(void);
> @@ -234,7 +235,8 @@ extern void omap2_init_common_hw(struct omap_sdrc_params *sp,
>                                 struct omap_opp *mpu_opps,
>                                 struct omap_opp *dsp_opps,
>                                 struct omap_opp *l3_opps,
> -                                struct prm_setup_vc *setup_times);
> +                                struct prm_setup_vc *setup_times,
> +                                struct cpuidle_params *idle_params);
>
>  #define __arch_ioremap(p,s,t)  omap_ioremap(p,s,t)
>  #define __arch_iounmap(v)      omap_iounmap(v)
> --
> 1.5.4.7
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-omap" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>
--
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Sanjeev Premi June 30, 2009, 11:41 a.m. UTC | #2
> -----Original Message-----
> From: linux-omap-owner@vger.kernel.org 
> [mailto:linux-omap-owner@vger.kernel.org] On Behalf Of Nayak, Rajendra
> Sent: Monday, June 29, 2009 8:05 PM
> To: linux-omap@vger.kernel.org
> Cc: Nayak, Rajendra
> Subject: [PATCH 2/2] OMAP3: PM: Configure CPUidle 
> latencies/thresholds from board files
> 
> The CPUidle C state latencies and thresholds are dependent
> on various board specific details.
> Hence this patch makes it possible to configure these values from the
> respective board files.
> 
> Signed-off-by: Rajendra Nayak <rnayak@ti.com>
> ---
>  arch/arm/mach-omap2/board-3430sdp.c     |   22 ++++++-
>  arch/arm/mach-omap2/board-apollon.c     |    2 +-
>  arch/arm/mach-omap2/board-generic.c     |    2 +-
>  arch/arm/mach-omap2/board-h4.c          |    2 +-
>  arch/arm/mach-omap2/board-ldp.c         |    2 +-
>  arch/arm/mach-omap2/board-omap3beagle.c |    2 +-
>  arch/arm/mach-omap2/board-omap3evm.c    |    2 +-
>  arch/arm/mach-omap2/board-overo.c       |    3 +-
>  arch/arm/mach-omap2/board-rx51.c        |    2 +-
>  arch/arm/mach-omap2/board-zoom2.c       |    2 +-
>  arch/arm/mach-omap2/cpuidle34xx.c       |  105 
> ++++++++++++++++++++++++------
>  arch/arm/mach-omap2/io.c                |    5 +-
>  arch/arm/mach-omap2/pm.c                |    7 ++-
>  arch/arm/mach-omap2/pm.h                |   12 +++-
>  arch/arm/plat-omap/include/mach/io.h    |    4 +-
>  15 files changed, 136 insertions(+), 38 deletions(-)
> 

[snip]---[snip]

> diff --git a/arch/arm/plat-omap/include/mach/io.h 
> b/arch/arm/plat-omap/include/mach/io.h
> index 3582bef..d143bd9 100644
> --- a/arch/arm/plat-omap/include/mach/io.h
> +++ b/arch/arm/plat-omap/include/mach/io.h
> @@ -225,6 +225,7 @@
>  struct omap_sdrc_params;
>  struct omap_opp;
>  struct prm_setup_vc;
> +struct cpuidle_params;
>  
>  extern void omap1_map_common_io(void);
>  extern void omap1_init_common_hw(void);
> @@ -234,7 +235,8 @@ extern void omap2_init_common_hw(struct 
> omap_sdrc_params *sp,
>  				 struct omap_opp *mpu_opps,
>  				 struct omap_opp *dsp_opps,
>  				 struct omap_opp *l3_opps,
> -				 struct prm_setup_vc *setup_times);
> +				 struct prm_setup_vc *setup_times,
> +				 struct cpuidle_params *idle_params);

Rajendra, all,

Aren't we 'overloading' omap2_init_common_hw() each time we add another
argument to it?

Shouldn't we defined define a function specific for PM initialization?
Some of the initialization actually doesn't even touch the HW.

Best regards,
Sanjeev

>  
>  #define __arch_ioremap(p,s,t)	omap_ioremap(p,s,t)
>  #define __arch_iounmap(v)	omap_iounmap(v)
> -- 
> 1.5.4.7
> 
> --
> To unsubscribe from this list: send the line "unsubscribe 
> linux-omap" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 
> --
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Kevin Hilman June 30, 2009, 10:58 p.m. UTC | #3
"Premi, Sanjeev" <premi@ti.com> writes:

>>  extern void omap1_map_common_io(void);
>>  extern void omap1_init_common_hw(void);
>> @@ -234,7 +235,8 @@ extern void omap2_init_common_hw(struct 
>> omap_sdrc_params *sp,
>>  				 struct omap_opp *mpu_opps,
>>  				 struct omap_opp *dsp_opps,
>>  				 struct omap_opp *l3_opps,
>> -				 struct prm_setup_vc *setup_times);
>> +				 struct prm_setup_vc *setup_times,
>> +				 struct cpuidle_params *idle_params);
>
> Rajendra, all,
>
> Aren't we 'overloading' omap2_init_common_hw() each time we add another
> argument to it?
>
> Shouldn't we defined define a function specific for PM initialization?
> Some of the initialization actually doesn't even touch the HW.
>

Completely agree.

We are absolutely overloading init_common_hw() and this is on the list
of things I'd like to see changed before those change go upstream.  I
just haven't got to that yet.

I would happily welcome any proposals or cleanups to this.

My current feeling is that I think these board-specific settings
should just be using platform_driver/platform_device model and then
board-specifics could be passed via platform_data.  If not settings
are given, conservative defaults can be used.  But honestly, I haven't
given it much more thought, other than I *really* don't like the
current overloading of that function.

Kevin


--
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
diff mbox

Patch

diff --git a/arch/arm/mach-omap2/board-3430sdp.c b/arch/arm/mach-omap2/board-3430sdp.c
index b43cf94..750d841 100644
--- a/arch/arm/mach-omap2/board-3430sdp.c
+++ b/arch/arm/mach-omap2/board-3430sdp.c
@@ -75,6 +75,24 @@  static struct prm_setup_vc omap3_setuptime_table = {
 	.vdd1_off = 0x00,
 };
 
+/* FIXME: These values need to be updated based on more profiling on 3430sdp*/
+static struct cpuidle_params omap3_cpuidle_params_table[] = {
+	/* C1 */
+	{2, 2, 5},
+	/* C2 */
+	{10, 10, 30},
+	/* C3 */
+	{50, 50, 300},
+	/* C4 */
+	{1500, 1800, 4000},
+	/* C5 */
+	{2500, 7500, 12000},
+	/* C6 */
+	{3000, 8500, 15000},
+	/* C7 */
+	{10000, 30000, 300000},
+};
+
 static int sdp3430_keymap[] = {
 	KEY(0, 0, KEY_LEFT),
 	KEY(0, 1, KEY_RIGHT),
@@ -191,8 +209,8 @@  static struct platform_device *sdp3430_devices[] __initdata = {
 static void __init omap_3430sdp_init_irq(void)
 {
 	omap2_init_common_hw(hyb18m512160af6_sdrc_params, omap3_mpu_rate_table,
-			     omap3_dsp_rate_table, omap3_l3_rate_table,
-			     &omap3_setuptime_table);
+			omap3_dsp_rate_table, omap3_l3_rate_table,
+			&omap3_setuptime_table, omap3_cpuidle_params_table);
 	omap_init_irq();
 	omap_gpio_init();
 }
diff --git a/arch/arm/mach-omap2/board-apollon.c b/arch/arm/mach-omap2/board-apollon.c
index 293a9b2..fe625a9 100644
--- a/arch/arm/mach-omap2/board-apollon.c
+++ b/arch/arm/mach-omap2/board-apollon.c
@@ -250,7 +250,7 @@  out:
 
 static void __init omap_apollon_init_irq(void)
 {
-	omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL);
+	omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL, NULL);
 	omap_init_irq();
 	omap_gpio_init();
 	apollon_init_smc91x();
diff --git a/arch/arm/mach-omap2/board-generic.c b/arch/arm/mach-omap2/board-generic.c
index dfc1b49..ecf2c45 100644
--- a/arch/arm/mach-omap2/board-generic.c
+++ b/arch/arm/mach-omap2/board-generic.c
@@ -33,7 +33,7 @@ 
 
 static void __init omap_generic_init_irq(void)
 {
-	omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL);
+	omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL, NULL);
 	omap_init_irq();
 }
 
diff --git a/arch/arm/mach-omap2/board-h4.c b/arch/arm/mach-omap2/board-h4.c
index af0ebaf..365bc69 100644
--- a/arch/arm/mach-omap2/board-h4.c
+++ b/arch/arm/mach-omap2/board-h4.c
@@ -270,7 +270,7 @@  static void __init h4_init_flash(void)
 
 static void __init omap_h4_init_irq(void)
 {
-	omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL);
+	omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL, NULL);
 	omap_init_irq();
 	omap_gpio_init();
 	h4_init_flash();
diff --git a/arch/arm/mach-omap2/board-ldp.c b/arch/arm/mach-omap2/board-ldp.c
index eb5e2e0..1265a12 100644
--- a/arch/arm/mach-omap2/board-ldp.c
+++ b/arch/arm/mach-omap2/board-ldp.c
@@ -270,7 +270,7 @@  static inline void __init ldp_init_smsc911x(void)
 
 static void __init omap_ldp_init_irq(void)
 {
-	omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL);
+	omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL, NULL);
 	omap_init_irq();
 	omap_gpio_init();
 	ldp_init_smsc911x();
diff --git a/arch/arm/mach-omap2/board-omap3beagle.c b/arch/arm/mach-omap2/board-omap3beagle.c
index e0be6bd..da1f3f6 100644
--- a/arch/arm/mach-omap2/board-omap3beagle.c
+++ b/arch/arm/mach-omap2/board-omap3beagle.c
@@ -289,7 +289,7 @@  static int __init omap3_beagle_i2c_init(void)
 static void __init omap3_beagle_init_irq(void)
 {
 	omap2_init_common_hw(mt46h32m32lf6_sdrc_params, omap3_mpu_rate_table,
-			     omap3_dsp_rate_table, omap3_l3_rate_table, NULL);
+			omap3_dsp_rate_table, omap3_l3_rate_table, NULL, NULL);
 	omap_init_irq();
 #ifdef CONFIG_OMAP_32K_TIMER
 	omap2_gp_clockevent_set_gptimer(12);
diff --git a/arch/arm/mach-omap2/board-omap3evm.c b/arch/arm/mach-omap2/board-omap3evm.c
index eaab39b..4a287b9 100644
--- a/arch/arm/mach-omap2/board-omap3evm.c
+++ b/arch/arm/mach-omap2/board-omap3evm.c
@@ -284,7 +284,7 @@  struct spi_board_info omap3evm_spi_board_info[] = {
 static void __init omap3_evm_init_irq(void)
 {
 	omap2_init_common_hw(mt46h32m32lf6_sdrc_params, omap3_mpu_rate_table,
-			omap3_dsp_rate_table, omap3_l3_rate_table, NULL);
+			omap3_dsp_rate_table, omap3_l3_rate_table, NULL, NULL);
 	omap_init_irq();
 	omap_gpio_init();
 	omap3evm_init_smc911x();
diff --git a/arch/arm/mach-omap2/board-overo.c b/arch/arm/mach-omap2/board-overo.c
index f159e18..a673921 100644
--- a/arch/arm/mach-omap2/board-overo.c
+++ b/arch/arm/mach-omap2/board-overo.c
@@ -360,7 +360,8 @@  static int __init overo_i2c_init(void)
 
 static void __init overo_init_irq(void)
 {
-	omap2_init_common_hw(mt46h32m32lf6_sdrc_params, NULL, NULL, NULL, NULL);
+	omap2_init_common_hw(mt46h32m32lf6_sdrc_params,
+				 NULL, NULL, NULL, NULL, NULL);
 	omap_init_irq();
 	omap_gpio_init();
 }
diff --git a/arch/arm/mach-omap2/board-rx51.c b/arch/arm/mach-omap2/board-rx51.c
index 3629a0e..6cb8715 100644
--- a/arch/arm/mach-omap2/board-rx51.c
+++ b/arch/arm/mach-omap2/board-rx51.c
@@ -66,7 +66,7 @@  static struct omap_board_config_kernel rx51_config[] = {
 static void __init rx51_init_irq(void)
 {
 	omap2_init_common_hw(rx51_get_sdram_timings(), omap3_mpu_rate_table,
-			     omap3_dsp_rate_table, omap3_l3_rate_table, NULL);
+		omap3_dsp_rate_table, omap3_l3_rate_table, NULL, NULL);
 	omap_init_irq();
 	omap_gpio_init();
 }
diff --git a/arch/arm/mach-omap2/board-zoom2.c b/arch/arm/mach-omap2/board-zoom2.c
index e63bfa0..0fcd0ff 100644
--- a/arch/arm/mach-omap2/board-zoom2.c
+++ b/arch/arm/mach-omap2/board-zoom2.c
@@ -27,7 +27,7 @@ 
 static void __init omap_zoom2_init_irq(void)
 {
 	omap2_init_common_hw(NULL, omap3_mpu_rate_table,
-			omap3_dsp_rate_table, omap3_l3_rate_table, NULL);
+			omap3_dsp_rate_table, omap3_l3_rate_table, NULL, NULL);
 	omap_init_irq();
 	omap_gpio_init();
 }
diff --git a/arch/arm/mach-omap2/cpuidle34xx.c b/arch/arm/mach-omap2/cpuidle34xx.c
index 7bbec90..3d6c55a 100644
--- a/arch/arm/mach-omap2/cpuidle34xx.c
+++ b/arch/arm/mach-omap2/cpuidle34xx.c
@@ -60,6 +60,30 @@  struct omap3_processor_cx omap3_power_states[OMAP3_MAX_STATES];
 struct omap3_processor_cx current_cx_state;
 struct powerdomain *mpu_pd, *core_pd, *per_pd;
 
+/*
+ * The latencies/thresholds for various C states have
+ * to be configured from the respective board files.
+ * These are some default values (which might not provide
+ * the best power savings) used on boards which do not
+ * pass these details from the board file.
+ */
+static struct cpuidle_params cpuidle_params_table[] = {
+	/* C1 */
+	{2, 2, 5},
+	/* C2 */
+	{10, 10, 30},
+	/* C3 */
+	{50, 50, 300},
+	/* C4 */
+	{1500, 1800, 4000},
+	/* C5 */
+	{2500, 7500, 12000},
+	/* C6 */
+	{3000, 8500, 15000},
+	/* C7 */
+	{10000, 30000, 300000},
+};
+
 static int omap3_idle_bm_check(void)
 {
 	if (!omap3_can_sleep())
@@ -165,6 +189,24 @@  static int omap3_enter_idle_bm(struct cpuidle_device *dev,
 
 DEFINE_PER_CPU(struct cpuidle_device, omap3_idle_dev);
 
+void omap3_set_idle_params(struct cpuidle_params *cpuidle_board_params)
+{
+	int i;
+
+	if (!cpuidle_board_params)
+		return;
+
+	for (i = OMAP3_STATE_C1; i < OMAP3_MAX_STATES; i++) {
+		cpuidle_params_table[i].sleep_latency =
+					cpuidle_board_params[i].sleep_latency;
+		cpuidle_params_table[i].wake_latency =
+					cpuidle_board_params[i].wake_latency;
+		cpuidle_params_table[i].threshold =
+					cpuidle_board_params[i].threshold;
+	}
+	return;
+}
+
 /* omap3_init_power_states - Initialises the OMAP3 specific C states.
  *
  * Below is the desciption of each C state.
@@ -181,9 +223,12 @@  void omap_init_power_states(void)
 	/* C1 . MPU WFI + Core active */
 	omap3_power_states[OMAP3_STATE_C1].valid = 1;
 	omap3_power_states[OMAP3_STATE_C1].type = OMAP3_STATE_C1;
-	omap3_power_states[OMAP3_STATE_C1].sleep_latency = 2;
-	omap3_power_states[OMAP3_STATE_C1].wakeup_latency = 2;
-	omap3_power_states[OMAP3_STATE_C1].threshold = 5;
+	omap3_power_states[OMAP3_STATE_C1].sleep_latency =
+			cpuidle_params_table[OMAP3_STATE_C1].sleep_latency;
+	omap3_power_states[OMAP3_STATE_C1].wakeup_latency =
+			cpuidle_params_table[OMAP3_STATE_C1].wake_latency;
+	omap3_power_states[OMAP3_STATE_C1].threshold =
+			cpuidle_params_table[OMAP3_STATE_C1].threshold;
 	omap3_power_states[OMAP3_STATE_C1].mpu_state = PWRDM_POWER_ON;
 	omap3_power_states[OMAP3_STATE_C1].core_state = PWRDM_POWER_ON;
 	omap3_power_states[OMAP3_STATE_C1].flags = CPUIDLE_FLAG_TIME_VALID;
@@ -191,9 +236,12 @@  void omap_init_power_states(void)
 	/* C2 . MPU WFI + Core inactive */
 	omap3_power_states[OMAP3_STATE_C2].valid = 1;
 	omap3_power_states[OMAP3_STATE_C2].type = OMAP3_STATE_C2;
-	omap3_power_states[OMAP3_STATE_C2].sleep_latency = 10;
-	omap3_power_states[OMAP3_STATE_C2].wakeup_latency = 10;
-	omap3_power_states[OMAP3_STATE_C2].threshold = 30;
+	omap3_power_states[OMAP3_STATE_C2].sleep_latency =
+			cpuidle_params_table[OMAP3_STATE_C2].sleep_latency;;
+	omap3_power_states[OMAP3_STATE_C2].wakeup_latency =
+			cpuidle_params_table[OMAP3_STATE_C2].wake_latency;;
+	omap3_power_states[OMAP3_STATE_C2].threshold =
+			cpuidle_params_table[OMAP3_STATE_C2].threshold;;
 	omap3_power_states[OMAP3_STATE_C2].mpu_state = PWRDM_POWER_ON;
 	omap3_power_states[OMAP3_STATE_C2].core_state = PWRDM_POWER_ON;
 	omap3_power_states[OMAP3_STATE_C2].flags = CPUIDLE_FLAG_TIME_VALID;
@@ -201,9 +249,12 @@  void omap_init_power_states(void)
 	/* C3 . MPU CSWR + Core inactive */
 	omap3_power_states[OMAP3_STATE_C3].valid = 1;
 	omap3_power_states[OMAP3_STATE_C3].type = OMAP3_STATE_C3;
-	omap3_power_states[OMAP3_STATE_C3].sleep_latency = 50;
-	omap3_power_states[OMAP3_STATE_C3].wakeup_latency = 50;
-	omap3_power_states[OMAP3_STATE_C3].threshold = 300;
+	omap3_power_states[OMAP3_STATE_C3].sleep_latency =
+			cpuidle_params_table[OMAP3_STATE_C3].sleep_latency;
+	omap3_power_states[OMAP3_STATE_C3].wakeup_latency =
+			cpuidle_params_table[OMAP3_STATE_C3].wake_latency;
+	omap3_power_states[OMAP3_STATE_C3].threshold =
+			cpuidle_params_table[OMAP3_STATE_C3].threshold;
 	omap3_power_states[OMAP3_STATE_C3].mpu_state = PWRDM_POWER_RET;
 	omap3_power_states[OMAP3_STATE_C3].core_state = PWRDM_POWER_ON;
 	omap3_power_states[OMAP3_STATE_C3].flags = CPUIDLE_FLAG_TIME_VALID |
@@ -212,9 +263,12 @@  void omap_init_power_states(void)
 	/* C4 . MPU OFF + Core inactive */
 	omap3_power_states[OMAP3_STATE_C4].valid = 1;
 	omap3_power_states[OMAP3_STATE_C4].type = OMAP3_STATE_C4;
-	omap3_power_states[OMAP3_STATE_C4].sleep_latency = 1500;
-	omap3_power_states[OMAP3_STATE_C4].wakeup_latency = 1800;
-	omap3_power_states[OMAP3_STATE_C4].threshold = 4000;
+	omap3_power_states[OMAP3_STATE_C4].sleep_latency =
+			cpuidle_params_table[OMAP3_STATE_C4].sleep_latency;
+	omap3_power_states[OMAP3_STATE_C4].wakeup_latency =
+			cpuidle_params_table[OMAP3_STATE_C4].wake_latency;
+	omap3_power_states[OMAP3_STATE_C4].threshold =
+			cpuidle_params_table[OMAP3_STATE_C4].threshold;
 	omap3_power_states[OMAP3_STATE_C4].mpu_state = PWRDM_POWER_OFF;
 	omap3_power_states[OMAP3_STATE_C4].core_state = PWRDM_POWER_ON;
 	omap3_power_states[OMAP3_STATE_C4].flags = CPUIDLE_FLAG_TIME_VALID |
@@ -223,9 +277,12 @@  void omap_init_power_states(void)
 	/* C5 . MPU CSWR + Core CSWR*/
 	omap3_power_states[OMAP3_STATE_C5].valid = 1;
 	omap3_power_states[OMAP3_STATE_C5].type = OMAP3_STATE_C5;
-	omap3_power_states[OMAP3_STATE_C5].sleep_latency = 2500;
-	omap3_power_states[OMAP3_STATE_C5].wakeup_latency = 7500;
-	omap3_power_states[OMAP3_STATE_C5].threshold = 12000;
+	omap3_power_states[OMAP3_STATE_C5].sleep_latency =
+			cpuidle_params_table[OMAP3_STATE_C5].sleep_latency;
+	omap3_power_states[OMAP3_STATE_C5].wakeup_latency =
+			cpuidle_params_table[OMAP3_STATE_C5].wake_latency;
+	omap3_power_states[OMAP3_STATE_C5].threshold =
+			cpuidle_params_table[OMAP3_STATE_C5].threshold;
 	omap3_power_states[OMAP3_STATE_C5].mpu_state = PWRDM_POWER_RET;
 	omap3_power_states[OMAP3_STATE_C5].core_state = PWRDM_POWER_RET;
 	omap3_power_states[OMAP3_STATE_C5].flags = CPUIDLE_FLAG_TIME_VALID |
@@ -234,9 +291,12 @@  void omap_init_power_states(void)
 	/* C6 . MPU OFF + Core CSWR */
 	omap3_power_states[OMAP3_STATE_C6].valid = 1;
 	omap3_power_states[OMAP3_STATE_C6].type = OMAP3_STATE_C6;
-	omap3_power_states[OMAP3_STATE_C6].sleep_latency = 3000;
-	omap3_power_states[OMAP3_STATE_C6].wakeup_latency = 8500;
-	omap3_power_states[OMAP3_STATE_C6].threshold = 15000;
+	omap3_power_states[OMAP3_STATE_C6].sleep_latency =
+			cpuidle_params_table[OMAP3_STATE_C6].sleep_latency;
+	omap3_power_states[OMAP3_STATE_C6].wakeup_latency =
+			cpuidle_params_table[OMAP3_STATE_C6].wake_latency;
+	omap3_power_states[OMAP3_STATE_C6].threshold =
+			cpuidle_params_table[OMAP3_STATE_C6].threshold;
 	omap3_power_states[OMAP3_STATE_C6].mpu_state = PWRDM_POWER_OFF;
 	omap3_power_states[OMAP3_STATE_C6].core_state = PWRDM_POWER_RET;
 	omap3_power_states[OMAP3_STATE_C6].flags = CPUIDLE_FLAG_TIME_VALID |
@@ -245,9 +305,12 @@  void omap_init_power_states(void)
 	/* C7 . MPU OFF + Core OFF */
 	omap3_power_states[OMAP3_STATE_C7].valid = 1;
 	omap3_power_states[OMAP3_STATE_C7].type = OMAP3_STATE_C7;
-	omap3_power_states[OMAP3_STATE_C7].sleep_latency = 10000;
-	omap3_power_states[OMAP3_STATE_C7].wakeup_latency = 30000;
-	omap3_power_states[OMAP3_STATE_C7].threshold = 300000;
+	omap3_power_states[OMAP3_STATE_C7].sleep_latency =
+			cpuidle_params_table[OMAP3_STATE_C7].sleep_latency;
+	omap3_power_states[OMAP3_STATE_C7].wakeup_latency =
+			cpuidle_params_table[OMAP3_STATE_C7].wake_latency;
+	omap3_power_states[OMAP3_STATE_C7].threshold =
+			cpuidle_params_table[OMAP3_STATE_C7].threshold;
 	omap3_power_states[OMAP3_STATE_C7].mpu_state = PWRDM_POWER_OFF;
 	omap3_power_states[OMAP3_STATE_C7].core_state = PWRDM_POWER_OFF;
 	omap3_power_states[OMAP3_STATE_C7].flags = CPUIDLE_FLAG_TIME_VALID |
diff --git a/arch/arm/mach-omap2/io.c b/arch/arm/mach-omap2/io.c
index 266a5a1..d8d10aa 100644
--- a/arch/arm/mach-omap2/io.c
+++ b/arch/arm/mach-omap2/io.c
@@ -283,13 +283,14 @@  void __init omap2_init_common_hw(struct omap_sdrc_params *sp,
 				 struct omap_opp *mpu_opps,
 				 struct omap_opp *dsp_opps,
 				 struct omap_opp *l3_opps,
-				 struct prm_setup_vc *setup_times)
+				 struct prm_setup_vc *setup_times,
+				 struct cpuidle_params *idle_params)
 {
 	omap2_mux_init();
 #ifndef CONFIG_ARCH_OMAP4 /* FIXME: Remove this once the clkdev is ready */
 	/* The OPP tables have to be registered before a clk init */
 	omap_pm_if_early_init(mpu_opps, dsp_opps, l3_opps);
-	omap_pm_early_init(setup_times);
+	omap_pm_early_init(setup_times, idle_params);
 	pwrdm_init(powerdomains_omap);
 	clkdm_init(clockdomains_omap, clkdm_pwrdm_autodeps);
 	omapdev_init(omapdevs);
diff --git a/arch/arm/mach-omap2/pm.c b/arch/arm/mach-omap2/pm.c
index b81ba3b..5c5c59e 100644
--- a/arch/arm/mach-omap2/pm.c
+++ b/arch/arm/mach-omap2/pm.c
@@ -236,10 +236,13 @@  unsigned get_last_off_on_transaction_id(struct device *dev)
 	return 0;
 }
 
-void __init omap_pm_early_init(struct prm_setup_vc *setup_times)
+void __init omap_pm_early_init(struct prm_setup_vc *setup_times,
+					struct cpuidle_params *idle_params)
 {
-	if (cpu_is_omap34xx())
+	if (cpu_is_omap34xx()) {
 		omap3_set_prm_setup_vc(setup_times);
+		omap3_set_idle_params(idle_params);
+	}
 	return;
 }
 
diff --git a/arch/arm/mach-omap2/pm.h b/arch/arm/mach-omap2/pm.h
index 0beb32d..8759053 100644
--- a/arch/arm/mach-omap2/pm.h
+++ b/arch/arm/mach-omap2/pm.h
@@ -31,6 +31,12 @@  struct prm_setup_vc {
 	u16 vdd1_off;
 };
 
+struct cpuidle_params {
+	u32 sleep_latency;
+	u32 wake_latency;
+	u32 threshold;
+};
+
 #ifdef CONFIG_ARCH_OMAP3
 extern unsigned short enable_dyn_sleep;
 extern unsigned short enable_off_mode;
@@ -43,6 +49,7 @@  extern int set_pwrdm_state(struct powerdomain *pwrdm, u32 state);
 extern int omap3_pm_get_suspend_state(struct powerdomain *pwrdm);
 extern int omap3_pm_set_suspend_state(struct powerdomain *pwrdm, int state);
 extern void omap3_set_prm_setup_vc(struct prm_setup_vc *setup_vc);
+extern void omap3_set_idle_params(struct cpuidle_params *cpuidle_board_params);
 #ifdef CONFIG_CPU_IDLE
 int omap3_idle_init(void);
 #else
@@ -51,8 +58,10 @@  static inline int omap3_idle_init(void) { return 0; }
 
 #else /* CONFIG_ARCH_OMAP3 */
 #define omap3_set_prm_setup_vc(setup_vc) do {} while (0);
+#define omap3_set_idle_params(parmas, board_params) do {} while (0);
 
 #endif /* CONFIG_ARCH_OMAP3 */
+
 extern int resource_set_opp_level(int res, u32 target_level, int flags);
 extern int resource_access_opp_lock(int res, int delta);
 #define resource_lock_opp(res) resource_access_opp_lock(res, 1)
@@ -91,6 +100,7 @@  extern unsigned int omap34xx_suspend_sz;
 extern unsigned int save_secure_ram_context_sz;
 extern unsigned int omap24xx_cpu_suspend_sz;
 extern unsigned int omap34xx_cpu_suspend_sz;
-void __init omap_pm_early_init(struct prm_setup_vc *setup_times);
+void __init omap_pm_early_init(struct prm_setup_vc *setup_times,
+					struct cpuidle_params *idle_params);
 
 #endif
diff --git a/arch/arm/plat-omap/include/mach/io.h b/arch/arm/plat-omap/include/mach/io.h
index 3582bef..d143bd9 100644
--- a/arch/arm/plat-omap/include/mach/io.h
+++ b/arch/arm/plat-omap/include/mach/io.h
@@ -225,6 +225,7 @@ 
 struct omap_sdrc_params;
 struct omap_opp;
 struct prm_setup_vc;
+struct cpuidle_params;
 
 extern void omap1_map_common_io(void);
 extern void omap1_init_common_hw(void);
@@ -234,7 +235,8 @@  extern void omap2_init_common_hw(struct omap_sdrc_params *sp,
 				 struct omap_opp *mpu_opps,
 				 struct omap_opp *dsp_opps,
 				 struct omap_opp *l3_opps,
-				 struct prm_setup_vc *setup_times);
+				 struct prm_setup_vc *setup_times,
+				 struct cpuidle_params *idle_params);
 
 #define __arch_ioremap(p,s,t)	omap_ioremap(p,s,t)
 #define __arch_iounmap(v)	omap_iounmap(v)