Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input
[cascardo/linux.git] / arch / arm / mach-shmobile / sleep-sh7372.S
1 /*
2  * sh7372 lowlevel sleep code for "Core Standby Mode"
3  *
4  * Copyright (C) 2011 Magnus Damm
5  *
6  * In "Core Standby Mode" the ARM core is off, but L2 cache is still on
7  *
8  * Based on mach-omap2/sleep34xx.S
9  *
10  * (C) Copyright 2007 Texas Instruments
11  * Karthik Dasu <karthik-dp@ti.com>
12  *
13  * (C) Copyright 2004 Texas Instruments, <www.ti.com>
14  * Richard Woodruff <r-woodruff2@ti.com>
15  *
16  * This program is free software; you can redistribute it and/or
17  * modify it under the terms of the GNU General Public License as
18  * published by the Free Software Foundation; either version 2 of
19  * the License, or (at your option) any later version.
20  *
21  * This program is distributed in the hope that it will be useful,
22  * but WITHOUT ANY WARRANTY; without even the implied warranty of
23  * MERCHANTABILITY or FITNESS FOR A PARTICULAR /PURPOSE.  See the
24  * GNU General Public License for more details.
25  *
26  * You should have received a copy of the GNU General Public License
27  * along with this program; if not, write to the Free Software
28  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
29  * MA 02111-1307 USA
30  */
31
32 #include <linux/linkage.h>
33 #include <linux/init.h>
34 #include <asm/memory.h>
35 #include <asm/assembler.h>
36
37 #if defined(CONFIG_SUSPEND) || defined(CONFIG_CPU_IDLE)
38         .align  12
39         .text
40         .global sh7372_resume_core_standby_sysc
41 sh7372_resume_core_standby_sysc:
42         ldr     pc, 1f
43
44         .align  2
45         .globl  sh7372_cpu_resume
46 sh7372_cpu_resume:
47 1:      .space  4
48
49 #define SPDCR 0xe6180008
50
51         /* A3SM & A4S power down */
52         .global sh7372_do_idle_sysc
53 sh7372_do_idle_sysc:
54         mov     r8, r0 /* sleep mode passed in r0 */
55
56         /*
57          * Clear the SCTLR.C bit to prevent further data cache
58          * allocation. Clearing SCTLR.C would make all the data accesses
59          * strongly ordered and would not hit the cache.
60          */
61         mrc     p15, 0, r0, c1, c0, 0
62         bic     r0, r0, #(1 << 2)       @ Disable the C bit
63         mcr     p15, 0, r0, c1, c0, 0
64         isb
65
66         /*
67          * Clean and invalidate data cache again.
68          */
69         ldr     r1, kernel_flush
70         blx     r1
71
72         /* disable L2 cache in the aux control register */
73         mrc     p15, 0, r10, c1, c0, 1
74         bic     r10, r10, #2
75         mcr     p15, 0, r10, c1, c0, 1
76         isb
77
78         /*
79          * The kernel doesn't interwork: v7_flush_dcache_all in particluar will
80          * always return in Thumb state when CONFIG_THUMB2_KERNEL is enabled.
81          * This sequence switches back to ARM.  Note that .align may insert a
82          * nop: bx pc needs to be word-aligned in order to work.
83          */
84  THUMB( .thumb          )
85  THUMB( .align          )
86  THUMB( bx      pc      )
87  THUMB( nop             )
88         .arm
89
90         /* Data memory barrier and Data sync barrier */
91         dsb
92         dmb
93
94         /* SYSC power down */
95         ldr     r0, =SPDCR
96         str     r8, [r0]
97 1:
98         b      1b
99
100         .align  2
101 kernel_flush:
102         .word v7_flush_dcache_all
103 #endif