| 
									
										
										
										
											2010-06-01 21:57:44 +02:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * 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>
 | 
					
						
							| 
									
										
										
										
											2012-09-14 14:14:45 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "hardware.h"
 | 
					
						
							| 
									
										
										
										
											2010-06-01 21:57:44 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 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 = __raw_readl(MX27_IO_ADDRESS(MX27_CCM_BASE_ADDR)); | 
					
						
							|  |  |  | 		cscr &= 0xFFFFFFFC; | 
					
						
							|  |  |  | 		__raw_writel(cscr, MX27_IO_ADDRESS(MX27_CCM_BASE_ADDR)); | 
					
						
							|  |  |  | 		/* Executes WFI */ | 
					
						
							| 
									
										
										
										
											2011-08-03 11:34:59 -04:00
										 |  |  | 		cpu_do_idle(); | 
					
						
							| 
									
										
										
										
											2010-06-01 21:57:44 +02:00
										 |  |  | 		break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	default: | 
					
						
							|  |  |  | 		return -EINVAL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-16 14:14:02 +01:00
										 |  |  | static const struct platform_suspend_ops mx27_suspend_ops = { | 
					
						
							| 
									
										
										
										
											2010-06-01 21:57:44 +02:00
										 |  |  | 	.enter = mx27_suspend_enter, | 
					
						
							|  |  |  | 	.valid = suspend_valid_only_mem, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int __init mx27_pm_init(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-11-04 23:09:18 +01:00
										 |  |  | 	if (!cpu_is_mx27()) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-01 21:57:44 +02:00
										 |  |  | 	suspend_set_ops(&mx27_suspend_ops); | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | device_initcall(mx27_pm_init); |