aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
Diffstat (limited to 'arch')
-rw-r--r--arch/arm/mach-omap2/pm34xx.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/arch/arm/mach-omap2/pm34xx.c b/arch/arm/mach-omap2/pm34xx.c
index d9440a18bd00..cf6ea9f318fb 100644
--- a/arch/arm/mach-omap2/pm34xx.c
+++ b/arch/arm/mach-omap2/pm34xx.c
@@ -63,7 +63,7 @@ static struct powerdomain *mpu_pwrdm;
63 */ 63 */
64static int prcm_clear_mod_irqs(s16 module, u8 regs) 64static int prcm_clear_mod_irqs(s16 module, u8 regs)
65{ 65{
66 u32 wkst, fclk, iclk; 66 u32 wkst, fclk, iclk, clken;
67 u16 wkst_off = (regs == 3) ? OMAP3430ES2_PM_WKST3 : PM_WKST1; 67 u16 wkst_off = (regs == 3) ? OMAP3430ES2_PM_WKST3 : PM_WKST1;
68 u16 fclk_off = (regs == 3) ? OMAP3430ES2_CM_FCLKEN3 : CM_FCLKEN1; 68 u16 fclk_off = (regs == 3) ? OMAP3430ES2_CM_FCLKEN3 : CM_FCLKEN1;
69 u16 iclk_off = (regs == 3) ? CM_ICLKEN3 : CM_ICLKEN1; 69 u16 iclk_off = (regs == 3) ? CM_ICLKEN3 : CM_ICLKEN1;
@@ -77,8 +77,15 @@ static int prcm_clear_mod_irqs(s16 module, u8 regs)
77 iclk = cm_read_mod_reg(module, iclk_off); 77 iclk = cm_read_mod_reg(module, iclk_off);
78 fclk = cm_read_mod_reg(module, fclk_off); 78 fclk = cm_read_mod_reg(module, fclk_off);
79 while (wkst) { 79 while (wkst) {
80 cm_set_mod_reg_bits(wkst, module, iclk_off); 80 clken = wkst;
81 cm_set_mod_reg_bits(wkst, module, fclk_off); 81 cm_set_mod_reg_bits(clken, module, iclk_off);
82 /*
83 * For USBHOST, we don't know whether HOST1 or
84 * HOST2 woke us up, so enable both f-clocks
85 */
86 if (module == OMAP3430ES2_USBHOST_MOD)
87 clken |= 1 << OMAP3430ES2_EN_USBHOST2_SHIFT;
88 cm_set_mod_reg_bits(clken, module, fclk_off);
82 prm_write_mod_reg(wkst, module, wkst_off); 89 prm_write_mod_reg(wkst, module, wkst_off);
83 wkst = prm_read_mod_reg(module, wkst_off); 90 wkst = prm_read_mod_reg(module, wkst_off);
84 c++; 91 c++;