blob: 6fcffa7db978d4b025bf6eed72ea4b0b99c417c7 [file] [log] [blame]
Eric Bénardf42ae0e2010-06-01 21:57:44 +02001/*
2 * i.MX27 Power Management Routines
3 *
4 * Based on Freescale's BSP
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License.
8 */
9
10#include <linux/kernel.h>
11#include <linux/suspend.h>
12#include <linux/io.h>
Shawn Guo41e7daf2011-09-28 17:16:06 +080013#include <mach/hardware.h>
Eric Bénardf42ae0e2010-06-01 21:57:44 +020014
15static int mx27_suspend_enter(suspend_state_t state)
16{
17 u32 cscr;
18 switch (state) {
19 case PM_SUSPEND_MEM:
20 /* Clear MPEN and SPEN to disable MPLL/SPLL */
21 cscr = __raw_readl(MX27_IO_ADDRESS(MX27_CCM_BASE_ADDR));
22 cscr &= 0xFFFFFFFC;
23 __raw_writel(cscr, MX27_IO_ADDRESS(MX27_CCM_BASE_ADDR));
24 /* Executes WFI */
Nicolas Pitre4a3ea242011-08-03 11:34:59 -040025 cpu_do_idle();
Eric Bénardf42ae0e2010-06-01 21:57:44 +020026 break;
27
28 default:
29 return -EINVAL;
30 }
31 return 0;
32}
33
Lionel Debroux2f55ac02010-11-16 14:14:02 +010034static const struct platform_suspend_ops mx27_suspend_ops = {
Eric Bénardf42ae0e2010-06-01 21:57:44 +020035 .enter = mx27_suspend_enter,
36 .valid = suspend_valid_only_mem,
37};
38
39static int __init mx27_pm_init(void)
40{
Sascha Hauer76586d32010-11-04 23:09:18 +010041 if (!cpu_is_mx27())
42 return 0;
43
Eric Bénardf42ae0e2010-06-01 21:57:44 +020044 suspend_set_ops(&mx27_suspend_ops);
45 return 0;
46}
47
48device_initcall(mx27_pm_init);