diff options
Diffstat (limited to 'arch/arm/mach-omap2/sleep34xx.S')
-rw-r--r-- | arch/arm/mach-omap2/sleep34xx.S | 220 |
1 files changed, 198 insertions, 22 deletions
diff --git a/arch/arm/mach-omap2/sleep34xx.S b/arch/arm/mach-omap2/sleep34xx.S index e5e2553e79a6..15268f8b61de 100644 --- a/arch/arm/mach-omap2/sleep34xx.S +++ b/arch/arm/mach-omap2/sleep34xx.S | |||
@@ -27,22 +27,35 @@ | |||
27 | #include <linux/linkage.h> | 27 | #include <linux/linkage.h> |
28 | #include <asm/assembler.h> | 28 | #include <asm/assembler.h> |
29 | #include <mach/io.h> | 29 | #include <mach/io.h> |
30 | #include <mach/control.h> | 30 | #include <plat/control.h> |
31 | 31 | ||
32 | #include "cm.h" | ||
32 | #include "prm.h" | 33 | #include "prm.h" |
33 | #include "sdrc.h" | 34 | #include "sdrc.h" |
34 | 35 | ||
35 | #define PM_PREPWSTST_CORE_V OMAP34XX_PRM_REGADDR(CORE_MOD, \ | 36 | #define PM_PREPWSTST_CORE_V OMAP34XX_PRM_REGADDR(CORE_MOD, \ |
36 | OMAP3430_PM_PREPWSTST) | 37 | OMAP3430_PM_PREPWSTST) |
38 | #define PM_PREPWSTST_CORE_P 0x48306AE8 | ||
37 | #define PM_PREPWSTST_MPU_V OMAP34XX_PRM_REGADDR(MPU_MOD, \ | 39 | #define PM_PREPWSTST_MPU_V OMAP34XX_PRM_REGADDR(MPU_MOD, \ |
38 | OMAP3430_PM_PREPWSTST) | 40 | OMAP3430_PM_PREPWSTST) |
39 | #define PM_PWSTCTRL_MPU_P OMAP34XX_PRM_REGADDR(MPU_MOD, PM_PWSTCTRL) | 41 | #define PM_PWSTCTRL_MPU_P OMAP3430_PRM_BASE + MPU_MOD + PM_PWSTCTRL |
42 | #define CM_IDLEST1_CORE_V OMAP34XX_CM_REGADDR(CORE_MOD, CM_IDLEST1) | ||
43 | #define SRAM_BASE_P 0x40200000 | ||
44 | #define CONTROL_STAT 0x480022F0 | ||
40 | #define SCRATCHPAD_MEM_OFFS 0x310 /* Move this as correct place is | 45 | #define SCRATCHPAD_MEM_OFFS 0x310 /* Move this as correct place is |
41 | * available */ | 46 | * available */ |
42 | #define SCRATCHPAD_BASE_P OMAP343X_CTRL_REGADDR(\ | 47 | #define SCRATCHPAD_BASE_P (OMAP343X_CTRL_BASE + OMAP343X_CONTROL_MEM_WKUP\ |
43 | OMAP343X_CONTROL_MEM_WKUP +\ | 48 | + SCRATCHPAD_MEM_OFFS) |
44 | SCRATCHPAD_MEM_OFFS) | ||
45 | #define SDRC_POWER_V OMAP34XX_SDRC_REGADDR(SDRC_POWER) | 49 | #define SDRC_POWER_V OMAP34XX_SDRC_REGADDR(SDRC_POWER) |
50 | #define SDRC_SYSCONFIG_P (OMAP343X_SDRC_BASE + SDRC_SYSCONFIG) | ||
51 | #define SDRC_MR_0_P (OMAP343X_SDRC_BASE + SDRC_MR_0) | ||
52 | #define SDRC_EMR2_0_P (OMAP343X_SDRC_BASE + SDRC_EMR2_0) | ||
53 | #define SDRC_MANUAL_0_P (OMAP343X_SDRC_BASE + SDRC_MANUAL_0) | ||
54 | #define SDRC_MR_1_P (OMAP343X_SDRC_BASE + SDRC_MR_1) | ||
55 | #define SDRC_EMR2_1_P (OMAP343X_SDRC_BASE + SDRC_EMR2_1) | ||
56 | #define SDRC_MANUAL_1_P (OMAP343X_SDRC_BASE + SDRC_MANUAL_1) | ||
57 | #define SDRC_DLLA_STATUS_V OMAP34XX_SDRC_REGADDR(SDRC_DLLA_STATUS) | ||
58 | #define SDRC_DLLA_CTRL_V OMAP34XX_SDRC_REGADDR(SDRC_DLLA_CTRL) | ||
46 | 59 | ||
47 | .text | 60 | .text |
48 | /* Function call to get the restore pointer for resume from OFF */ | 61 | /* Function call to get the restore pointer for resume from OFF */ |
@@ -51,7 +64,93 @@ ENTRY(get_restore_pointer) | |||
51 | adr r0, restore | 64 | adr r0, restore |
52 | ldmfd sp!, {pc} @ restore regs and return | 65 | ldmfd sp!, {pc} @ restore regs and return |
53 | ENTRY(get_restore_pointer_sz) | 66 | ENTRY(get_restore_pointer_sz) |
54 | .word . - get_restore_pointer_sz | 67 | .word . - get_restore_pointer |
68 | |||
69 | .text | ||
70 | /* Function call to get the restore pointer for for ES3 to resume from OFF */ | ||
71 | ENTRY(get_es3_restore_pointer) | ||
72 | stmfd sp!, {lr} @ save registers on stack | ||
73 | adr r0, restore_es3 | ||
74 | ldmfd sp!, {pc} @ restore regs and return | ||
75 | ENTRY(get_es3_restore_pointer_sz) | ||
76 | .word . - get_es3_restore_pointer | ||
77 | |||
78 | ENTRY(es3_sdrc_fix) | ||
79 | ldr r4, sdrc_syscfg @ get config addr | ||
80 | ldr r5, [r4] @ get value | ||
81 | tst r5, #0x100 @ is part access blocked | ||
82 | it eq | ||
83 | biceq r5, r5, #0x100 @ clear bit if set | ||
84 | str r5, [r4] @ write back change | ||
85 | ldr r4, sdrc_mr_0 @ get config addr | ||
86 | ldr r5, [r4] @ get value | ||
87 | str r5, [r4] @ write back change | ||
88 | ldr r4, sdrc_emr2_0 @ get config addr | ||
89 | ldr r5, [r4] @ get value | ||
90 | str r5, [r4] @ write back change | ||
91 | ldr r4, sdrc_manual_0 @ get config addr | ||
92 | mov r5, #0x2 @ autorefresh command | ||
93 | str r5, [r4] @ kick off refreshes | ||
94 | ldr r4, sdrc_mr_1 @ get config addr | ||
95 | ldr r5, [r4] @ get value | ||
96 | str r5, [r4] @ write back change | ||
97 | ldr r4, sdrc_emr2_1 @ get config addr | ||
98 | ldr r5, [r4] @ get value | ||
99 | str r5, [r4] @ write back change | ||
100 | ldr r4, sdrc_manual_1 @ get config addr | ||
101 | mov r5, #0x2 @ autorefresh command | ||
102 | str r5, [r4] @ kick off refreshes | ||
103 | bx lr | ||
104 | sdrc_syscfg: | ||
105 | .word SDRC_SYSCONFIG_P | ||
106 | sdrc_mr_0: | ||
107 | .word SDRC_MR_0_P | ||
108 | sdrc_emr2_0: | ||
109 | .word SDRC_EMR2_0_P | ||
110 | sdrc_manual_0: | ||
111 | .word SDRC_MANUAL_0_P | ||
112 | sdrc_mr_1: | ||
113 | .word SDRC_MR_1_P | ||
114 | sdrc_emr2_1: | ||
115 | .word SDRC_EMR2_1_P | ||
116 | sdrc_manual_1: | ||
117 | .word SDRC_MANUAL_1_P | ||
118 | ENTRY(es3_sdrc_fix_sz) | ||
119 | .word . - es3_sdrc_fix | ||
120 | |||
121 | /* Function to call rom code to save secure ram context */ | ||
122 | ENTRY(save_secure_ram_context) | ||
123 | stmfd sp!, {r1-r12, lr} @ save registers on stack | ||
124 | save_secure_ram_debug: | ||
125 | /* b save_secure_ram_debug */ @ enable to debug save code | ||
126 | adr r3, api_params @ r3 points to parameters | ||
127 | str r0, [r3,#0x4] @ r0 has sdram address | ||
128 | ldr r12, high_mask | ||
129 | and r3, r3, r12 | ||
130 | ldr r12, sram_phy_addr_mask | ||
131 | orr r3, r3, r12 | ||
132 | mov r0, #25 @ set service ID for PPA | ||
133 | mov r12, r0 @ copy secure service ID in r12 | ||
134 | mov r1, #0 @ set task id for ROM code in r1 | ||
135 | mov r2, #4 @ set some flags in r2, r6 | ||
136 | mov r6, #0xff | ||
137 | mcr p15, 0, r0, c7, c10, 4 @ data write barrier | ||
138 | mcr p15, 0, r0, c7, c10, 5 @ data memory barrier | ||
139 | .word 0xE1600071 @ call SMI monitor (smi #1) | ||
140 | nop | ||
141 | nop | ||
142 | nop | ||
143 | nop | ||
144 | ldmfd sp!, {r1-r12, pc} | ||
145 | sram_phy_addr_mask: | ||
146 | .word SRAM_BASE_P | ||
147 | high_mask: | ||
148 | .word 0xffff | ||
149 | api_params: | ||
150 | .word 0x4, 0x0, 0x0, 0x1, 0x1 | ||
151 | ENTRY(save_secure_ram_context_sz) | ||
152 | .word . - save_secure_ram_context | ||
153 | |||
55 | /* | 154 | /* |
56 | * Forces OMAP into idle state | 155 | * Forces OMAP into idle state |
57 | * | 156 | * |
@@ -92,11 +191,29 @@ loop: | |||
92 | nop | 191 | nop |
93 | nop | 192 | nop |
94 | nop | 193 | nop |
95 | bl i_dll_wait | 194 | bl wait_sdrc_ok |
96 | 195 | ||
97 | ldmfd sp!, {r0-r12, pc} @ restore regs and return | 196 | ldmfd sp!, {r0-r12, pc} @ restore regs and return |
197 | restore_es3: | ||
198 | /*b restore_es3*/ @ Enable to debug restore code | ||
199 | ldr r5, pm_prepwstst_core_p | ||
200 | ldr r4, [r5] | ||
201 | and r4, r4, #0x3 | ||
202 | cmp r4, #0x0 @ Check if previous power state of CORE is OFF | ||
203 | bne restore | ||
204 | adr r0, es3_sdrc_fix | ||
205 | ldr r1, sram_base | ||
206 | ldr r2, es3_sdrc_fix_sz | ||
207 | mov r2, r2, ror #2 | ||
208 | copy_to_sram: | ||
209 | ldmia r0!, {r3} @ val = *src | ||
210 | stmia r1!, {r3} @ *dst = val | ||
211 | subs r2, r2, #0x1 @ num_words-- | ||
212 | bne copy_to_sram | ||
213 | ldr r1, sram_base | ||
214 | blx r1 | ||
98 | restore: | 215 | restore: |
99 | /* b restore*/ @ Enable to debug restore code | 216 | /* b restore*/ @ Enable to debug restore code |
100 | /* Check what was the reason for mpu reset and store the reason in r9*/ | 217 | /* Check what was the reason for mpu reset and store the reason in r9*/ |
101 | /* 1 - Only L1 and logic lost */ | 218 | /* 1 - Only L1 and logic lost */ |
102 | /* 2 - Only L2 lost - In this case, we wont be here */ | 219 | /* 2 - Only L2 lost - In this case, we wont be here */ |
@@ -108,9 +225,44 @@ restore: | |||
108 | moveq r9, #0x3 @ MPU OFF => L1 and L2 lost | 225 | moveq r9, #0x3 @ MPU OFF => L1 and L2 lost |
109 | movne r9, #0x1 @ Only L1 and L2 lost => avoid L2 invalidation | 226 | movne r9, #0x1 @ Only L1 and L2 lost => avoid L2 invalidation |
110 | bne logic_l1_restore | 227 | bne logic_l1_restore |
228 | ldr r0, control_stat | ||
229 | ldr r1, [r0] | ||
230 | and r1, #0x700 | ||
231 | cmp r1, #0x300 | ||
232 | beq l2_inv_gp | ||
233 | mov r0, #40 @ set service ID for PPA | ||
234 | mov r12, r0 @ copy secure Service ID in r12 | ||
235 | mov r1, #0 @ set task id for ROM code in r1 | ||
236 | mov r2, #4 @ set some flags in r2, r6 | ||
237 | mov r6, #0xff | ||
238 | adr r3, l2_inv_api_params @ r3 points to dummy parameters | ||
239 | mcr p15, 0, r0, c7, c10, 4 @ data write barrier | ||
240 | mcr p15, 0, r0, c7, c10, 5 @ data memory barrier | ||
241 | .word 0xE1600071 @ call SMI monitor (smi #1) | ||
242 | /* Write to Aux control register to set some bits */ | ||
243 | mov r0, #42 @ set service ID for PPA | ||
244 | mov r12, r0 @ copy secure Service ID in r12 | ||
245 | mov r1, #0 @ set task id for ROM code in r1 | ||
246 | mov r2, #4 @ set some flags in r2, r6 | ||
247 | mov r6, #0xff | ||
248 | adr r3, write_aux_control_params @ r3 points to parameters | ||
249 | mcr p15, 0, r0, c7, c10, 4 @ data write barrier | ||
250 | mcr p15, 0, r0, c7, c10, 5 @ data memory barrier | ||
251 | .word 0xE1600071 @ call SMI monitor (smi #1) | ||
252 | |||
253 | b logic_l1_restore | ||
254 | l2_inv_api_params: | ||
255 | .word 0x1, 0x00 | ||
256 | write_aux_control_params: | ||
257 | .word 0x1, 0x72 | ||
258 | l2_inv_gp: | ||
111 | /* Execute smi to invalidate L2 cache */ | 259 | /* Execute smi to invalidate L2 cache */ |
112 | mov r12, #0x1 @ set up to invalide L2 | 260 | mov r12, #0x1 @ set up to invalide L2 |
113 | smi: .word 0xE1600070 @ Call SMI monitor (smieq) | 261 | smi: .word 0xE1600070 @ Call SMI monitor (smieq) |
262 | /* Write to Aux control register to set some bits */ | ||
263 | mov r0, #0x72 | ||
264 | mov r12, #0x3 | ||
265 | .word 0xE1600070 @ Call SMI monitor (smieq) | ||
114 | logic_l1_restore: | 266 | logic_l1_restore: |
115 | mov r1, #0 | 267 | mov r1, #0 |
116 | /* Invalidate all instruction caches to PoU | 268 | /* Invalidate all instruction caches to PoU |
@@ -391,33 +543,55 @@ skip_l2_inval: | |||
391 | nop | 543 | nop |
392 | nop | 544 | nop |
393 | nop | 545 | nop |
394 | bl i_dll_wait | 546 | bl wait_sdrc_ok |
395 | /* restore regs and return */ | 547 | /* restore regs and return */ |
396 | ldmfd sp!, {r0-r12, pc} | 548 | ldmfd sp!, {r0-r12, pc} |
397 | 549 | ||
398 | i_dll_wait: | 550 | /* Make sure SDRC accesses are ok */ |
399 | ldr r4, clk_stabilize_delay | 551 | wait_sdrc_ok: |
552 | ldr r4, cm_idlest1_core | ||
553 | ldr r5, [r4] | ||
554 | and r5, r5, #0x2 | ||
555 | cmp r5, #0 | ||
556 | bne wait_sdrc_ok | ||
557 | ldr r4, sdrc_power | ||
558 | ldr r5, [r4] | ||
559 | bic r5, r5, #0x40 | ||
560 | str r5, [r4] | ||
561 | wait_dll_lock: | ||
562 | /* Is dll in lock mode? */ | ||
563 | ldr r4, sdrc_dlla_ctrl | ||
564 | ldr r5, [r4] | ||
565 | tst r5, #0x4 | ||
566 | bxne lr | ||
567 | /* wait till dll locks */ | ||
568 | ldr r4, sdrc_dlla_status | ||
569 | ldr r5, [r4] | ||
570 | and r5, r5, #0x4 | ||
571 | cmp r5, #0x4 | ||
572 | bne wait_dll_lock | ||
573 | bx lr | ||
400 | 574 | ||
401 | i_dll_delay: | 575 | cm_idlest1_core: |
402 | subs r4, r4, #0x1 | 576 | .word CM_IDLEST1_CORE_V |
403 | bne i_dll_delay | 577 | sdrc_dlla_status: |
404 | ldr r4, sdrc_power | 578 | .word SDRC_DLLA_STATUS_V |
405 | ldr r5, [r4] | 579 | sdrc_dlla_ctrl: |
406 | bic r5, r5, #0x40 | 580 | .word SDRC_DLLA_CTRL_V |
407 | str r5, [r4] | ||
408 | bx lr | ||
409 | pm_prepwstst_core: | 581 | pm_prepwstst_core: |
410 | .word PM_PREPWSTST_CORE_V | 582 | .word PM_PREPWSTST_CORE_V |
583 | pm_prepwstst_core_p: | ||
584 | .word PM_PREPWSTST_CORE_P | ||
411 | pm_prepwstst_mpu: | 585 | pm_prepwstst_mpu: |
412 | .word PM_PREPWSTST_MPU_V | 586 | .word PM_PREPWSTST_MPU_V |
413 | pm_pwstctrl_mpu: | 587 | pm_pwstctrl_mpu: |
414 | .word PM_PWSTCTRL_MPU_P | 588 | .word PM_PWSTCTRL_MPU_P |
415 | scratchpad_base: | 589 | scratchpad_base: |
416 | .word SCRATCHPAD_BASE_P | 590 | .word SCRATCHPAD_BASE_P |
591 | sram_base: | ||
592 | .word SRAM_BASE_P + 0x8000 | ||
417 | sdrc_power: | 593 | sdrc_power: |
418 | .word SDRC_POWER_V | 594 | .word SDRC_POWER_V |
419 | context_mem: | ||
420 | .word 0x803E3E14 | ||
421 | clk_stabilize_delay: | 595 | clk_stabilize_delay: |
422 | .word 0x000001FF | 596 | .word 0x000001FF |
423 | assoc_mask: | 597 | assoc_mask: |
@@ -432,5 +606,7 @@ table_entry: | |||
432 | .word 0x00000C02 | 606 | .word 0x00000C02 |
433 | cache_pred_disable_mask: | 607 | cache_pred_disable_mask: |
434 | .word 0xFFFFE7FB | 608 | .word 0xFFFFE7FB |
609 | control_stat: | ||
610 | .word CONTROL_STAT | ||
435 | ENTRY(omap34xx_cpu_suspend_sz) | 611 | ENTRY(omap34xx_cpu_suspend_sz) |
436 | .word . - omap34xx_cpu_suspend | 612 | .word . - omap34xx_cpu_suspend |