blob: 5faba7a3c95f6e74393699045aa0635331459d46 [file] [log] [blame]
Shawn Guoa1f1c7e2011-09-06 15:08:40 +08001/*
2 * Copyright 2011 Freescale Semiconductor, Inc.
3 * Copyright 2011 Linaro Ltd.
4 *
5 * The code contained herein is licensed under the GNU General Public
6 * License. You may obtain a copy of the GNU General Public License
7 * Version 2 or later at the following locations:
8 *
9 * http://www.opensource.org/licenses/gpl-license.html
10 * http://www.gnu.org/copyleft/gpl.html
11 */
12
13#include <linux/init.h>
14#include <linux/io.h>
15#include <linux/of.h>
16#include <linux/suspend.h>
17#include <asm/cacheflush.h>
18#include <asm/proc-fns.h>
19#include <asm/suspend.h>
20#include <asm/hardware/cache-l2x0.h>
Shawn Guoa1f1c7e2011-09-06 15:08:40 +080021
Shawn Guoe3372472012-09-13 21:01:00 +080022#include "common.h"
Shawn Guo50f2de62012-09-14 14:14:45 +080023#include "hardware.h"
Shawn Guoe3372472012-09-13 21:01:00 +080024
Shawn Guoa1f1c7e2011-09-06 15:08:40 +080025static int imx6q_suspend_finish(unsigned long val)
26{
27 cpu_do_idle();
28 return 0;
29}
30
31static int imx6q_pm_enter(suspend_state_t state)
32{
33 switch (state) {
34 case PM_SUSPEND_MEM:
35 imx6q_set_lpm(STOP_POWER_OFF);
36 imx_gpc_pre_suspend();
37 imx_set_cpu_jump(0, v7_cpu_resume);
38 /* Zzz ... */
39 cpu_suspend(0, imx6q_suspend_finish);
40 imx_smp_prepare();
41 imx_gpc_post_resume();
Shawn Guo83ae20982013-01-14 21:11:10 +080042 imx6q_set_lpm(WAIT_CLOCKED);
Shawn Guoa1f1c7e2011-09-06 15:08:40 +080043 break;
44 default:
45 return -EINVAL;
46 }
47
48 return 0;
49}
50
51static const struct platform_suspend_ops imx6q_pm_ops = {
52 .enter = imx6q_pm_enter,
53 .valid = suspend_valid_only_mem,
54};
55
56void __init imx6q_pm_init(void)
57{
Shawn Guoa1f1c7e2011-09-06 15:08:40 +080058 suspend_set_ops(&imx6q_pm_ops);
59}