From 5d1646d90e1f2cceb9f0828f4b28318cd0ec7744 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sat, 27 Apr 2024 12:05:51 +0200 Subject: Adding upstream version 5.10.209. Signed-off-by: Daniel Baumann --- arch/arm/mach-imx/pm-imx27.c | 51 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100644 arch/arm/mach-imx/pm-imx27.c (limited to 'arch/arm/mach-imx/pm-imx27.c') diff --git a/arch/arm/mach-imx/pm-imx27.c b/arch/arm/mach-imx/pm-imx27.c new file mode 100644 index 000000000..020e6deb6 --- /dev/null +++ b/arch/arm/mach-imx/pm-imx27.c @@ -0,0 +1,51 @@ +/* + * i.MX27 Power Management Routines + * + * Based on Freescale's BSP + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License. + */ + +#include +#include +#include +#include + +#include "hardware.h" + +static int mx27_suspend_enter(suspend_state_t state) +{ + void __iomem *ccm_base; + struct device_node *np; + u32 cscr; + + np = of_find_compatible_node(NULL, NULL, "fsl,imx27-ccm"); + ccm_base = of_iomap(np, 0); + BUG_ON(!ccm_base); + + switch (state) { + case PM_SUSPEND_MEM: + /* Clear MPEN and SPEN to disable MPLL/SPLL */ + cscr = imx_readl(ccm_base); + cscr &= 0xFFFFFFFC; + imx_writel(cscr, ccm_base); + /* Executes WFI */ + cpu_do_idle(); + break; + + default: + return -EINVAL; + } + return 0; +} + +static const struct platform_suspend_ops mx27_suspend_ops = { + .enter = mx27_suspend_enter, + .valid = suspend_valid_only_mem, +}; + +void __init imx27_pm_init(void) +{ + suspend_set_ops(&mx27_suspend_ops); +} -- cgit v1.2.3