Tero Kristo <[email protected]> writes:
> From: Tero Kristo <[email protected]>
> Subject: [PATCH] OMAP3: GPIO fixes for off-mode
> To: [email protected]
> Date: Mon, 22 Dec 2008 14:27:12 +0200
>
> Off mode is now using the omap2 retention fix code for scanning GPIOs
> during off-mode transitions. All the *non_wakeup_gpios variables
> are now used for off-mode transition tracking on OMAP3. This patch fixes
> cases where GPIO state changes are missed during off-mode.
>
> Signed-off-by: Tero Kristo <[email protected]>
Looks good now, thanks. Pulling into PM branch.
Kevin
> ---
> arch/arm/mach-omap2/pm34xx.c | 10 ++++++----
> arch/arm/plat-omap/gpio.c | 29 ++++++++++++++++++++---------
> 2 files changed, 26 insertions(+), 13 deletions(-)
>
> diff --git a/arch/arm/mach-omap2/pm34xx.c b/arch/arm/mach-omap2/pm34xx.c
> index c67d770..66f2b22 100644
> --- a/arch/arm/mach-omap2/pm34xx.c
> +++ b/arch/arm/mach-omap2/pm34xx.c
> @@ -330,14 +330,15 @@ void omap_sram_idle(void)
> core_next_state = pwrdm_read_next_pwrst(core_pwrdm);
> if (per_next_state < PWRDM_POWER_ON) {
> omap_uart_prepare_idle(2);
> - omap2_gpio_prepare_for_retention();
> if (per_next_state == PWRDM_POWER_OFF) {
> if (core_next_state == PWRDM_POWER_ON) {
> per_next_state = PWRDM_POWER_RET;
> pwrdm_set_next_pwrst(per_pwrdm, per_next_state);
> per_state_modified = 1;
> - } else
> + } else {
> + omap2_gpio_prepare_for_retention();
> omap3_per_save_context();
> + }
> }
> }
>
> @@ -411,9 +412,10 @@ void omap_sram_idle(void)
> /* PER */
> if (per_next_state < PWRDM_POWER_ON) {
> per_prev_state = pwrdm_read_prev_pwrst(per_pwrdm);
> - if (per_prev_state == PWRDM_POWER_OFF)
> + if (per_prev_state == PWRDM_POWER_OFF) {
> omap3_per_restore_context();
> - omap2_gpio_resume_after_retention();
> + omap2_gpio_resume_after_retention();
> + }
> omap_uart_resume_idle(2);
> if (per_state_modified)
> pwrdm_set_next_pwrst(per_pwrdm, PWRDM_POWER_OFF);
> diff --git a/arch/arm/plat-omap/gpio.c b/arch/arm/plat-omap/gpio.c
> index 83a5953..db40037 100644
> --- a/arch/arm/plat-omap/gpio.c
> +++ b/arch/arm/plat-omap/gpio.c
> @@ -540,7 +540,9 @@ static inline void set_24xx_gpio_triggering(struct
> gpio_bank *bank, int gpio,
> else
> __raw_writel(1 << gpio, bank->base
> + OMAP24XX_GPIO_CLEARWKUENA);
> - } else {
> + }
> + /* This part needs to be executed always for OMAP34xx */
> + if (cpu_is_omap34xx() || (bank->non_wakeup_gpios & gpio_bit)) {
> if (trigger != 0)
> bank->enabled_non_wakeup_gpios |= gpio_bit;
> else
> @@ -1456,7 +1458,8 @@ static int __init _omap_gpio_init(void)
>
> /* Initialize interface clock ungated, module enabled */
> __raw_writel(0, bank->base + OMAP24XX_GPIO_CTRL);
> - if (i < ARRAY_SIZE(non_wakeup_gpios))
--
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html