| 
									
										
										
										
											2009-06-04 11:32:12 +02:00
										 |  |  | #ifndef __MACH_MX25_H__
 | 
					
						
							|  |  |  | #define __MACH_MX25_H__
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-12 21:51:55 +01:00
										 |  |  | #define MX25_AIPS1_BASE_ADDR		0x43f00000
 | 
					
						
							| 
									
										
										
										
											2009-06-04 11:32:12 +02:00
										 |  |  | #define MX25_AIPS1_SIZE			SZ_1M
 | 
					
						
							| 
									
										
										
										
											2009-11-12 21:51:55 +01:00
										 |  |  | #define MX25_AIPS2_BASE_ADDR		0x53f00000
 | 
					
						
							| 
									
										
										
										
											2009-06-04 11:32:12 +02:00
										 |  |  | #define MX25_AIPS2_SIZE			SZ_1M
 | 
					
						
							|  |  |  | #define MX25_AVIC_BASE_ADDR		0x68000000
 | 
					
						
							|  |  |  | #define MX25_AVIC_SIZE			SZ_1M
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-16 14:55:07 +02:00
										 |  |  | #define MX25_I2C1_BASE_ADDR		(MX25_AIPS1_BASE_ADDR + 0x80000)
 | 
					
						
							|  |  |  | #define MX25_I2C3_BASE_ADDR		(MX25_AIPS1_BASE_ADDR + 0x84000)
 | 
					
						
							| 
									
										
										
										
											2010-07-22 11:41:56 +02:00
										 |  |  | #define MX25_CAN1_BASE_ADDR		(MX25_AIPS1_BASE_ADDR + 0x88000)
 | 
					
						
							|  |  |  | #define MX25_CAN2_BASE_ADDR		(MX25_AIPS1_BASE_ADDR + 0x8c000)
 | 
					
						
							| 
									
										
										
										
											2010-06-16 14:55:07 +02:00
										 |  |  | #define MX25_I2C2_BASE_ADDR		(MX25_AIPS1_BASE_ADDR + 0x98000)
 | 
					
						
							| 
									
										
										
										
											2010-06-21 17:34:58 +02:00
										 |  |  | #define MX25_CSPI1_BASE_ADDR		(MX25_AIPS1_BASE_ADDR + 0xa4000)
 | 
					
						
							| 
									
										
										
										
											2009-06-04 11:32:12 +02:00
										 |  |  | #define MX25_IOMUXC_BASE_ADDR		(MX25_AIPS1_BASE_ADDR + 0xac000)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define MX25_CRM_BASE_ADDR		(MX25_AIPS2_BASE_ADDR + 0x80000)
 | 
					
						
							|  |  |  | #define MX25_GPT1_BASE_ADDR		(MX25_AIPS2_BASE_ADDR + 0x90000)
 | 
					
						
							| 
									
										
										
										
											2010-10-25 15:54:58 +02:00
										 |  |  | #define MX25_GPIO4_BASE_ADDR		(MX25_AIPS2_BASE_ADDR + 0x9c000)
 | 
					
						
							| 
									
										
										
										
											2010-11-10 22:15:45 +01:00
										 |  |  | #define MX25_PWM2_BASE_ADDR		(MX25_AIPS2_BASE_ADDR + 0xa0000)
 | 
					
						
							| 
									
										
										
										
											2010-10-25 15:54:58 +02:00
										 |  |  | #define MX25_GPIO3_BASE_ADDR		(MX25_AIPS2_BASE_ADDR + 0xa4000)
 | 
					
						
							| 
									
										
										
										
											2010-11-10 22:15:45 +01:00
										 |  |  | #define MX25_PWM3_BASE_ADDR		(MX25_AIPS2_BASE_ADDR + 0xa8000)
 | 
					
						
							|  |  |  | #define MX25_PWM4_BASE_ADDR		(MX25_AIPS2_BASE_ADDR + 0xc8000)
 | 
					
						
							| 
									
										
										
										
											2010-10-25 15:54:58 +02:00
										 |  |  | #define MX25_GPIO1_BASE_ADDR		(MX25_AIPS2_BASE_ADDR + 0xcc000)
 | 
					
						
							|  |  |  | #define MX25_GPIO2_BASE_ADDR		(MX25_AIPS2_BASE_ADDR + 0xd0000)
 | 
					
						
							| 
									
										
										
										
											2009-06-04 11:32:12 +02:00
										 |  |  | #define MX25_WDOG_BASE_ADDR		(MX25_AIPS2_BASE_ADDR + 0xdc000)
 | 
					
						
							| 
									
										
										
										
											2010-11-10 22:15:45 +01:00
										 |  |  | #define MX25_PWM1_BASE_ADDR		(MX25_AIPS2_BASE_ADDR + 0xe0000)
 | 
					
						
							| 
									
										
										
										
											2009-06-04 11:32:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-25 17:55:16 +01:00
										 |  |  | #define MX25_UART1_BASE_ADDR		0x43f90000
 | 
					
						
							|  |  |  | #define MX25_UART2_BASE_ADDR		0x43f94000
 | 
					
						
							| 
									
										
										
										
											2010-06-08 11:03:00 +02:00
										 |  |  | #define MX25_AUDMUX_BASE_ADDR		0x43fb0000
 | 
					
						
							| 
									
										
										
										
											2010-06-24 15:20:44 +02:00
										 |  |  | #define MX25_UART3_BASE_ADDR		0x5000c000
 | 
					
						
							|  |  |  | #define MX25_UART4_BASE_ADDR		0x50008000
 | 
					
						
							|  |  |  | #define MX25_UART5_BASE_ADDR		0x5002c000
 | 
					
						
							| 
									
										
										
										
											2009-06-04 11:32:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-21 17:34:58 +02:00
										 |  |  | #define MX25_CSPI3_BASE_ADDR		0x50004000
 | 
					
						
							|  |  |  | #define MX25_CSPI2_BASE_ADDR		0x50010000
 | 
					
						
							| 
									
										
										
										
											2009-12-21 13:44:31 +02:00
										 |  |  | #define MX25_FEC_BASE_ADDR		0x50038000
 | 
					
						
							| 
									
										
										
										
											2010-06-08 11:03:00 +02:00
										 |  |  | #define MX25_SSI2_BASE_ADDR		0x50014000
 | 
					
						
							|  |  |  | #define MX25_SSI1_BASE_ADDR		0x50034000
 | 
					
						
							| 
									
										
										
										
											2010-01-14 11:24:14 +02:00
										 |  |  | #define MX25_NFC_BASE_ADDR		0xbb000000
 | 
					
						
							| 
									
										
										
										
											2011-08-29 21:13:44 +08:00
										 |  |  | #define MX25_IIM_BASE_ADDR		0x53ff0000
 | 
					
						
							| 
									
										
										
										
											2010-01-27 15:00:48 +02:00
										 |  |  | #define MX25_DRYICE_BASE_ADDR		0x53ffc000
 | 
					
						
							| 
									
										
										
										
											2010-10-02 17:15:28 +02:00
										 |  |  | #define MX25_ESDHC1_BASE_ADDR		0x53fb4000
 | 
					
						
							|  |  |  | #define MX25_ESDHC2_BASE_ADDR		0x53fb8000
 | 
					
						
							| 
									
										
										
										
											2010-02-17 12:33:24 +02:00
										 |  |  | #define MX25_LCDC_BASE_ADDR		0x53fbc000
 | 
					
						
							| 
									
										
										
										
											2010-05-26 15:12:10 +03:00
										 |  |  | #define MX25_KPP_BASE_ADDR		0x43fa8000
 | 
					
						
							| 
									
										
										
										
											2010-10-12 14:08:42 +02:00
										 |  |  | #define MX25_SDMA_BASE_ADDR		0x53fd4000
 | 
					
						
							| 
									
										
										
										
											2010-11-10 21:27:55 +01:00
										 |  |  | #define MX25_USB_BASE_ADDR		0x53ff4000
 | 
					
						
							|  |  |  | #define MX25_USB_OTG_BASE_ADDR			(MX25_USB_BASE_ADDR + 0x0000)
 | 
					
						
							| 
									
										
										
										
											2010-11-29 08:58:14 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * The reference manual (IMX25RM, Rev. 1, 06/2009) specifies an offset of 0x200 | 
					
						
							|  |  |  |  * for the host controller.  Early documentation drafts specified 0x400 and | 
					
						
							|  |  |  |  * Freescale internal sources confirm only the latter value to work. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #define MX25_USB_HS_BASE_ADDR			(MX25_USB_BASE_ADDR + 0x0400)
 | 
					
						
							| 
									
										
										
										
											2010-06-21 08:16:00 +03:00
										 |  |  | #define MX25_CSI_BASE_ADDR		0x53ff8000
 | 
					
						
							| 
									
										
										
										
											2009-12-21 13:44:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-25 15:44:25 +02:00
										 |  |  | #define MX25_IO_P2V(x)			IMX_IO_P2V(x)
 | 
					
						
							|  |  |  | #define MX25_IO_ADDRESS(x)		IOMEM(MX25_IO_P2V(x))
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-14 11:16:14 +08:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Interrupt numbers | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #include <asm/irq.h>
 | 
					
						
							|  |  |  | #define MX25_INT_CSPI3		(NR_IRQS_LEGACY + 0)
 | 
					
						
							|  |  |  | #define MX25_INT_I2C1		(NR_IRQS_LEGACY + 3)
 | 
					
						
							|  |  |  | #define MX25_INT_I2C2		(NR_IRQS_LEGACY + 4)
 | 
					
						
							|  |  |  | #define MX25_INT_UART4		(NR_IRQS_LEGACY + 5)
 | 
					
						
							|  |  |  | #define MX25_INT_ESDHC2		(NR_IRQS_LEGACY + 8)
 | 
					
						
							|  |  |  | #define MX25_INT_ESDHC1		(NR_IRQS_LEGACY + 9)
 | 
					
						
							|  |  |  | #define MX25_INT_I2C3		(NR_IRQS_LEGACY + 10)
 | 
					
						
							|  |  |  | #define MX25_INT_SSI2		(NR_IRQS_LEGACY + 11)
 | 
					
						
							|  |  |  | #define MX25_INT_SSI1		(NR_IRQS_LEGACY + 12)
 | 
					
						
							|  |  |  | #define MX25_INT_CSPI2		(NR_IRQS_LEGACY + 13)
 | 
					
						
							|  |  |  | #define MX25_INT_CSPI1		(NR_IRQS_LEGACY + 14)
 | 
					
						
							|  |  |  | #define MX25_INT_GPIO3		(NR_IRQS_LEGACY + 16)
 | 
					
						
							|  |  |  | #define MX25_INT_CSI		(NR_IRQS_LEGACY + 17)
 | 
					
						
							|  |  |  | #define MX25_INT_UART3		(NR_IRQS_LEGACY + 18)
 | 
					
						
							|  |  |  | #define MX25_INT_GPIO4		(NR_IRQS_LEGACY + 23)
 | 
					
						
							|  |  |  | #define MX25_INT_KPP		(NR_IRQS_LEGACY + 24)
 | 
					
						
							|  |  |  | #define MX25_INT_DRYICE		(NR_IRQS_LEGACY + 25)
 | 
					
						
							|  |  |  | #define MX25_INT_PWM1		(NR_IRQS_LEGACY + 26)
 | 
					
						
							|  |  |  | #define MX25_INT_UART2		(NR_IRQS_LEGACY + 32)
 | 
					
						
							|  |  |  | #define MX25_INT_NFC		(NR_IRQS_LEGACY + 33)
 | 
					
						
							|  |  |  | #define MX25_INT_SDMA		(NR_IRQS_LEGACY + 34)
 | 
					
						
							|  |  |  | #define MX25_INT_USB_HS		(NR_IRQS_LEGACY + 35)
 | 
					
						
							|  |  |  | #define MX25_INT_PWM2		(NR_IRQS_LEGACY + 36)
 | 
					
						
							|  |  |  | #define MX25_INT_USB_OTG	(NR_IRQS_LEGACY + 37)
 | 
					
						
							|  |  |  | #define MX25_INT_LCDC		(NR_IRQS_LEGACY + 39)
 | 
					
						
							|  |  |  | #define MX25_INT_UART5		(NR_IRQS_LEGACY + 40)
 | 
					
						
							|  |  |  | #define MX25_INT_PWM3		(NR_IRQS_LEGACY + 41)
 | 
					
						
							|  |  |  | #define MX25_INT_PWM4		(NR_IRQS_LEGACY + 42)
 | 
					
						
							|  |  |  | #define MX25_INT_CAN1		(NR_IRQS_LEGACY + 43)
 | 
					
						
							|  |  |  | #define MX25_INT_CAN2		(NR_IRQS_LEGACY + 44)
 | 
					
						
							|  |  |  | #define MX25_INT_UART1		(NR_IRQS_LEGACY + 45)
 | 
					
						
							|  |  |  | #define MX25_INT_GPIO2		(NR_IRQS_LEGACY + 51)
 | 
					
						
							|  |  |  | #define MX25_INT_GPIO1		(NR_IRQS_LEGACY + 52)
 | 
					
						
							| 
									
										
										
										
											2012-09-18 10:05:31 +02:00
										 |  |  | #define MX25_INT_GPT1		(NR_IRQS_LEGACY + 54)
 | 
					
						
							| 
									
										
										
										
											2012-06-14 11:16:14 +08:00
										 |  |  | #define MX25_INT_FEC		(NR_IRQS_LEGACY + 57)
 | 
					
						
							| 
									
										
										
										
											2009-12-21 13:44:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-25 17:37:45 +02:00
										 |  |  | #define MX25_DMA_REQ_SSI2_RX1	22
 | 
					
						
							|  |  |  | #define MX25_DMA_REQ_SSI2_TX1	23
 | 
					
						
							|  |  |  | #define MX25_DMA_REQ_SSI2_RX0	24
 | 
					
						
							|  |  |  | #define MX25_DMA_REQ_SSI2_TX0	25
 | 
					
						
							|  |  |  | #define MX25_DMA_REQ_SSI1_RX1	26
 | 
					
						
							|  |  |  | #define MX25_DMA_REQ_SSI1_TX1	27
 | 
					
						
							|  |  |  | #define MX25_DMA_REQ_SSI1_RX0	28
 | 
					
						
							|  |  |  | #define MX25_DMA_REQ_SSI1_TX0	29
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-26 13:35:19 +08:00
										 |  |  | #ifndef __ASSEMBLY__
 | 
					
						
							|  |  |  | extern int mx25_revision(void); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-08 16:02:30 +01:00
										 |  |  | #endif /* ifndef __MACH_MX25_H__ */
 |