| 
									
										
										
										
											2010-11-04 10:09:10 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Copyright (C) 2010 Pengutronix | 
					
						
							|  |  |  |  * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or modify it under | 
					
						
							|  |  |  |  * the terms of the GNU General Public License version 2 as published by the | 
					
						
							|  |  |  |  * Free Software Foundation. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #include <asm/sizes.h>
 | 
					
						
							| 
									
										
										
										
											2012-09-14 14:14:45 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "../hardware.h"
 | 
					
						
							| 
									
										
										
										
											2012-09-13 15:51:15 +08:00
										 |  |  | #include "devices-common.h"
 | 
					
						
							| 
									
										
										
										
											2010-11-04 10:09:10 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-06 16:38:32 -02:00
										 |  |  | #define imx_imx2_wdt_data_entry_single(soc, _id, _hwid, _size)		\
 | 
					
						
							| 
									
										
										
										
											2010-11-04 10:09:10 +01:00
										 |  |  | 	{								\ | 
					
						
							| 
									
										
										
										
											2010-12-06 16:38:32 -02:00
										 |  |  | 		.id = _id,						\ | 
					
						
							|  |  |  | 		.iobase = soc ## _WDOG ## _hwid ## _BASE_ADDR,		\ | 
					
						
							| 
									
										
										
										
											2010-11-11 16:58:50 +01:00
										 |  |  | 		.iosize = _size,					\ | 
					
						
							| 
									
										
										
										
											2010-11-04 10:09:10 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-12-06 16:38:32 -02:00
										 |  |  | #define imx_imx2_wdt_data_entry(soc, _id, _hwid, _size)			\
 | 
					
						
							|  |  |  | 	[_id] = imx_imx2_wdt_data_entry_single(soc, _id, _hwid, _size) | 
					
						
							| 
									
										
										
										
											2010-11-04 10:09:10 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef CONFIG_SOC_IMX21
 | 
					
						
							|  |  |  | const struct imx_imx2_wdt_data imx21_imx2_wdt_data __initconst = | 
					
						
							| 
									
										
										
										
											2010-12-06 16:38:32 -02:00
										 |  |  | 	imx_imx2_wdt_data_entry_single(MX21, 0, , SZ_4K); | 
					
						
							| 
									
										
										
										
											2010-11-04 10:09:10 +01:00
										 |  |  | #endif /* ifdef CONFIG_SOC_IMX21 */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-11 18:35:01 +01:00
										 |  |  | #ifdef CONFIG_SOC_IMX25
 | 
					
						
							| 
									
										
										
										
											2010-11-11 16:58:50 +01:00
										 |  |  | const struct imx_imx2_wdt_data imx25_imx2_wdt_data __initconst = | 
					
						
							| 
									
										
										
										
											2010-12-06 16:38:32 -02:00
										 |  |  | 	imx_imx2_wdt_data_entry_single(MX25, 0, , SZ_16K); | 
					
						
							| 
									
										
										
										
											2010-11-11 18:35:01 +01:00
										 |  |  | #endif /* ifdef CONFIG_SOC_IMX25 */
 | 
					
						
							| 
									
										
										
										
											2010-11-11 16:58:50 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-04 10:09:10 +01:00
										 |  |  | #ifdef CONFIG_SOC_IMX27
 | 
					
						
							|  |  |  | const struct imx_imx2_wdt_data imx27_imx2_wdt_data __initconst = | 
					
						
							| 
									
										
										
										
											2010-12-06 16:38:32 -02:00
										 |  |  | 	imx_imx2_wdt_data_entry_single(MX27, 0, , SZ_4K); | 
					
						
							| 
									
										
										
										
											2010-11-04 10:09:10 +01:00
										 |  |  | #endif /* ifdef CONFIG_SOC_IMX27 */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-15 15:28:45 +01:00
										 |  |  | #ifdef CONFIG_SOC_IMX31
 | 
					
						
							|  |  |  | const struct imx_imx2_wdt_data imx31_imx2_wdt_data __initconst = | 
					
						
							| 
									
										
										
										
											2010-12-06 16:38:32 -02:00
										 |  |  | 	imx_imx2_wdt_data_entry_single(MX31, 0, , SZ_16K); | 
					
						
							| 
									
										
										
										
											2010-11-15 15:28:45 +01:00
										 |  |  | #endif /* ifdef CONFIG_SOC_IMX31 */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef CONFIG_SOC_IMX35
 | 
					
						
							|  |  |  | const struct imx_imx2_wdt_data imx35_imx2_wdt_data __initconst = | 
					
						
							| 
									
										
										
										
											2010-12-06 16:38:32 -02:00
										 |  |  | 	imx_imx2_wdt_data_entry_single(MX35, 0, , SZ_16K); | 
					
						
							| 
									
										
										
										
											2010-11-15 15:28:45 +01:00
										 |  |  | #endif /* ifdef CONFIG_SOC_IMX35 */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-26 12:25:59 -02:00
										 |  |  | #ifdef CONFIG_SOC_IMX51
 | 
					
						
							| 
									
										
										
										
											2010-12-06 16:38:32 -02:00
										 |  |  | const struct imx_imx2_wdt_data imx51_imx2_wdt_data[] __initconst = { | 
					
						
							|  |  |  | #define imx51_imx2_wdt_data_entry(_id, _hwid)				\
 | 
					
						
							|  |  |  | 	imx_imx2_wdt_data_entry(MX51, _id, _hwid, SZ_16K) | 
					
						
							|  |  |  | 	imx51_imx2_wdt_data_entry(0, 1), | 
					
						
							|  |  |  | 	imx51_imx2_wdt_data_entry(1, 2), | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2010-11-26 12:25:59 -02:00
										 |  |  | #endif /* ifdef CONFIG_SOC_IMX51 */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-17 18:09:52 -02:00
										 |  |  | #ifdef CONFIG_SOC_IMX53
 | 
					
						
							|  |  |  | const struct imx_imx2_wdt_data imx53_imx2_wdt_data[] __initconst = { | 
					
						
							|  |  |  | #define imx53_imx2_wdt_data_entry(_id, _hwid)				\
 | 
					
						
							|  |  |  | 	imx_imx2_wdt_data_entry(MX53, _id, _hwid, SZ_16K) | 
					
						
							|  |  |  | 	imx53_imx2_wdt_data_entry(0, 1), | 
					
						
							|  |  |  | 	imx53_imx2_wdt_data_entry(1, 2), | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | #endif /* ifdef CONFIG_SOC_IMX53 */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-04 10:09:10 +01:00
										 |  |  | struct platform_device *__init imx_add_imx2_wdt( | 
					
						
							|  |  |  | 		const struct imx_imx2_wdt_data *data) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct resource res[] = { | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			.start = data->iobase, | 
					
						
							| 
									
										
										
										
											2010-11-11 16:58:50 +01:00
										 |  |  | 			.end = data->iobase + data->iosize - 1, | 
					
						
							| 
									
										
										
										
											2010-11-04 10:09:10 +01:00
										 |  |  | 			.flags = IORESOURCE_MEM, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	}; | 
					
						
							| 
									
										
										
										
											2010-12-06 16:38:32 -02:00
										 |  |  | 	return imx_add_platform_device("imx2-wdt", data->id, | 
					
						
							| 
									
										
										
										
											2010-11-04 10:09:10 +01:00
										 |  |  | 			res, ARRAY_SIZE(res), NULL, 0); | 
					
						
							|  |  |  | } |