OMAP2/3: GPIO: generalize prepare for idle
Currently, the GPIO 'prepare' hook is only called when going to off-mode, while the function is called 'prepare_for_retention.' This patch renames the function to 'prepare_for_idle' and calls it for any powersate != PWRDM_POWER_ON passing in the powerstate. The hook itself is then responsible for doing various preparation based on the powerstate. Signed-off-by: Kevin Hilman <khilman@deeprootsystems.com>
This commit is contained in:
parent
699117a69f
commit
43ffcd9a04
|
@ -107,7 +107,7 @@ static void omap2_enter_full_retention(void)
|
|||
l = omap_ctrl_readl(OMAP2_CONTROL_DEVCONF0) | OMAP24XX_USBSTANDBYCTRL;
|
||||
omap_ctrl_writel(l, OMAP2_CONTROL_DEVCONF0);
|
||||
|
||||
omap2_gpio_prepare_for_retention();
|
||||
omap2_gpio_prepare_for_idle(PWRDM_POWER_RET);
|
||||
|
||||
if (omap2_pm_debug) {
|
||||
omap2_pm_dump(0, 0, 0);
|
||||
|
@ -141,7 +141,7 @@ no_sleep:
|
|||
tmp = timespec_to_ns(&ts_idle) * NSEC_PER_USEC;
|
||||
omap2_pm_dump(0, 1, tmp);
|
||||
}
|
||||
omap2_gpio_resume_after_retention();
|
||||
omap2_gpio_resume_after_idle();
|
||||
|
||||
clk_enable(osc_ck);
|
||||
|
||||
|
|
|
@ -376,15 +376,14 @@ 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_idle(per_next_state);
|
||||
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 {
|
||||
omap2_gpio_prepare_for_retention();
|
||||
} else
|
||||
omap3_per_save_context();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -455,10 +454,9 @@ 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) {
|
||||
omap2_gpio_resume_after_idle();
|
||||
if (per_prev_state == PWRDM_POWER_OFF)
|
||||
omap3_per_restore_context();
|
||||
omap2_gpio_resume_after_retention();
|
||||
}
|
||||
omap_uart_resume_idle(2);
|
||||
if (per_state_modified)
|
||||
pwrdm_set_next_pwrst(per_pwrdm, PWRDM_POWER_OFF);
|
||||
|
|
|
@ -27,6 +27,7 @@
|
|||
#include <mach/irqs.h>
|
||||
#include <mach/gpio.h>
|
||||
#include <asm/mach/irq.h>
|
||||
#include <plat/powerdomain.h>
|
||||
|
||||
/*
|
||||
* OMAP1510 GPIO registers
|
||||
|
@ -2041,19 +2042,24 @@ static struct sys_device omap_gpio_device = {
|
|||
|
||||
static int workaround_enabled;
|
||||
|
||||
void omap2_gpio_prepare_for_retention(void)
|
||||
void omap2_gpio_prepare_for_idle(int power_state)
|
||||
{
|
||||
int i, c = 0;
|
||||
int min = 0;
|
||||
|
||||
if (cpu_is_omap34xx())
|
||||
min = 1;
|
||||
/* Remove triggering for all non-wakeup GPIOs. Otherwise spurious
|
||||
* IRQs will be generated. See OMAP2420 Errata item 1.101. */
|
||||
|
||||
for (i = min; i < gpio_bank_count; i++) {
|
||||
struct gpio_bank *bank = &gpio_bank[i];
|
||||
u32 l1, l2;
|
||||
|
||||
if (power_state > PWRDM_POWER_OFF)
|
||||
continue;
|
||||
|
||||
/* If going to OFF, remove triggering for all
|
||||
* non-wakeup GPIOs. Otherwise spurious IRQs will be
|
||||
* generated. See OMAP2420 Errata item 1.101. */
|
||||
if (!(bank->enabled_non_wakeup_gpios))
|
||||
continue;
|
||||
|
||||
|
@ -2101,19 +2107,20 @@ void omap2_gpio_prepare_for_retention(void)
|
|||
workaround_enabled = 1;
|
||||
}
|
||||
|
||||
void omap2_gpio_resume_after_retention(void)
|
||||
void omap2_gpio_resume_after_idle(void)
|
||||
{
|
||||
int i;
|
||||
int min = 0;
|
||||
|
||||
if (!workaround_enabled)
|
||||
return;
|
||||
if (cpu_is_omap34xx())
|
||||
min = 1;
|
||||
for (i = min; i < gpio_bank_count; i++) {
|
||||
struct gpio_bank *bank = &gpio_bank[i];
|
||||
u32 l, gen, gen0, gen1;
|
||||
|
||||
if (!workaround_enabled)
|
||||
continue;
|
||||
|
||||
if (!(bank->enabled_non_wakeup_gpios))
|
||||
continue;
|
||||
|
||||
|
|
|
@ -72,8 +72,8 @@
|
|||
IH_GPIO_BASE + (nr))
|
||||
|
||||
extern int omap_gpio_init(void); /* Call from board init only */
|
||||
extern void omap2_gpio_prepare_for_retention(void);
|
||||
extern void omap2_gpio_resume_after_retention(void);
|
||||
extern void omap2_gpio_prepare_for_idle(int power_state);
|
||||
extern void omap2_gpio_resume_after_idle(void);
|
||||
extern void omap_set_gpio_debounce(int gpio, int enable);
|
||||
extern void omap_set_gpio_debounce_time(int gpio, int enable);
|
||||
extern void omap_gpio_save_context(void);
|
||||
|
|
Loading…
Reference in New Issue