diff options
author | Tomasz Figa <t.figa@samsung.com> | 2014-03-17 18:28:09 -0400 |
---|---|---|
committer | Kukjin Kim <kgene.kim@samsung.com> | 2014-03-20 15:04:42 -0400 |
commit | 61557b8bac9c80a5c14d237d420c246703e5c2e2 (patch) | |
tree | 8d6ea839f96309abd1f453896f8ec7a46af7fdaf | |
parent | 8460dc7f2777d564b4cf094721e9de6e6657e11c (diff) |
ARM: EXYNOS: Do not resume l2x0 if not enabled before suspend
Trying to resume l2x0 if it was not enabled before suspend leads to
system crash. This patch prevents this by checking if l2x0_regs_phys is
a valid pointer to l2x0 context data saved on initialization.
Signed-off-by: Tomasz Figa <t.figa@samsung.com>
Acked-by: Kyungmin Park <kyungmin.park@samsung.com>
Signed-off-by: Kukjin Kim <kgene.kim@samsung.com>
-rw-r--r-- | arch/arm/plat-samsung/s5p-sleep.S | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/arch/arm/plat-samsung/s5p-sleep.S b/arch/arm/plat-samsung/s5p-sleep.S index a030e7301da8..20764bd5518e 100644 --- a/arch/arm/plat-samsung/s5p-sleep.S +++ b/arch/arm/plat-samsung/s5p-sleep.S | |||
@@ -59,13 +59,15 @@ ENTRY(s3c_cpu_resume) | |||
59 | and r0, r0, r1 | 59 | and r0, r0, r1 |
60 | ldr r1, =CPU_CORTEX_A9 | 60 | ldr r1, =CPU_CORTEX_A9 |
61 | cmp r0, r1 | 61 | cmp r0, r1 |
62 | bne resume_l2on | 62 | bne skip_l2_resume |
63 | adr r0, l2x0_regs_phys | 63 | adr r0, l2x0_regs_phys |
64 | ldr r0, [r0] | 64 | ldr r0, [r0] |
65 | cmp r0, #0 | ||
66 | beq skip_l2_resume | ||
65 | ldr r1, [r0, #L2X0_R_PHY_BASE] | 67 | ldr r1, [r0, #L2X0_R_PHY_BASE] |
66 | ldr r2, [r1, #L2X0_CTRL] | 68 | ldr r2, [r1, #L2X0_CTRL] |
67 | tst r2, #0x1 | 69 | tst r2, #0x1 |
68 | bne resume_l2on | 70 | bne skip_l2_resume |
69 | ldr r2, [r0, #L2X0_R_AUX_CTRL] | 71 | ldr r2, [r0, #L2X0_R_AUX_CTRL] |
70 | str r2, [r1, #L2X0_AUX_CTRL] | 72 | str r2, [r1, #L2X0_AUX_CTRL] |
71 | ldr r2, [r0, #L2X0_R_TAG_LATENCY] | 73 | ldr r2, [r0, #L2X0_R_TAG_LATENCY] |
@@ -78,7 +80,7 @@ ENTRY(s3c_cpu_resume) | |||
78 | str r2, [r1, #L2X0_POWER_CTRL] | 80 | str r2, [r1, #L2X0_POWER_CTRL] |
79 | mov r2, #1 | 81 | mov r2, #1 |
80 | str r2, [r1, #L2X0_CTRL] | 82 | str r2, [r1, #L2X0_CTRL] |
81 | resume_l2on: | 83 | skip_l2_resume: |
82 | #endif | 84 | #endif |
83 | b cpu_resume | 85 | b cpu_resume |
84 | ENDPROC(s3c_cpu_resume) | 86 | ENDPROC(s3c_cpu_resume) |