xref: /rk3399_rockchip-uboot/arch/arm/include/asm/arch-mx27/imx-regs.h (revision 1d2c0506d31a9997e5ffc22e90942902f673b107)
1819833afSPeter Tyser /*
2819833afSPeter Tyser  * (c) 2007 Pengutronix, Sascha Hauer <s.hauer@pengutronix.de>
3819833afSPeter Tyser  * (c) 2009 Ilya Yanok, Emcraft Systems <yanok@emcraft.com>
4819833afSPeter Tyser  *
51a459660SWolfgang Denk  * SPDX-License-Identifier:	GPL-2.0+
6819833afSPeter Tyser  */
7819833afSPeter Tyser 
8819833afSPeter Tyser #ifndef _IMX_REGS_H
9819833afSPeter Tyser #define _IMX_REGS_H
10819833afSPeter Tyser 
1178befb69Strem #include <asm/arch/regs-rtc.h>
1278befb69Strem 
13819833afSPeter Tyser #ifndef __ASSEMBLY__
14819833afSPeter Tyser 
15819833afSPeter Tyser extern void imx_gpio_mode (int gpio_mode);
16819833afSPeter Tyser 
17819833afSPeter Tyser #ifdef CONFIG_MXC_UART
183f7bfbddSFabio Estevam extern void mx27_uart1_init_pins(void);
19819833afSPeter Tyser #endif /* CONFIG_MXC_UART */
20819833afSPeter Tyser 
21819833afSPeter Tyser #ifdef CONFIG_FEC_MXC
22819833afSPeter Tyser extern void mx27_fec_init_pins(void);
23819833afSPeter Tyser #endif /* CONFIG_FEC_MXC */
24819833afSPeter Tyser 
25*1d2c0506SMasahiro Yamada #ifdef CONFIG_MMC_MXC
261e65c2beSHeiko Schocher extern void mx27_sd1_init_pins(void);
27819833afSPeter Tyser extern void mx27_sd2_init_pins(void);
28*1d2c0506SMasahiro Yamada #endif /* CONFIG_MMC_MXC */
29819833afSPeter Tyser 
30819833afSPeter Tyser /* AIPI */
31819833afSPeter Tyser struct aipi_regs {
32819833afSPeter Tyser 	u32 psr0;
33819833afSPeter Tyser 	u32 psr1;
34819833afSPeter Tyser };
35819833afSPeter Tyser 
36819833afSPeter Tyser /* System Control */
37819833afSPeter Tyser struct system_control_regs {
38819833afSPeter Tyser 	u32 res[5];
39819833afSPeter Tyser 	u32 fmcr;
40819833afSPeter Tyser 	u32 gpcr;
41819833afSPeter Tyser 	u32 wbcr;
42819833afSPeter Tyser 	u32 dscr1;
43819833afSPeter Tyser 	u32 dscr2;
44819833afSPeter Tyser 	u32 dscr3;
45819833afSPeter Tyser 	u32 dscr4;
46819833afSPeter Tyser 	u32 dscr5;
47819833afSPeter Tyser 	u32 dscr6;
48819833afSPeter Tyser 	u32 dscr7;
49819833afSPeter Tyser 	u32 dscr8;
50819833afSPeter Tyser 	u32 dscr9;
51819833afSPeter Tyser 	u32 dscr10;
52819833afSPeter Tyser 	u32 dscr11;
53819833afSPeter Tyser 	u32 dscr12;
54819833afSPeter Tyser 	u32 dscr13;
55819833afSPeter Tyser 	u32 pscr;
56819833afSPeter Tyser 	u32 pmcr;
57819833afSPeter Tyser 	u32 res1;
58819833afSPeter Tyser 	u32 dcvr0;
59819833afSPeter Tyser 	u32 dcvr1;
60819833afSPeter Tyser 	u32 dcvr2;
61819833afSPeter Tyser 	u32 dcvr3;
62819833afSPeter Tyser };
63819833afSPeter Tyser 
64819833afSPeter Tyser /* Chip Select Registers */
65819833afSPeter Tyser struct weim_regs {
66819833afSPeter Tyser 	u32 cs0u;	/* Chip Select 0 Upper Register */
67819833afSPeter Tyser 	u32 cs0l;	/* Chip Select 0 Lower Register */
68819833afSPeter Tyser 	u32 cs0a;	/* Chip Select 0 Addition Register */
69819833afSPeter Tyser 	u32 pad0;
70819833afSPeter Tyser 	u32 cs1u;	/* Chip Select 1 Upper Register */
71819833afSPeter Tyser 	u32 cs1l;	/* Chip Select 1 Lower Register */
72819833afSPeter Tyser 	u32 cs1a;	/* Chip Select 1 Addition Register */
73819833afSPeter Tyser 	u32 pad1;
74819833afSPeter Tyser 	u32 cs2u;	/* Chip Select 2 Upper Register */
75819833afSPeter Tyser 	u32 cs2l;	/* Chip Select 2 Lower Register */
76819833afSPeter Tyser 	u32 cs2a;	/* Chip Select 2 Addition Register */
77819833afSPeter Tyser 	u32 pad2;
78819833afSPeter Tyser 	u32 cs3u;	/* Chip Select 3 Upper Register */
79819833afSPeter Tyser 	u32 cs3l;	/* Chip Select 3 Lower Register */
80819833afSPeter Tyser 	u32 cs3a;	/* Chip Select 3 Addition Register */
81819833afSPeter Tyser 	u32 pad3;
82819833afSPeter Tyser 	u32 cs4u;	/* Chip Select 4 Upper Register */
83819833afSPeter Tyser 	u32 cs4l;	/* Chip Select 4 Lower Register */
84819833afSPeter Tyser 	u32 cs4a;	/* Chip Select 4 Addition Register */
85819833afSPeter Tyser 	u32 pad4;
86819833afSPeter Tyser 	u32 cs5u;	/* Chip Select 5 Upper Register */
87819833afSPeter Tyser 	u32 cs5l;	/* Chip Select 5 Lower Register */
88819833afSPeter Tyser 	u32 cs5a;	/* Chip Select 5 Addition Register */
89819833afSPeter Tyser 	u32 pad5;
90819833afSPeter Tyser 	u32 eim;	/* WEIM Configuration Register */
91819833afSPeter Tyser };
92819833afSPeter Tyser 
93819833afSPeter Tyser /* SDRAM Controller registers */
94819833afSPeter Tyser struct esdramc_regs {
95819833afSPeter Tyser /* Enhanced SDRAM Control Register 0 */
96819833afSPeter Tyser 	u32 esdctl0;
97819833afSPeter Tyser /* Enhanced SDRAM Configuration Register 0 */
98819833afSPeter Tyser 	u32 esdcfg0;
99819833afSPeter Tyser /* Enhanced SDRAM Control Register 1 */
100819833afSPeter Tyser 	u32 esdctl1;
101819833afSPeter Tyser /* Enhanced SDRAM Configuration Register 1 */
102819833afSPeter Tyser 	u32 esdcfg1;
103819833afSPeter Tyser /* Enhanced SDRAM Miscellanious Register */
104819833afSPeter Tyser 	u32 esdmisc;
105819833afSPeter Tyser };
106819833afSPeter Tyser 
107819833afSPeter Tyser /* Watchdog Registers*/
108819833afSPeter Tyser struct wdog_regs {
109f7440928SLeonid Iziumtsev 	u16 wcr;
110f7440928SLeonid Iziumtsev 	u16 wsr;
111f7440928SLeonid Iziumtsev 	u16 wstr;
112819833afSPeter Tyser };
113819833afSPeter Tyser 
114819833afSPeter Tyser /* PLL registers */
115819833afSPeter Tyser struct pll_regs {
116819833afSPeter Tyser 	u32 cscr;	/* Clock Source Control Register */
117819833afSPeter Tyser 	u32 mpctl0;	/* MCU PLL Control Register 0 */
118819833afSPeter Tyser 	u32 mpctl1;	/* MCU PLL Control Register 1 */
119819833afSPeter Tyser 	u32 spctl0;	/* System PLL Control Register 0 */
120819833afSPeter Tyser 	u32 spctl1;	/* System PLL Control Register 1 */
121819833afSPeter Tyser 	u32 osc26mctl;	/* Oscillator 26M Register */
122819833afSPeter Tyser 	u32 pcdr0;	/* Peripheral Clock Divider Register 0 */
123819833afSPeter Tyser 	u32 pcdr1;	/* Peripheral Clock Divider Register 1 */
124819833afSPeter Tyser 	u32 pccr0;	/* Peripheral Clock Control Register 0 */
125819833afSPeter Tyser 	u32 pccr1;	/* Peripheral Clock Control Register 1 */
126819833afSPeter Tyser 	u32 ccsr;	/* Clock Control Status Register */
127819833afSPeter Tyser };
128819833afSPeter Tyser 
129819833afSPeter Tyser /*
130819833afSPeter Tyser  * Definitions for the clocksource registers
131819833afSPeter Tyser  */
132819833afSPeter Tyser struct gpt_regs {
133819833afSPeter Tyser 	u32 gpt_tctl;
134819833afSPeter Tyser 	u32 gpt_tprer;
135819833afSPeter Tyser 	u32 gpt_tcmp;
136819833afSPeter Tyser 	u32 gpt_tcr;
137819833afSPeter Tyser 	u32 gpt_tcn;
138819833afSPeter Tyser 	u32 gpt_tstat;
139819833afSPeter Tyser };
140819833afSPeter Tyser 
141819833afSPeter Tyser /* IIM Control Registers */
142819833afSPeter Tyser struct iim_regs {
143819833afSPeter Tyser 	u32 iim_stat;
144819833afSPeter Tyser 	u32 iim_statm;
145819833afSPeter Tyser 	u32 iim_err;
146819833afSPeter Tyser 	u32 iim_emask;
147819833afSPeter Tyser 	u32 iim_fctl;
148819833afSPeter Tyser 	u32 iim_ua;
149819833afSPeter Tyser 	u32 iim_la;
150819833afSPeter Tyser 	u32 iim_sdat;
151819833afSPeter Tyser 	u32 iim_prev;
152819833afSPeter Tyser 	u32 iim_srev;
1538f3ff11cSBenoît Thébaudeau 	u32 iim_prg_p;
154819833afSPeter Tyser 	u32 iim_scs0;
155819833afSPeter Tyser 	u32 iim_scs1;
156819833afSPeter Tyser 	u32 iim_scs2;
157819833afSPeter Tyser 	u32 iim_scs3;
158565e39c5SLiu Hui-R64343 	u32 res[0x1f1];
159565e39c5SLiu Hui-R64343 	struct fuse_bank {
160565e39c5SLiu Hui-R64343 		u32 fuse_regs[0x20];
161565e39c5SLiu Hui-R64343 		u32 fuse_rsvd[0xe0];
162e24278afStrem 	} bank[2];
163819833afSPeter Tyser };
164565e39c5SLiu Hui-R64343 
165565e39c5SLiu Hui-R64343 struct fuse_bank0_regs {
166565e39c5SLiu Hui-R64343 	u32 fuse0_3[5];
167565e39c5SLiu Hui-R64343 	u32 mac_addr[6];
168565e39c5SLiu Hui-R64343 	u32 fuse10_31[0x16];
169565e39c5SLiu Hui-R64343 };
170565e39c5SLiu Hui-R64343 
171819833afSPeter Tyser #endif
172819833afSPeter Tyser 
1738e99ecd7SBenoît Thébaudeau #define ARCH_MXC
1748e99ecd7SBenoît Thébaudeau 
175819833afSPeter Tyser #define IMX_IO_BASE		0x10000000
176819833afSPeter Tyser 
177819833afSPeter Tyser #define IMX_AIPI1_BASE		(0x00000 + IMX_IO_BASE)
178819833afSPeter Tyser #define IMX_WDT_BASE		(0x02000 + IMX_IO_BASE)
179819833afSPeter Tyser #define IMX_TIM1_BASE		(0x03000 + IMX_IO_BASE)
180819833afSPeter Tyser #define IMX_TIM2_BASE		(0x04000 + IMX_IO_BASE)
181819833afSPeter Tyser #define IMX_TIM3_BASE		(0x05000 + IMX_IO_BASE)
18278befb69Strem #define IMX_RTC_BASE		(0x07000 + IMX_IO_BASE)
18340f6fffeSStefano Babic #define UART1_BASE		(0x0a000 + IMX_IO_BASE)
18440f6fffeSStefano Babic #define UART2_BASE		(0x0b000 + IMX_IO_BASE)
18540f6fffeSStefano Babic #define UART3_BASE		(0x0c000 + IMX_IO_BASE)
18640f6fffeSStefano Babic #define UART4_BASE		(0x0d000 + IMX_IO_BASE)
187e6c8b716SHeiko Schocher #define I2C1_BASE_ADDR		(0x12000 + IMX_IO_BASE)
188819833afSPeter Tyser #define IMX_GPIO_BASE		(0x15000 + IMX_IO_BASE)
189819833afSPeter Tyser #define IMX_TIM4_BASE		(0x19000 + IMX_IO_BASE)
190819833afSPeter Tyser #define IMX_TIM5_BASE		(0x1a000 + IMX_IO_BASE)
191819833afSPeter Tyser #define IMX_UART5_BASE		(0x1b000 + IMX_IO_BASE)
192819833afSPeter Tyser #define IMX_UART6_BASE		(0x1c000 + IMX_IO_BASE)
193e6c8b716SHeiko Schocher #define I2C2_BASE_ADDR		(0x1D000 + IMX_IO_BASE)
194819833afSPeter Tyser #define IMX_TIM6_BASE		(0x1f000 + IMX_IO_BASE)
195819833afSPeter Tyser #define IMX_AIPI2_BASE		(0x20000 + IMX_IO_BASE)
196819833afSPeter Tyser #define IMX_PLL_BASE		(0x27000 + IMX_IO_BASE)
197819833afSPeter Tyser #define IMX_SYSTEM_CTL_BASE	(0x27800 + IMX_IO_BASE)
198819833afSPeter Tyser #define IMX_IIM_BASE		(0x28000 + IMX_IO_BASE)
1990f67e09eSBenoît Thébaudeau #define IIM_BASE_ADDR		IMX_IIM_BASE
200819833afSPeter Tyser #define IMX_FEC_BASE		(0x2b000 + IMX_IO_BASE)
201819833afSPeter Tyser 
202e24278afStrem #define IMX_NFC_BASE		(0xD8000000)
203819833afSPeter Tyser #define IMX_ESD_BASE		(0xD8001000)
204819833afSPeter Tyser #define IMX_WEIM_BASE		(0xD8002000)
205819833afSPeter Tyser 
206e24278afStrem #define NFC_BASE_ADDR		IMX_NFC_BASE
207e24278afStrem 
208e24278afStrem 
209819833afSPeter Tyser /* FMCR System Control bit definition*/
210819833afSPeter Tyser #define UART4_RXD_CTL	(1 << 25)
211819833afSPeter Tyser #define UART4_RTS_CTL	(1 << 24)
212819833afSPeter Tyser #define KP_COL6_CTL	(1 << 18)
213819833afSPeter Tyser #define KP_ROW7_CTL	(1 << 17)
214819833afSPeter Tyser #define KP_ROW6_CTL	(1 << 16)
215819833afSPeter Tyser #define PC_WAIT_B_CTL	(1 << 14)
216819833afSPeter Tyser #define PC_READY_CTL	(1 << 13)
217819833afSPeter Tyser #define PC_VS1_CTL	(1 << 12)
218819833afSPeter Tyser #define PC_VS2_CTL	(1 << 11)
219819833afSPeter Tyser #define PC_BVD1_CTL	(1 << 10)
220819833afSPeter Tyser #define PC_BVD2_CTL	(1 << 9)
221819833afSPeter Tyser #define IOS16_CTL	(1 << 8)
222819833afSPeter Tyser #define NF_FMS		(1 << 5)
223819833afSPeter Tyser #define NF_16BIT_SEL	(1 << 4)
224819833afSPeter Tyser #define SLCDC_SEL	(1 << 2)
225819833afSPeter Tyser #define SDCS1_SEL	(1 << 1)
226819833afSPeter Tyser #define SDCS0_SEL	(1 << 0)
227819833afSPeter Tyser 
228819833afSPeter Tyser 
229819833afSPeter Tyser /* important definition of some bits of WCR */
230819833afSPeter Tyser #define WCR_WDE 0x04
231819833afSPeter Tyser 
232819833afSPeter Tyser #define CSCR_MPEN		(1 << 0)
233819833afSPeter Tyser #define CSCR_SPEN		(1 << 1)
234819833afSPeter Tyser #define CSCR_FPM_EN		(1 << 2)
235819833afSPeter Tyser #define CSCR_OSC26M_DIS		(1 << 3)
236819833afSPeter Tyser #define CSCR_OSC26M_DIV1P5	(1 << 4)
237819833afSPeter Tyser #define CSCR_AHB_DIV
238819833afSPeter Tyser #define CSCR_ARM_DIV
239819833afSPeter Tyser #define CSCR_ARM_SRC_MPLL	(1 << 15)
240819833afSPeter Tyser #define CSCR_MCU_SEL		(1 << 16)
241819833afSPeter Tyser #define CSCR_SP_SEL		(1 << 17)
242819833afSPeter Tyser #define CSCR_MPLL_RESTART	(1 << 18)
243819833afSPeter Tyser #define CSCR_SPLL_RESTART	(1 << 19)
244819833afSPeter Tyser #define CSCR_MSHC_SEL		(1 << 20)
245819833afSPeter Tyser #define CSCR_H264_SEL		(1 << 21)
246819833afSPeter Tyser #define CSCR_SSI1_SEL		(1 << 22)
247819833afSPeter Tyser #define CSCR_SSI2_SEL		(1 << 23)
248819833afSPeter Tyser #define CSCR_SD_CNT
249819833afSPeter Tyser #define CSCR_USB_DIV
250819833afSPeter Tyser #define CSCR_UPDATE_DIS		(1 << 31)
251819833afSPeter Tyser 
252819833afSPeter Tyser #define MPCTL1_BRMO		(1 << 6)
253819833afSPeter Tyser #define MPCTL1_LF		(1 << 15)
254819833afSPeter Tyser 
255819833afSPeter Tyser #define PCCR0_SSI2_EN	(1 << 0)
256819833afSPeter Tyser #define PCCR0_SSI1_EN	(1 << 1)
257819833afSPeter Tyser #define PCCR0_SLCDC_EN	(1 << 2)
258819833afSPeter Tyser #define PCCR0_SDHC3_EN	(1 << 3)
259819833afSPeter Tyser #define PCCR0_SDHC2_EN	(1 << 4)
260819833afSPeter Tyser #define PCCR0_SDHC1_EN	(1 << 5)
261819833afSPeter Tyser #define PCCR0_SDC_EN	(1 << 6)
262819833afSPeter Tyser #define PCCR0_SAHARA_EN	(1 << 7)
263819833afSPeter Tyser #define PCCR0_RTIC_EN	(1 << 8)
264819833afSPeter Tyser #define PCCR0_RTC_EN	(1 << 9)
265819833afSPeter Tyser #define PCCR0_PWM_EN	(1 << 11)
266819833afSPeter Tyser #define PCCR0_OWIRE_EN	(1 << 12)
267819833afSPeter Tyser #define PCCR0_MSHC_EN	(1 << 13)
268819833afSPeter Tyser #define PCCR0_LCDC_EN	(1 << 14)
269819833afSPeter Tyser #define PCCR0_KPP_EN	(1 << 15)
270819833afSPeter Tyser #define PCCR0_IIM_EN	(1 << 16)
271819833afSPeter Tyser #define PCCR0_I2C2_EN	(1 << 17)
272819833afSPeter Tyser #define PCCR0_I2C1_EN	(1 << 18)
273819833afSPeter Tyser #define PCCR0_GPT6_EN	(1 << 19)
274819833afSPeter Tyser #define PCCR0_GPT5_EN	(1 << 20)
275819833afSPeter Tyser #define PCCR0_GPT4_EN	(1 << 21)
276819833afSPeter Tyser #define PCCR0_GPT3_EN	(1 << 22)
277819833afSPeter Tyser #define PCCR0_GPT2_EN	(1 << 23)
278819833afSPeter Tyser #define PCCR0_GPT1_EN	(1 << 24)
279819833afSPeter Tyser #define PCCR0_GPIO_EN	(1 << 25)
280819833afSPeter Tyser #define PCCR0_FEC_EN	(1 << 26)
281819833afSPeter Tyser #define PCCR0_EMMA_EN	(1 << 27)
282819833afSPeter Tyser #define PCCR0_DMA_EN	(1 << 28)
283819833afSPeter Tyser #define PCCR0_CSPI3_EN	(1 << 29)
284819833afSPeter Tyser #define PCCR0_CSPI2_EN	(1 << 30)
285819833afSPeter Tyser #define PCCR0_CSPI1_EN	(1 << 31)
286819833afSPeter Tyser 
287819833afSPeter Tyser #define PCCR1_MSHC_BAUDEN	(1 << 2)
288819833afSPeter Tyser #define PCCR1_NFC_BAUDEN	(1 << 3)
289819833afSPeter Tyser #define PCCR1_SSI2_BAUDEN	(1 << 4)
290819833afSPeter Tyser #define PCCR1_SSI1_BAUDEN	(1 << 5)
291819833afSPeter Tyser #define PCCR1_H264_BAUDEN	(1 << 6)
292819833afSPeter Tyser #define PCCR1_PERCLK4_EN	(1 << 7)
293819833afSPeter Tyser #define PCCR1_PERCLK3_EN	(1 << 8)
294819833afSPeter Tyser #define PCCR1_PERCLK2_EN	(1 << 9)
295819833afSPeter Tyser #define PCCR1_PERCLK1_EN	(1 << 10)
296819833afSPeter Tyser #define PCCR1_HCLK_USB		(1 << 11)
297819833afSPeter Tyser #define PCCR1_HCLK_SLCDC	(1 << 12)
298819833afSPeter Tyser #define PCCR1_HCLK_SAHARA	(1 << 13)
299819833afSPeter Tyser #define PCCR1_HCLK_RTIC		(1 << 14)
300819833afSPeter Tyser #define PCCR1_HCLK_LCDC		(1 << 15)
301819833afSPeter Tyser #define PCCR1_HCLK_H264		(1 << 16)
302819833afSPeter Tyser #define PCCR1_HCLK_FEC		(1 << 17)
303819833afSPeter Tyser #define PCCR1_HCLK_EMMA		(1 << 18)
304819833afSPeter Tyser #define PCCR1_HCLK_EMI		(1 << 19)
305819833afSPeter Tyser #define PCCR1_HCLK_DMA		(1 << 20)
306819833afSPeter Tyser #define PCCR1_HCLK_CSI		(1 << 21)
307819833afSPeter Tyser #define PCCR1_HCLK_BROM		(1 << 22)
308819833afSPeter Tyser #define PCCR1_HCLK_ATA		(1 << 23)
309819833afSPeter Tyser #define PCCR1_WDT_EN		(1 << 24)
310819833afSPeter Tyser #define PCCR1_USB_EN		(1 << 25)
311819833afSPeter Tyser #define PCCR1_UART6_EN		(1 << 26)
312819833afSPeter Tyser #define PCCR1_UART5_EN		(1 << 27)
313819833afSPeter Tyser #define PCCR1_UART4_EN		(1 << 28)
314819833afSPeter Tyser #define PCCR1_UART3_EN		(1 << 29)
315819833afSPeter Tyser #define PCCR1_UART2_EN		(1 << 30)
316819833afSPeter Tyser #define PCCR1_UART1_EN		(1 << 31)
317819833afSPeter Tyser 
318819833afSPeter Tyser /* SDRAM Controller registers bitfields */
319819833afSPeter Tyser #define ESDCTL_PRCT(x)		(((x) & 0x3f) << 0)
320819833afSPeter Tyser #define ESDCTL_BL		(1 << 7)
321819833afSPeter Tyser #define ESDCTL_FP		(1 << 8)
322819833afSPeter Tyser #define ESDCTL_PWDT(x)		(((x) & 3) << 10)
323819833afSPeter Tyser #define ESDCTL_SREFR(x)		(((x) & 7) << 13)
324819833afSPeter Tyser #define ESDCTL_DSIZ_16_UPPER	(0 << 16)
325819833afSPeter Tyser #define ESDCTL_DSIZ_16_LOWER	(1 << 16)
326819833afSPeter Tyser #define ESDCTL_DSIZ_32		(2 << 16)
327819833afSPeter Tyser #define ESDCTL_COL8		(0 << 20)
328819833afSPeter Tyser #define ESDCTL_COL9		(1 << 20)
329819833afSPeter Tyser #define ESDCTL_COL10		(2 << 20)
330819833afSPeter Tyser #define ESDCTL_ROW11		(0 << 24)
331819833afSPeter Tyser #define ESDCTL_ROW12		(1 << 24)
332819833afSPeter Tyser #define ESDCTL_ROW13		(2 << 24)
333819833afSPeter Tyser #define ESDCTL_ROW14		(3 << 24)
334819833afSPeter Tyser #define ESDCTL_ROW15		(4 << 24)
335819833afSPeter Tyser #define ESDCTL_SP		(1 << 27)
336819833afSPeter Tyser #define ESDCTL_SMODE_NORMAL	(0 << 28)
337819833afSPeter Tyser #define ESDCTL_SMODE_PRECHARGE	(1 << 28)
338819833afSPeter Tyser #define ESDCTL_SMODE_AUTO_REF	(2 << 28)
339819833afSPeter Tyser #define ESDCTL_SMODE_LOAD_MODE	(3 << 28)
340819833afSPeter Tyser #define ESDCTL_SMODE_MAN_REF	(4 << 28)
341819833afSPeter Tyser #define ESDCTL_SDE		(1 << 31)
342819833afSPeter Tyser 
343819833afSPeter Tyser #define ESDCFG_TRC(x)		(((x) & 0xf) << 0)
344819833afSPeter Tyser #define ESDCFG_TRCD(x)		(((x) & 0x7) << 4)
345819833afSPeter Tyser #define ESDCFG_TCAS(x)		(((x) & 0x3) << 8)
346819833afSPeter Tyser #define ESDCFG_TRRD(x)		(((x) & 0x3) << 10)
347819833afSPeter Tyser #define ESDCFG_TRAS(x)		(((x) & 0x7) << 12)
348819833afSPeter Tyser #define ESDCFG_TWR		(1 << 15)
349819833afSPeter Tyser #define ESDCFG_TMRD(x)		(((x) & 0x3) << 16)
350819833afSPeter Tyser #define ESDCFG_TRP(x)		(((x) & 0x3) << 18)
351819833afSPeter Tyser #define ESDCFG_TWTR		(1 << 20)
352819833afSPeter Tyser #define ESDCFG_TXP(x)		(((x) & 0x3) << 21)
353819833afSPeter Tyser 
354819833afSPeter Tyser #define ESDMISC_RST		(1 << 1)
355819833afSPeter Tyser #define ESDMISC_MDDREN		(1 << 2)
356819833afSPeter Tyser #define ESDMISC_MDDR_DL_RST	(1 << 3)
357819833afSPeter Tyser #define ESDMISC_MDDR_MDIS	(1 << 4)
358819833afSPeter Tyser #define ESDMISC_LHD		(1 << 5)
359819833afSPeter Tyser #define ESDMISC_MA10_SHARE	(1 << 6)
360819833afSPeter Tyser #define ESDMISC_SDRAM_RDY	(1 << 31)
361819833afSPeter Tyser 
362819833afSPeter Tyser #define PC5_PF_I2C2_DATA	(GPIO_PORTC | GPIO_OUT | GPIO_PF | 5)
363819833afSPeter Tyser #define PC6_PF_I2C2_CLK		(GPIO_PORTC | GPIO_OUT | GPIO_PF | 6)
364819833afSPeter Tyser #define PC7_PF_USBOTG_DATA5	(GPIO_PORTC | GPIO_OUT | GPIO_PF | 7)
365819833afSPeter Tyser #define PC8_PF_USBOTG_DATA6	(GPIO_PORTC | GPIO_OUT | GPIO_PF | 8)
366819833afSPeter Tyser #define PC9_PF_USBOTG_DATA0	(GPIO_PORTC | GPIO_OUT | GPIO_PF | 9)
367819833afSPeter Tyser #define PC10_PF_USBOTG_DATA2	(GPIO_PORTC | GPIO_OUT | GPIO_PF | 10)
368819833afSPeter Tyser #define PC11_PF_USBOTG_DATA1	(GPIO_PORTC | GPIO_OUT | GPIO_PF | 11)
369819833afSPeter Tyser #define PC12_PF_USBOTG_DATA4	(GPIO_PORTC | GPIO_OUT | GPIO_PF | 12)
370819833afSPeter Tyser #define PC13_PF_USBOTG_DATA3	(GPIO_PORTC | GPIO_OUT | GPIO_PF | 13)
371819833afSPeter Tyser 
372819833afSPeter Tyser #define PD0_AIN_FEC_TXD0	(GPIO_PORTD | GPIO_OUT | GPIO_AIN | 0)
373819833afSPeter Tyser #define PD1_AIN_FEC_TXD1	(GPIO_PORTD | GPIO_OUT | GPIO_AIN | 1)
374819833afSPeter Tyser #define PD2_AIN_FEC_TXD2	(GPIO_PORTD | GPIO_OUT | GPIO_AIN | 2)
375819833afSPeter Tyser #define PD3_AIN_FEC_TXD3	(GPIO_PORTD | GPIO_OUT | GPIO_AIN | 3)
376819833afSPeter Tyser #define PD4_AOUT_FEC_RX_ER	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 4)
377819833afSPeter Tyser #define PD5_AOUT_FEC_RXD1	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 5)
378819833afSPeter Tyser #define PD6_AOUT_FEC_RXD2	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 6)
379819833afSPeter Tyser #define PD7_AOUT_FEC_RXD3	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 7)
380819833afSPeter Tyser #define PD8_AF_FEC_MDIO		(GPIO_PORTD | GPIO_IN | GPIO_AF | 8)
381819833afSPeter Tyser #define PD9_AIN_FEC_MDC		(GPIO_PORTD | GPIO_OUT | GPIO_AIN | 9)
382819833afSPeter Tyser #define PD10_AOUT_FEC_CRS	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 10)
383819833afSPeter Tyser #define PD11_AOUT_FEC_TX_CLK	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 11)
384819833afSPeter Tyser #define PD12_AOUT_FEC_RXD0	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 12)
385819833afSPeter Tyser #define PD13_AOUT_FEC_RX_DV	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 13)
386819833afSPeter Tyser #define PD14_AOUT_FEC_CLR	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 14)
387819833afSPeter Tyser #define PD15_AOUT_FEC_COL	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 15)
388819833afSPeter Tyser #define PD16_AIN_FEC_TX_ER	(GPIO_PORTD | GPIO_OUT | GPIO_AIN | 16)
389819833afSPeter Tyser #define PF23_AIN_FEC_TX_EN	(GPIO_PORTF | GPIO_OUT | GPIO_AIN | 23)
390819833afSPeter Tyser 
391819833afSPeter Tyser #define PE0_PF_USBOTG_NXT	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 0)
392819833afSPeter Tyser #define PE1_PF_USBOTG_STP	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 1)
393819833afSPeter Tyser #define PE2_PF_USBOTG_DIR	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 2)
394819833afSPeter Tyser #define PE3_PF_UART2_CTS	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 3)
395819833afSPeter Tyser #define PE4_PF_UART2_RTS	(GPIO_PORTE | GPIO_IN  | GPIO_PF | 4)
396819833afSPeter Tyser #define PE6_PF_UART2_TXD	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 6)
397819833afSPeter Tyser #define PE7_PF_UART2_RXD	(GPIO_PORTE | GPIO_IN  | GPIO_PF | 7)
398819833afSPeter Tyser #define PE8_PF_UART3_TXD	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 8)
399819833afSPeter Tyser #define PE9_PF_UART3_RXD	(GPIO_PORTE | GPIO_IN  | GPIO_PF | 9)
400819833afSPeter Tyser #define PE10_PF_UART3_CTS	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 10)
401819833afSPeter Tyser #define PE11_PF_UART3_RTS	(GPIO_PORTE | GPIO_IN  | GPIO_PF | 11)
402819833afSPeter Tyser #define PE12_PF_UART1_TXD	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 12)
403819833afSPeter Tyser #define PE13_PF_UART1_RXD	(GPIO_PORTE | GPIO_IN  | GPIO_PF | 13)
404819833afSPeter Tyser #define PE14_PF_UART1_CTS	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 14)
405819833afSPeter Tyser #define PE15_PF_UART1_RTS	(GPIO_PORTE | GPIO_IN  | GPIO_PF | 15)
406819833afSPeter Tyser #define PE18_PF_SD1_D0		(GPIO_PORTE | GPIO_PF | 18)
407819833afSPeter Tyser #define PE19_PF_SD1_D1		(GPIO_PORTE | GPIO_PF | 19)
408819833afSPeter Tyser #define PE20_PF_SD1_D2		(GPIO_PORTE | GPIO_PF | 20)
409819833afSPeter Tyser #define PE21_PF_SD1_D3		(GPIO_PORTE | GPIO_PF | 21)
410819833afSPeter Tyser #define PE22_PF_SD1_CMD		(GPIO_PORTE | GPIO_PF | 22)
411819833afSPeter Tyser #define PE23_PF_SD1_CLK		(GPIO_PORTE | GPIO_PF | 23)
412819833afSPeter Tyser #define PB4_PF_SD2_D0		(GPIO_PORTB | GPIO_PF | 4)
413819833afSPeter Tyser #define PB5_PF_SD2_D1		(GPIO_PORTB | GPIO_PF | 5)
414819833afSPeter Tyser #define PB6_PF_SD2_D2		(GPIO_PORTB | GPIO_PF | 6)
415819833afSPeter Tyser #define PB7_PF_SD2_D3		(GPIO_PORTB | GPIO_PF | 7)
416819833afSPeter Tyser #define PB8_PF_SD2_CMD		(GPIO_PORTB | GPIO_PF | 8)
417819833afSPeter Tyser #define PB9_PF_SD2_CLK		(GPIO_PORTB | GPIO_PF | 9)
418819833afSPeter Tyser #define PD17_PF_I2C_DATA	(GPIO_PORTD | GPIO_OUT | GPIO_PF | 17)
419819833afSPeter Tyser #define PD18_PF_I2C_CLK		(GPIO_PORTD | GPIO_OUT | GPIO_PF | 18)
420819833afSPeter Tyser #define PE24_PF_USBOTG_CLK	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 24)
421819833afSPeter Tyser #define PE25_PF_USBOTG_DATA7	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 25)
422819833afSPeter Tyser 
423819833afSPeter Tyser /* Clocksource Bitfields */
424819833afSPeter Tyser #define TCTL_SWR	(1 << 15)	/* Software reset */
425819833afSPeter Tyser #define TCTL_FRR	(1 << 8)	/* Freerun / restart */
426819833afSPeter Tyser #define TCTL_CAP	(3 << 6)	/* Capture Edge */
427819833afSPeter Tyser #define TCTL_OM		(1 << 5)	/* output mode */
428819833afSPeter Tyser #define TCTL_IRQEN	(1 << 4)	/* interrupt enable */
429819833afSPeter Tyser #define TCTL_CLKSOURCE	1		/* Clock source bit position */
430819833afSPeter Tyser #define TCTL_TEN	1		/* Timer enable */
431819833afSPeter Tyser #define TPRER_PRES	0xff		/* Prescale */
432819833afSPeter Tyser #define TSTAT_CAPT	(1 << 1)	/* Capture event */
433819833afSPeter Tyser #define TSTAT_COMP	1		/* Compare event */
434819833afSPeter Tyser 
435e71c39deStrem #define GPIO1_BASE_ADDR 0x10015000
436e71c39deStrem #define GPIO2_BASE_ADDR 0x10015100
437e71c39deStrem #define GPIO3_BASE_ADDR 0x10015200
438e71c39deStrem #define GPIO4_BASE_ADDR 0x10015300
439e71c39deStrem #define GPIO5_BASE_ADDR 0x10015400
440e71c39deStrem #define GPIO6_BASE_ADDR 0x10015500
441e71c39deStrem 
442819833afSPeter Tyser #define GPIO_OUT	(1 << 8)
443819833afSPeter Tyser #define GPIO_IN		(0 << 8)
444819833afSPeter Tyser #define GPIO_PUEN	(1 << 9)
445819833afSPeter Tyser 
446819833afSPeter Tyser #define GPIO_PF		(1 << 10)
447819833afSPeter Tyser #define GPIO_AF		(1 << 11)
448819833afSPeter Tyser 
449819833afSPeter Tyser #define GPIO_OCR_SHIFT	12
450819833afSPeter Tyser #define GPIO_OCR_MASK	(3 << GPIO_OCR_SHIFT)
451819833afSPeter Tyser #define GPIO_AIN	(0 << GPIO_OCR_SHIFT)
452819833afSPeter Tyser #define GPIO_BIN	(1 << GPIO_OCR_SHIFT)
453819833afSPeter Tyser #define GPIO_CIN	(2 << GPIO_OCR_SHIFT)
454819833afSPeter Tyser #define GPIO_GPIO	(3 << GPIO_OCR_SHIFT)
455819833afSPeter Tyser 
456819833afSPeter Tyser #define GPIO_AOUT_SHIFT	14
457819833afSPeter Tyser #define GPIO_AOUT_MASK	(3 << GPIO_AOUT_SHIFT)
458819833afSPeter Tyser #define GPIO_AOUT	(0 << GPIO_AOUT_SHIFT)
459819833afSPeter Tyser #define GPIO_AOUT_ISR	(1 << GPIO_AOUT_SHIFT)
460819833afSPeter Tyser #define GPIO_AOUT_0	(2 << GPIO_AOUT_SHIFT)
461819833afSPeter Tyser #define GPIO_AOUT_1	(3 << GPIO_AOUT_SHIFT)
462819833afSPeter Tyser 
463819833afSPeter Tyser #define GPIO_BOUT_SHIFT	16
464819833afSPeter Tyser #define GPIO_BOUT_MASK	(3 << GPIO_BOUT_SHIFT)
465819833afSPeter Tyser #define GPIO_BOUT	(0 << GPIO_BOUT_SHIFT)
466819833afSPeter Tyser #define GPIO_BOUT_ISR	(1 << GPIO_BOUT_SHIFT)
467819833afSPeter Tyser #define GPIO_BOUT_0	(2 << GPIO_BOUT_SHIFT)
468819833afSPeter Tyser #define GPIO_BOUT_1	(3 << GPIO_BOUT_SHIFT)
469819833afSPeter Tyser 
470819833afSPeter Tyser #define IIM_STAT_BUSY	(1 << 7)
471819833afSPeter Tyser #define IIM_STAT_PRGD	(1 << 1)
472819833afSPeter Tyser #define IIM_STAT_SNSD	(1 << 0)
473819833afSPeter Tyser #define IIM_ERR_PRGE	(1 << 7)
474819833afSPeter Tyser #define IIM_ERR_WPE	(1 << 6)
475819833afSPeter Tyser #define IIM_ERR_OPE	(1 << 5)
476819833afSPeter Tyser #define IIM_ERR_RPE	(1 << 4)
477819833afSPeter Tyser #define IIM_ERR_WLRE	(1 << 3)
478819833afSPeter Tyser #define IIM_ERR_SNSE	(1 << 2)
479819833afSPeter Tyser #define IIM_ERR_PARITYE	(1 << 1)
480819833afSPeter Tyser 
481819833afSPeter Tyser #endif				/* _IMX_REGS_H */
482