ARM: OMAP2+: Fix power domain operations regression caused by 81xx
authorTony Lindgren <tony@atomide.com>
Fri, 7 Aug 2015 05:09:40 +0000 (22:09 -0700)
committerTony Lindgren <tony@atomide.com>
Fri, 7 Aug 2015 05:09:40 +0000 (22:09 -0700)
I managed to mess up omap3 power domain operations with commit
7c80a3f89c51 ("ARM: OMAP2+: Add custom prwdm_operations for 81xx
to support dm814x"), by default we should keep on using the
omap3_pwrdm_operations, only 81xx needs custom handling.

This causes omap3 PM to break so we won't hit off mode any longer
causing idle power consumption go up from less than 10mW to over
50 mW.

Fixs: 7c80a3f89c51 ("ARM: OMAP2+: Add custom prwdm_operations for
81xx to support dm814x")
Signed-off-by: Tony Lindgren <tony@atomide.com>
arch/arm/mach-omap2/powerdomains3xxx_data.c

index 7829d274e037b5d2835fb27169a2ed365740bba0..d31c495175c1aa3daaff7da2f65b8ac3075b6232 100644 (file)
@@ -580,7 +580,9 @@ void __init omap3xxx_powerdomains_init(void)
        if (!cpu_is_omap34xx() && !cpu_is_ti81xx())
                return;
 
-       pwrdm_register_platform_funcs(&ti81xx_pwrdm_operations);
+       /* Only 81xx needs custom pwrdm_operations */
+       if (!cpu_is_ti81xx())
+               pwrdm_register_platform_funcs(&omap3_pwrdm_operations);;
 
        rev = omap_rev();
 
@@ -588,9 +590,11 @@ void __init omap3xxx_powerdomains_init(void)
                pwrdm_register_pwrdms(powerdomains_am35x);
        } else if (rev == TI8148_REV_ES1_0 || rev == TI8148_REV_ES2_0 ||
                   rev == TI8148_REV_ES2_1) {
+               pwrdm_register_platform_funcs(&ti81xx_pwrdm_operations);
                pwrdm_register_pwrdms(powerdomains_ti814x);
        } else if (rev == TI8168_REV_ES1_0 || rev == TI8168_REV_ES1_1
                        || rev == TI8168_REV_ES2_0 || rev == TI8168_REV_ES2_1) {
+               pwrdm_register_platform_funcs(&ti81xx_pwrdm_operations);
                pwrdm_register_pwrdms(powerdomains_ti816x);
        } else {
                pwrdm_register_pwrdms(powerdomains_omap3430_common);