]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
ENGR00222257 MX6x-Prime TLB entries before DDR enters self-refresh.
authorRanjani Vaidyanathan <ra5478@freescale.com>
Sat, 1 Sep 2012 07:06:39 +0000 (02:06 -0500)
committerLothar Waßmann <LW@KARO-electronics.de>
Fri, 24 May 2013 06:35:21 +0000 (08:35 +0200)
Need to ensure that no page table walk occurs in DDR when it is in
self refresh and its IO pads are floated during suspend.
Hence we need to make sure that the translation of all the
addresses that the suspend code will access is in the TLB before
DDR cannot be accessed anymore.
So do a dummy read of IOMUX, MMDC, SRC and ANATOP regsiters.
Also need to add a dsb to drain all the write buffers before
DDR enters self-refresh.

Also ensure that the LDO bypass enable is reset if an interrupt
is pending before the system enters suspend.

Signed-off-by: Ranjani Vaidyanathan <ra5478@freescale.com>
arch/arm/mach-mx6/mx6_suspend.S

index a9b7e30cd85a81efe950721fe87ffa071ba8da55..0b9dc57b009136553a6bd0d9f797e3e7bc6fe036 100644 (file)
@@ -777,6 +777,22 @@ ddr_io_save_done:
 /****************************************************************
 set ddr iomux to low power mode
 ****************************************************************/
+       /* Make sure TLBs are primed. */
+       ldr     r1,  =MX6Q_IOMUXC_BASE_ADDR
+       add     r1, r1, #PERIPBASE_VIRT
+       ldr     r0, [r1]
+       ldr     r1, =SRC_BASE_ADDR
+       add     r1, r1, #PERIPBASE_VIRT
+       ldr     r0, [r1]
+#ifdef CONFIG_MX6_INTER_LDO_BYPASS
+       ldr     r1, =ANATOP_BASE_ADDR
+       add     r1, r1, #PERIPBASE_VIRT
+       ldr     r0, [r1]
+#endif
+
+       /* Do a DSB to drain the buffers. */
+       dsb
+
        ldr     r1, =MMDC_P0_BASE_ADDR
        add     r1, r1, #PERIPBASE_VIRT
        ldr     r0, [r1, #MMDC_MAPSR_OFFSET]
@@ -817,12 +833,12 @@ save resume pointer into SRC_GPR1
        add     r1, r1, #PERIPBASE_VIRT
        str     r3, [r1, #SRC_GPR1_OFFSET]
 #ifdef CONFIG_MX6_INTER_LDO_BYPASS
-       ldr     r1, =0x20c8140
+       ldr     r1, =ANATOP_BASE_ADDR
        add     r1, r1, #PERIPBASE_VIRT
-       ldr     r3, [r1]
+       ldr     r3, [r1, #0x140]
        bic     r3, r3, #0x1f
        orr     r3, r3, #0x1e
-       str     r3, [r1]
+       str     r3, [r1, #0x140]
 #endif
 /****************************************************************
 execute a wfi instruction to let SOC go into stop mode.
@@ -838,6 +854,14 @@ execute a wfi instruction to let SOC go into stop mode.
 if go here, means there is a wakeup irq pending, we should resume
 system immediately.
 ****************************************************************/
+#ifdef CONFIG_MX6_INTER_LDO_BYPASS
+       ldr     r1, =ANATOP_BASE_ADDR
+       add     r1, r1, #PERIPBASE_VIRT
+       ldr     r3, [r1, #0x140]
+       orr     r3, r3, #0x1f
+       str     r3, [r1, #0x140]
+#endif
+
        mov     r0, r2          /* get suspend_iram_base */
        add     r0, r0, #IRAM_SUSPEND_SIZE      /* 4K */
 
@@ -873,10 +897,10 @@ are running with MMU off.
 ****************************************************************/
 resume:
 #ifdef CONFIG_MX6_INTER_LDO_BYPASS
-       ldr     r1, =0x20c8140
-       ldr     r3, [r1]
+       ldr     r1, =ANATOP_BASE_ADDR
+       ldr     r3, [r1, #0x140]
        orr     r3, r3, #0x1f
-       str     r3, [r1]
+       str     r3, [r1, #0x140]
 #endif
        /* Invalidate L1 I-cache first */
        mov     r1,     #0x0