blob: 237e8aa9fe8378e584590a96bb294300574352aa [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
Fabio Estevamd54debc2020-09-16 21:41:16 -030010#include <linux/of_address.h>
Eric Bénardf42ae0e2010-06-01 21:57:44 +020011#include <linux/kernel.h>
12#include <linux/suspend.h>
13#include <linux/io.h>
Shawn Guo50f2de62012-09-14 14:14:45 +080014
Fabio Estevam779b56b2021-05-08 13:03:19 -030015#include "common.h"
Shawn Guo50f2de62012-09-14 14:14:45 +080016#include "hardware.h"
Eric Bénardf42ae0e2010-06-01 21:57:44 +020017
18static int mx27_suspend_enter(suspend_state_t state)
19{
Fabio Estevamd54debc2020-09-16 21:41:16 -030020 void __iomem *ccm_base;
21 struct device_node *np;
Eric Bénardf42ae0e2010-06-01 21:57:44 +020022 u32 cscr;
Fabio Estevamd54debc2020-09-16 21:41:16 -030023
24 np = of_find_compatible_node(NULL, NULL, "fsl,imx27-ccm");
25 ccm_base = of_iomap(np, 0);
26 BUG_ON(!ccm_base);
27
Eric Bénardf42ae0e2010-06-01 21:57:44 +020028 switch (state) {
29 case PM_SUSPEND_MEM:
30 /* Clear MPEN and SPEN to disable MPLL/SPLL */
Fabio Estevamd54debc2020-09-16 21:41:16 -030031 cscr = imx_readl(ccm_base);
Eric Bénardf42ae0e2010-06-01 21:57:44 +020032 cscr &= 0xFFFFFFFC;
Fabio Estevamd54debc2020-09-16 21:41:16 -030033 imx_writel(cscr, ccm_base);
Eric Bénardf42ae0e2010-06-01 21:57:44 +020034 /* Executes WFI */
Nicolas Pitre4a3ea242011-08-03 11:34:59 -040035 cpu_do_idle();
Eric Bénardf42ae0e2010-06-01 21:57:44 +020036 break;
37
38 default:
39 return -EINVAL;
40 }
41 return 0;
42}
43
Lionel Debroux2f55ac02010-11-16 14:14:02 +010044static const struct platform_suspend_ops mx27_suspend_ops = {
Eric Bénardf42ae0e2010-06-01 21:57:44 +020045 .enter = mx27_suspend_enter,
46 .valid = suspend_valid_only_mem,
47};
48
Arnd Bergmann48e076d2016-06-28 10:22:16 +080049void __init imx27_pm_init(void)
Eric Bénardf42ae0e2010-06-01 21:57:44 +020050{
Eric Bénardf42ae0e2010-06-01 21:57:44 +020051 suspend_set_ops(&mx27_suspend_ops);
Eric Bénardf42ae0e2010-06-01 21:57:44 +020052}