Hi, Nishanth Menon What would happen without this patch? L2 data corruption after back from OFF mode? -- Best Regards Hu Tao On Tue, Nov 30, 2010 at 4:19 AM, Nishanth Menon <nm@xxxxxx> wrote: > From: Peter 'p2' De Schrijver <peter.de-schrijver@xxxxxxxxx> > > This disables L2 cache before invalidating it and reenables it afterwards. > This is be done according to ARM documentation. Currently this is identified > as being needed on OMAP3630 as the disable/enable is done from "public side" > while, on OMAP3430, this is done in the "secure side". > > [nm@xxxxxx: ported to 2.6.37-rc2, added hooks to enable the logic only on 3630] > Signed-off-by: Nishanth Menon <nm@xxxxxx> > Signed-off-by: Eduardo Valentin <eduardo.valentin@xxxxxxxxx> > Signed-off-by: Peter 'p2' De Schrijver <peter.de-schrijver@xxxxxxxxx> > --- > v2: rebased out to this series independent of HS bugfixes > v1: http://marc.info/?l=linux-omap&m=129013171125204&w=2 > > arch/arm/mach-omap2/pm.h | 6 ++++++ > arch/arm/mach-omap2/pm34xx.c | 3 +++ > arch/arm/mach-omap2/sleep34xx.S | 30 ++++++++++++++++++++++++++++++ > 3 files changed, 39 insertions(+), 0 deletions(-) > > diff --git a/arch/arm/mach-omap2/pm.h b/arch/arm/mach-omap2/pm.h > index 0d75bfd..aff39d0 100644 > --- a/arch/arm/mach-omap2/pm.h > +++ b/arch/arm/mach-omap2/pm.h > @@ -85,4 +85,10 @@ extern unsigned int save_secure_ram_context_sz; > extern unsigned int omap24xx_cpu_suspend_sz; > extern unsigned int omap34xx_cpu_suspend_sz; > > +#if defined(CONFIG_PM) > +extern void enable_omap3630_toggle_l2_on_restore(void); > +#else > +static inline void enable_omap3630_toggle_l2_on_restore(void) { } > +#endif > + > #endif > diff --git a/arch/arm/mach-omap2/pm34xx.c b/arch/arm/mach-omap2/pm34xx.c > index bd426cc..e0ade5f 100644 > --- a/arch/arm/mach-omap2/pm34xx.c > +++ b/arch/arm/mach-omap2/pm34xx.c > @@ -988,6 +988,9 @@ static void pm_errata_configure(void) > if (cpu_is_omap34xx()) { > if (cpu_is_omap3630()) > pm34xx_errata |= RTA_ERRATUM_i608; > + /* Enable the l2 cache toggling in sleep logic */ > + if (cpu_is_omap3630()) > + enable_omap3630_toggle_l2_on_restore(); > } > } > > diff --git a/arch/arm/mach-omap2/sleep34xx.S b/arch/arm/mach-omap2/sleep34xx.S > index cc3507b..d2eda01 100644 > --- a/arch/arm/mach-omap2/sleep34xx.S > +++ b/arch/arm/mach-omap2/sleep34xx.S > @@ -111,6 +111,19 @@ ENTRY(get_omap3630_restore_pointer_sz) > .word . - get_omap3630_restore_pointer > > .text > +/* > + * L2 cache needs to be toggled for stable OFF mode functionality on 3630. > + * This function sets up a fflag that will allow for this toggling to take > + * place on 3630. Hopefully some version in the future maynot need this > + */ > +ENTRY(enable_omap3630_toggle_l2_on_restore) > + stmfd sp!, {lr} @ save registers on stack > + /* Setup so that we will disable and enable l2 */ > + mov r1, #0x1 > + str r1, l2dis_3630 > + ldmfd sp!, {pc} @ restore regs and return > + > + .text > /* Function call to get the restore pointer for for ES3 to resume from OFF */ > ENTRY(get_es3_restore_pointer) > stmfd sp!, {lr} @ save registers on stack > @@ -283,6 +296,14 @@ restore: > moveq r9, #0x3 @ MPU OFF => L1 and L2 lost > movne r9, #0x1 @ Only L1 and L2 lost => avoid L2 invalidation > bne logic_l1_restore > + > + ldr r0, l2dis_3630 > + cmp r0, #0x1 @ should we disable L2 on 3630? > + bne skipl2dis > + mrc p15, 0, r0, c1, c0, 1 > + bic r0, r0, #2 @ disable L2 cache > + mcr p15, 0, r0, c1, c0, 1 > +skipl2dis: > ldr r0, control_stat > ldr r1, [r0] > and r1, #0x700 > @@ -343,6 +364,13 @@ smi: .word 0xE1600070 @ Call SMI monitor (smieq) > mov r12, #0x2 > .word 0xE1600070 @ Call SMI monitor (smieq) > logic_l1_restore: > + ldr r1, l2dis_3630 > + cmp r1, #0x1 @ Do we need to re-enable L2 on 3630? > + bne skipl2reen > + mrc p15, 0, r1, c1, c0, 1 > + orr r1, r1, #2 @ re-enable L2 cache > + mcr p15, 0, r1, c1, c0, 1 > +skipl2reen: > mov r1, #0 > /* Invalidate all instruction caches to PoU > * and flush branch target cache */ > @@ -678,6 +706,8 @@ control_mem_rta: > .word CONTROL_MEM_RTA_CTRL > kernel_flush: > .word v7_flush_dcache_all > +l2dis_3630: > + .word 0 > /* these 2 words need to be at the end !!! */ > kick_counter: > .word 0 > -- > 1.6.3.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