Hello Joe,
On Thu, 12 Jul 2012, Joe Woodward wrote:
> I think this has fixed the following warning:
> [ 0.000000] clockdomain: mpu_clkdm: powerdomain ¬õ`À8ºsÀ does not exist
>
> But when I try and suspend I still get the same problems:
> # echo mem > /sys/power/state
> [ 13.283935] PM: Syncing filesystems ... done.
> [ 13.300537] Freezing user space processes ... (elapsed 0.01 seconds) done.
> [ 13.324859] Freezing remaining freezable tasks ... (elapsed 0.02 seconds)
> done.
> [ 13.356140] Suspending console(s) (use no_console_suspend to debug)
> [ 13.487823] PM: suspend of devices complete after 120.578 msecs
> [ 13.491577] PM: late suspend of devices complete after 3.722 msecs
> [ 13.497375] PM: noirq suspend of devices complete after 5.767 msecs
> [ 13.497436] Disabling non-boot CPUs ...
> [ 15.806640] Powerdomain (iva2_pwrdm) didn't enter target state 1
> [ 15.806640] Powerdomain (dss_pwrdm) didn't enter target state 1
> [ 15.806671] Powerdomain (per_pwrdm) didn't enter target state 1
> [ 15.806671] Powerdomain (core_pwrdm) didn't enter target state 1
> [ 15.806671] Powerdomain (usbhost_pwrdm) didn't enter target state 1
> [ 15.806671] Could not enter target state in pm_suspend
> [ 15.809722] PM: noirq resume of devices complete after 2.868 msecs
> [ 15.813598] PM: early resume of devices complete after 2.380 msecs
> [ 16.179382] mmc1: error -110 during resume (card was removed?)
> [ 16.189575] PM: resume of devices complete after 375.824 msecs
> [ 16.279602] Restarting tasks ... done.
> sh: write error: Operation not permitted
Thanks for the test. Perhaps you could try the following untested patch?
- Paul
---
arch/arm/mach-omap2/pm34xx.c | 14 +++++---------
1 file changed, 5 insertions(+), 9 deletions(-)
diff --git a/arch/arm/mach-omap2/pm34xx.c b/arch/arm/mach-omap2/pm34xx.c
index e4fc88c..ced2f76 100644
--- a/arch/arm/mach-omap2/pm34xx.c
+++ b/arch/arm/mach-omap2/pm34xx.c
@@ -545,13 +545,10 @@ static void __init prcm_setup_regs(void)
OMAP3430_PER_MOD, OMAP3430_PM_MPUGRPSEL);
/* Don't attach IVA interrupts */
- if (omap3_has_iva()) {
- omap2_prm_write_mod_reg(0, WKUP_MOD, OMAP3430_PM_IVAGRPSEL);
- omap2_prm_write_mod_reg(0, CORE_MOD, OMAP3430_PM_IVAGRPSEL1);
- omap2_prm_write_mod_reg(0, CORE_MOD, OMAP3430ES2_PM_IVAGRPSEL3);
- omap2_prm_write_mod_reg(0, OMAP3430_PER_MOD,
- OMAP3430_PM_IVAGRPSEL);
- }
+ omap2_prm_write_mod_reg(0, WKUP_MOD, OMAP3430_PM_IVAGRPSEL);
+ omap2_prm_write_mod_reg(0, CORE_MOD, OMAP3430_PM_IVAGRPSEL1);
+ omap2_prm_write_mod_reg(0, CORE_MOD, OMAP3430ES2_PM_IVAGRPSEL3);
+ omap2_prm_write_mod_reg(0, OMAP3430_PER_MOD, OMAP3430_PM_IVAGRPSEL);
/* Clear any pending 'reset' flags */
omap2_prm_write_mod_reg(0xffffffff, MPU_MOD, OMAP2_RM_RSTST);
@@ -565,8 +562,7 @@ static void __init prcm_setup_regs(void)
/* Clear any pending PRCM interrupts */
omap2_prm_write_mod_reg(0, OCP_MOD, OMAP3_PRM_IRQSTATUS_MPU_OFFSET);
- if (omap3_has_iva())
- omap3_iva_idle();
+ omap3_iva_idle();
omap3_d2d_idle();
}
--
1.7.10