| /* | 
|  * 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 <linux/kernel.h> | 
| #include <linux/suspend.h> | 
| #include <linux/io.h> | 
|   | 
| #include "hardware.h" | 
|   | 
| static int mx27_suspend_enter(suspend_state_t state) | 
| { | 
|     u32 cscr; | 
|     switch (state) { | 
|     case PM_SUSPEND_MEM: | 
|         /* Clear MPEN and SPEN to disable MPLL/SPLL */ | 
|         cscr = imx_readl(MX27_IO_ADDRESS(MX27_CCM_BASE_ADDR)); | 
|         cscr &= 0xFFFFFFFC; | 
|         imx_writel(cscr, MX27_IO_ADDRESS(MX27_CCM_BASE_ADDR)); | 
|         /* 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); | 
| } |