>-----Original Message----- >From: ext Cousson, Benoit [mailto:b-cousson@xxxxxx] >Sent: 16 October, 2009 18:27 >To: Kristo Tero (Nokia-D/Tampere); linux-omap@xxxxxxxxxxxxxxx >Cc: Kalle Jokiniemi >Subject: RE: [PATCH 03/17] PM: Block CORE off when DSS is active > >Hi Tero, > >> >Texas Instruments France SA, 821 Avenue Jack Kilby, 06270 >Villeneuve Loubet. 036 420 040 R.C.S Antibes. Capital de EUR 753.920 > >-----Original Message----- > >>From: linux-omap-owner@xxxxxxxxxxxxxxx [mailto:linux-omap- >>owner@xxxxxxxxxxxxxxx] On Behalf Of Tero Kristo >>Sent: Friday, October 16, 2009 12:49 PM >>To: linux-omap@xxxxxxxxxxxxxxx >>Cc: Kalle Jokiniemi >>Subject: [PATCH 03/17] PM: Block CORE off when DSS is active >> >>From: Kalle Jokiniemi <kalle.jokiniemi@xxxxxxxxx> >> >>If CORE power domain is allowed to reach off state >>while display is active, the display will go blank. >>Fixed by adding a check in idle loop. > >What is root cause? I guess it is due to extra latency >required to wakeup from OFF? >In that case, it should be better to use the >omap_pm_set_max_dev_wakeup_lat() function and set a latency >constraint to the CORE. I believe the root cause is that if core enters off while display is doing something (between DSS data bursts for example), then when the display next wakes up and tries to access memories, core has lost its context which is rather bad. It is not really a wakeup latency issue as such. >On the other hand, I remember a discussion between Kevin and >Tomi saying that this API might not be fully functional yet. > >Regards, >Benoit > > >>Signed-off-by: Kalle Jokiniemi <ext-kalle.jokiniemi@xxxxxxxxx> >>Signed-off-by: Jouni Hogander <jouni.hogander@xxxxxxxxx> >>--- >> arch/arm/mach-omap2/pm34xx.c | 9 ++++++++- >> 1 files changed, 8 insertions(+), 1 deletions(-) >> >>diff --git a/arch/arm/mach-omap2/pm34xx.c >b/arch/arm/mach-omap2/pm34xx.c >>index e8704a6..52a3f2b 100644 >>--- a/arch/arm/mach-omap2/pm34xx.c >>+++ b/arch/arm/mach-omap2/pm34xx.c >>@@ -103,7 +103,7 @@ static int (*_omap_save_secure_sram)(u32 *addr); >> >> static struct powerdomain *mpu_pwrdm, *neon_pwrdm; >> static struct powerdomain *core_pwrdm, *per_pwrdm; >>-static struct powerdomain *cam_pwrdm, *iva2_pwrdm; >>+static struct powerdomain *cam_pwrdm, *iva2_pwrdm, *dss_pwrdm; >> >> static struct prm_setup_vc prm_setup = { >> .clksetup = 0xff, >>@@ -427,6 +427,7 @@ void omap_sram_idle(void) >> int mpu_next_state = PWRDM_POWER_ON; >> int per_next_state = PWRDM_POWER_ON; >> int core_next_state = PWRDM_POWER_ON; >>+ int dss_state = PWRDM_POWER_ON; >> int core_prev_state, per_prev_state; >> u32 sdrc_pwr = 0; >> int per_state_modified = 0; >>@@ -469,6 +470,7 @@ void omap_sram_idle(void) >> * save / restore. >> */ >> core_next_state = pwrdm_read_next_pwrst(core_pwrdm); >>+ dss_state = pwrdm_read_pwrst(dss_pwrdm); >> if (core_next_state < PWRDM_POWER_ON) { >> core_saved_state = core_next_state; >> if ((cm_read_mod_reg(CORE_MOD, CM_IDLEST1) & >CORE_IDLEST1_ALL) >>@@ -479,6 +481,10 @@ void omap_sram_idle(void) >> CORE_IDLEST3_ALL) != >CORE_IDLEST3_ALL) { >> core_next_state = PWRDM_POWER_ON; >> pwrdm_set_next_pwrst(core_pwrdm, >PWRDM_POWER_ON); >>+ } else if (core_next_state == PWRDM_POWER_OFF && >>+ dss_state == PWRDM_POWER_ON) { >>+ core_next_state = PWRDM_POWER_RET; >>+ pwrdm_set_next_pwrst(core_pwrdm, >PWRDM_POWER_RET); >> } >> } >> >>@@ -1234,6 +1240,7 @@ static int __init omap3_pm_init(void) >> core_pwrdm = pwrdm_lookup("core_pwrdm"); >> cam_pwrdm = pwrdm_lookup("cam_pwrdm"); >> iva2_pwrdm = pwrdm_lookup("iva2_pwrdm"); >>+ dss_pwrdm = pwrdm_lookup("dss_pwrdm"); >> >> omap_push_sram_idle(); >> #ifdef CONFIG_SUSPEND >>-- >>1.5.4.3 >> >>-- >>To unsubscribe from this list: send the line "unsubscribe >linux-omap" in >>the body of a message to majordomo@xxxxxxxxxxxxxxx >>More majordomo info at http://vger.kernel.org/majordomo-info.html > > >-- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html