diff options
author | Russell King <rmk@dyn-67.arm.linux.org.uk> | 2008-01-28 08:21:38 -0500 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2008-01-28 08:21:38 -0500 |
commit | 0ff66f0c7a5f1f4f5a0d91341b6f71fd2a49f0fa (patch) | |
tree | 7c4d74a76bf4f49e87d769c236fdd2db77fb241d /arch/arm/mach-pxa/standby.S | |
parent | c00d4ffdbace1bdc9fdd888e4ba6d207ffa3b679 (diff) | |
parent | 4e4fc05a2b6e7bd2e0facd96e0c18dceb34d9349 (diff) |
Merge branch 'pxa-plat' into devel
* pxa-plat: (53 commits)
[ARM] 4762/1: Basic support for Toradex Colibri module
[ARM] pxa: fix mci_init functions returning -1
[ARM] 4737/1: Refactor corgi_lcd to improve readability + bugfix
[ARM] 4747/1: pcm027: support for pcm990 baseboard for phyCORE-PXA270
[ARM] 4746/1: pcm027: network support for phyCORE-PXA270
[ARM] 4745/1: pcm027: default configuration
[ARM] 4744/1: pcm027: add support for phyCORE-PXA270 CPU module
[NET] smc91x: Make smc91x use IRQ resource trigger flags
[ARM] pxa: add default config for littleton
[ARM] pxa: add basic support for Littleton (PXA3xx Form Factor Platform)
[ARM] 4664/1: Add basic support for HTC Magician PDA phones
[ARM] 4649/1: Base support for pxa-based Toshiba e-series PDAs.
[ARM] pxa: skip registers saving/restoring if entering standby mode
[ARM] pxa: fix PXA27x resume
[ARM] pxa: Avoid fiddling with CKEN register on suspend
[ARM] pxa: Add PXA3 standby code hooked into the IRQ wake scheme
[ARM] pxa: Add zylonite MFP wakeup configurations
[ARM] pxa: program MFPs for low power mode when suspending
[ARM] pxa: make MFP configuration processor independent
[ARM] pxa: remove un-used pxa3xx_mfp_set_xxx() functions
...
Conflicts:
arch/arm/mach-pxa/ssp.c
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch/arm/mach-pxa/standby.S')
-rw-r--r-- | arch/arm/mach-pxa/standby.S | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/arch/arm/mach-pxa/standby.S b/arch/arm/mach-pxa/standby.S index d774430d02c0..167412e6bec8 100644 --- a/arch/arm/mach-pxa/standby.S +++ b/arch/arm/mach-pxa/standby.S | |||
@@ -17,6 +17,7 @@ | |||
17 | 17 | ||
18 | .text | 18 | .text |
19 | 19 | ||
20 | #ifdef CONFIG_PXA27x | ||
20 | ENTRY(pxa_cpu_standby) | 21 | ENTRY(pxa_cpu_standby) |
21 | ldr r0, =PSSR | 22 | ldr r0, =PSSR |
22 | mov r1, #(PSSR_PH | PSSR_STS) | 23 | mov r1, #(PSSR_PH | PSSR_STS) |
@@ -29,3 +30,85 @@ ENTRY(pxa_cpu_standby) | |||
29 | 1: mcr p14, 0, r2, c7, c0, 0 @ put the system into Standby | 30 | 1: mcr p14, 0, r2, c7, c0, 0 @ put the system into Standby |
30 | str r1, [r0] @ make sure PSSR_PH/STS are clear | 31 | str r1, [r0] @ make sure PSSR_PH/STS are clear |
31 | mov pc, lr | 32 | mov pc, lr |
33 | |||
34 | #endif | ||
35 | |||
36 | #ifdef CONFIG_PXA3xx | ||
37 | |||
38 | #define MDCNFG 0x0000 | ||
39 | #define MDCNFG_DMCEN (1 << 30) | ||
40 | #define DDR_HCAL 0x0060 | ||
41 | #define DDR_HCAL_HCRNG 0x1f | ||
42 | #define DDR_HCAL_HCPROG (1 << 28) | ||
43 | #define DDR_HCAL_HCEN (1 << 31) | ||
44 | #define DMCIER 0x0070 | ||
45 | #define DMCIER_EDLP (1 << 29) | ||
46 | #define DMCISR 0x0078 | ||
47 | #define RCOMP 0x0100 | ||
48 | #define RCOMP_SWEVAL (1 << 31) | ||
49 | |||
50 | ENTRY(pm_enter_standby_start) | ||
51 | mov r1, #0xf6000000 @ DMEMC_REG_BASE (MDCNFG) | ||
52 | add r1, r1, #0x00100000 | ||
53 | |||
54 | /* | ||
55 | * Preload the TLB entry for accessing the dynamic memory | ||
56 | * controller registers. Note that page table lookups will | ||
57 | * fail until the dynamic memory controller has been | ||
58 | * reinitialised - and that includes MMU page table walks. | ||
59 | * This also means that only the dynamic memory controller | ||
60 | * can be reliably accessed in the code following standby. | ||
61 | */ | ||
62 | ldr r2, [r1] @ Dummy read MDCNFG | ||
63 | |||
64 | mcr p14, 0, r0, c7, c0, 0 | ||
65 | .rept 8 | ||
66 | nop | ||
67 | .endr | ||
68 | |||
69 | ldr r0, [r1, #DDR_HCAL] @ Clear (and wait for) HCEN | ||
70 | bic r0, r0, #DDR_HCAL_HCEN | ||
71 | str r0, [r1, #DDR_HCAL] | ||
72 | 1: ldr r0, [r1, #DDR_HCAL] | ||
73 | tst r0, #DDR_HCAL_HCEN | ||
74 | bne 1b | ||
75 | |||
76 | ldr r0, [r1, #RCOMP] @ Initiate RCOMP | ||
77 | orr r0, r0, #RCOMP_SWEVAL | ||
78 | str r0, [r1, #RCOMP] | ||
79 | |||
80 | mov r0, #~0 @ Clear interrupts | ||
81 | str r0, [r1, #DMCISR] | ||
82 | |||
83 | ldr r0, [r1, #DMCIER] @ set DMIER[EDLP] | ||
84 | orr r0, r0, #DMCIER_EDLP | ||
85 | str r0, [r1, #DMCIER] | ||
86 | |||
87 | ldr r0, [r1, #DDR_HCAL] @ clear HCRNG, set HCPROG, HCEN | ||
88 | bic r0, r0, #DDR_HCAL_HCRNG | ||
89 | orr r0, r0, #DDR_HCAL_HCEN | DDR_HCAL_HCPROG | ||
90 | str r0, [r1, #DDR_HCAL] | ||
91 | |||
92 | 1: ldr r0, [r1, #DMCISR] | ||
93 | tst r0, #DMCIER_EDLP | ||
94 | beq 1b | ||
95 | |||
96 | ldr r0, [r1, #MDCNFG] @ set MDCNFG[DMCEN] | ||
97 | orr r0, r0, #MDCNFG_DMCEN | ||
98 | str r0, [r1, #MDCNFG] | ||
99 | 1: ldr r0, [r1, #MDCNFG] | ||
100 | tst r0, #MDCNFG_DMCEN | ||
101 | beq 1b | ||
102 | |||
103 | ldr r0, [r1, #DDR_HCAL] @ set DDR_HCAL[HCRNG] | ||
104 | orr r0, r0, #2 @ HCRNG | ||
105 | str r0, [r1, #DDR_HCAL] | ||
106 | |||
107 | ldr r0, [r1, #DMCIER] @ Clear the interrupt | ||
108 | bic r0, r0, #0x20000000 | ||
109 | str r0, [r1, #DMCIER] | ||
110 | |||
111 | mov pc, lr | ||
112 | ENTRY(pm_enter_standby_end) | ||
113 | |||
114 | #endif | ||