Merge branch 'next' of git://git.kernel.org/pub/scm/linux/kernel/git/davej/cpufreq
[pandora-kernel.git] / arch / blackfin / mach-common / dpmc_modes.S
index 2d1c3ce..1c534d2 100644 (file)
@@ -196,21 +196,20 @@ ENTRY(_set_dram_srfs)
 #else                          /* SDRAM */
        P0.L = lo(EBIU_SDGCTL);
        P0.H = hi(EBIU_SDGCTL);
+       P1.L = lo(EBIU_SDSTAT);
+       P1.H = hi(EBIU_SDSTAT);
+
        R2 = [P0];
        BITSET(R2, 24); /* SRFS enter self-refresh mode */
        [P0] = R2;
        SSYNC;
 
-       P0.L = lo(EBIU_SDSTAT);
-       P0.H = hi(EBIU_SDSTAT);
 1:
-       R2 = w[P0];
+       R2 = w[P1];
        SSYNC;
        cc = BITTST(R2, 1); /* SDSRA poll self-refresh status */
        if !cc jump 1b;
 
-       P0.L = lo(EBIU_SDGCTL);
-       P0.H = hi(EBIU_SDGCTL);
        R2 = [P0];
        BITCLR(R2, 0); /* SCTLE disable CLKOUT */
        [P0] = R2;
@@ -220,6 +219,7 @@ ENDPROC(_set_dram_srfs)
 
 ENTRY(_unset_dram_srfs)
        /*  set the dram out of self refresh mode */
+
 #if defined(EBIU_RSTCTL)       /* DDR */
        P0.H = hi(EBIU_RSTCTL);
        P0.L = lo(EBIU_RSTCTL);
@@ -227,20 +227,21 @@ ENTRY(_unset_dram_srfs)
        BITCLR(R2, 3); /* clear SRREQ bit */
        [P0] = R2;
 #elif defined(EBIU_SDGCTL)     /* SDRAM */
-
-       P0.L = lo(EBIU_SDGCTL); /* release CLKOUT from self-refresh */
+       /* release CLKOUT from self-refresh */
+       P0.L = lo(EBIU_SDGCTL);
        P0.H = hi(EBIU_SDGCTL);
+
        R2 = [P0];
        BITSET(R2, 0); /* SCTLE enable CLKOUT */
        [P0] = R2
        SSYNC;
 
-       P0.L = lo(EBIU_SDGCTL); /* release SDRAM from self-refresh */
-       P0.H = hi(EBIU_SDGCTL);
+       /* release SDRAM from self-refresh */
        R2 = [P0];
        BITCLR(R2, 24); /* clear SRFS bit */
        [P0] = R2
 #endif
+
        SSYNC;
        RTS;
 ENDPROC(_unset_dram_srfs)