xref: /rk3399_rockchip-uboot/arch/arm/include/asm/arch-mx27/imx-regs.h (revision 78befb695d0b28d9888fe5dee27dc80b24eac1c9)
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  *
5819833afSPeter Tyser  * See file CREDITS for list of people who contributed to this
6819833afSPeter Tyser  * project.
7819833afSPeter Tyser  *
8819833afSPeter Tyser  * This program is free software; you can redistribute it and/or
9819833afSPeter Tyser  * modify it under the terms of the GNU General Public License as
10819833afSPeter Tyser  * published by the Free Software Foundation; either version 2 of
11819833afSPeter Tyser  * the License, or (at your option) any later version.
12819833afSPeter Tyser  *
13819833afSPeter Tyser  * This program is distributed in the hope that it will be useful,
14819833afSPeter Tyser  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15819833afSPeter Tyser  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16819833afSPeter Tyser  * GNU General Public License for more details.
17819833afSPeter Tyser  *
18819833afSPeter Tyser  * You should have received a copy of the GNU General Public License
19819833afSPeter Tyser  * along with this program; if not, write to the Free Software
20819833afSPeter Tyser  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
21819833afSPeter Tyser  * MA 02111-1307 USA
22819833afSPeter Tyser  */
23819833afSPeter Tyser 
24819833afSPeter Tyser #ifndef _IMX_REGS_H
25819833afSPeter Tyser #define _IMX_REGS_H
26819833afSPeter Tyser 
27*78befb69Strem #include <asm/arch/regs-rtc.h>
28*78befb69Strem 
29819833afSPeter Tyser #ifndef __ASSEMBLY__
30819833afSPeter Tyser 
31819833afSPeter Tyser extern void imx_gpio_mode (int gpio_mode);
32819833afSPeter Tyser 
33819833afSPeter Tyser #ifdef CONFIG_MXC_UART
343f7bfbddSFabio Estevam extern void mx27_uart1_init_pins(void);
35819833afSPeter Tyser #endif /* CONFIG_MXC_UART */
36819833afSPeter Tyser 
37819833afSPeter Tyser #ifdef CONFIG_FEC_MXC
38819833afSPeter Tyser extern void mx27_fec_init_pins(void);
39819833afSPeter Tyser #endif /* CONFIG_FEC_MXC */
40819833afSPeter Tyser 
41819833afSPeter Tyser #ifdef CONFIG_MXC_MMC
421e65c2beSHeiko Schocher extern void mx27_sd1_init_pins(void);
43819833afSPeter Tyser extern void mx27_sd2_init_pins(void);
44819833afSPeter Tyser #endif /* CONFIG_MXC_MMC */
45819833afSPeter Tyser 
46819833afSPeter Tyser /* AIPI */
47819833afSPeter Tyser struct aipi_regs {
48819833afSPeter Tyser 	u32 psr0;
49819833afSPeter Tyser 	u32 psr1;
50819833afSPeter Tyser };
51819833afSPeter Tyser 
52819833afSPeter Tyser /* System Control */
53819833afSPeter Tyser struct system_control_regs {
54819833afSPeter Tyser 	u32 res[5];
55819833afSPeter Tyser 	u32 fmcr;
56819833afSPeter Tyser 	u32 gpcr;
57819833afSPeter Tyser 	u32 wbcr;
58819833afSPeter Tyser 	u32 dscr1;
59819833afSPeter Tyser 	u32 dscr2;
60819833afSPeter Tyser 	u32 dscr3;
61819833afSPeter Tyser 	u32 dscr4;
62819833afSPeter Tyser 	u32 dscr5;
63819833afSPeter Tyser 	u32 dscr6;
64819833afSPeter Tyser 	u32 dscr7;
65819833afSPeter Tyser 	u32 dscr8;
66819833afSPeter Tyser 	u32 dscr9;
67819833afSPeter Tyser 	u32 dscr10;
68819833afSPeter Tyser 	u32 dscr11;
69819833afSPeter Tyser 	u32 dscr12;
70819833afSPeter Tyser 	u32 dscr13;
71819833afSPeter Tyser 	u32 pscr;
72819833afSPeter Tyser 	u32 pmcr;
73819833afSPeter Tyser 	u32 res1;
74819833afSPeter Tyser 	u32 dcvr0;
75819833afSPeter Tyser 	u32 dcvr1;
76819833afSPeter Tyser 	u32 dcvr2;
77819833afSPeter Tyser 	u32 dcvr3;
78819833afSPeter Tyser };
79819833afSPeter Tyser 
80819833afSPeter Tyser /* Chip Select Registers */
81819833afSPeter Tyser struct weim_regs {
82819833afSPeter Tyser 	u32 cs0u;	/* Chip Select 0 Upper Register */
83819833afSPeter Tyser 	u32 cs0l;	/* Chip Select 0 Lower Register */
84819833afSPeter Tyser 	u32 cs0a;	/* Chip Select 0 Addition Register */
85819833afSPeter Tyser 	u32 pad0;
86819833afSPeter Tyser 	u32 cs1u;	/* Chip Select 1 Upper Register */
87819833afSPeter Tyser 	u32 cs1l;	/* Chip Select 1 Lower Register */
88819833afSPeter Tyser 	u32 cs1a;	/* Chip Select 1 Addition Register */
89819833afSPeter Tyser 	u32 pad1;
90819833afSPeter Tyser 	u32 cs2u;	/* Chip Select 2 Upper Register */
91819833afSPeter Tyser 	u32 cs2l;	/* Chip Select 2 Lower Register */
92819833afSPeter Tyser 	u32 cs2a;	/* Chip Select 2 Addition Register */
93819833afSPeter Tyser 	u32 pad2;
94819833afSPeter Tyser 	u32 cs3u;	/* Chip Select 3 Upper Register */
95819833afSPeter Tyser 	u32 cs3l;	/* Chip Select 3 Lower Register */
96819833afSPeter Tyser 	u32 cs3a;	/* Chip Select 3 Addition Register */
97819833afSPeter Tyser 	u32 pad3;
98819833afSPeter Tyser 	u32 cs4u;	/* Chip Select 4 Upper Register */
99819833afSPeter Tyser 	u32 cs4l;	/* Chip Select 4 Lower Register */
100819833afSPeter Tyser 	u32 cs4a;	/* Chip Select 4 Addition Register */
101819833afSPeter Tyser 	u32 pad4;
102819833afSPeter Tyser 	u32 cs5u;	/* Chip Select 5 Upper Register */
103819833afSPeter Tyser 	u32 cs5l;	/* Chip Select 5 Lower Register */
104819833afSPeter Tyser 	u32 cs5a;	/* Chip Select 5 Addition Register */
105819833afSPeter Tyser 	u32 pad5;
106819833afSPeter Tyser 	u32 eim;	/* WEIM Configuration Register */
107819833afSPeter Tyser };
108819833afSPeter Tyser 
109819833afSPeter Tyser /* SDRAM Controller registers */
110819833afSPeter Tyser struct esdramc_regs {
111819833afSPeter Tyser /* Enhanced SDRAM Control Register 0 */
112819833afSPeter Tyser 	u32 esdctl0;
113819833afSPeter Tyser /* Enhanced SDRAM Configuration Register 0 */
114819833afSPeter Tyser 	u32 esdcfg0;
115819833afSPeter Tyser /* Enhanced SDRAM Control Register 1 */
116819833afSPeter Tyser 	u32 esdctl1;
117819833afSPeter Tyser /* Enhanced SDRAM Configuration Register 1 */
118819833afSPeter Tyser 	u32 esdcfg1;
119819833afSPeter Tyser /* Enhanced SDRAM Miscellanious Register */
120819833afSPeter Tyser 	u32 esdmisc;
121819833afSPeter Tyser };
122819833afSPeter Tyser 
123819833afSPeter Tyser /* Watchdog Registers*/
124819833afSPeter Tyser struct wdog_regs {
125819833afSPeter Tyser 	u32 wcr;
126819833afSPeter Tyser 	u32 wsr;
127819833afSPeter Tyser 	u32 wstr;
128819833afSPeter Tyser };
129819833afSPeter Tyser 
130819833afSPeter Tyser /* PLL registers */
131819833afSPeter Tyser struct pll_regs {
132819833afSPeter Tyser 	u32 cscr;	/* Clock Source Control Register */
133819833afSPeter Tyser 	u32 mpctl0;	/* MCU PLL Control Register 0 */
134819833afSPeter Tyser 	u32 mpctl1;	/* MCU PLL Control Register 1 */
135819833afSPeter Tyser 	u32 spctl0;	/* System PLL Control Register 0 */
136819833afSPeter Tyser 	u32 spctl1;	/* System PLL Control Register 1 */
137819833afSPeter Tyser 	u32 osc26mctl;	/* Oscillator 26M Register */
138819833afSPeter Tyser 	u32 pcdr0;	/* Peripheral Clock Divider Register 0 */
139819833afSPeter Tyser 	u32 pcdr1;	/* Peripheral Clock Divider Register 1 */
140819833afSPeter Tyser 	u32 pccr0;	/* Peripheral Clock Control Register 0 */
141819833afSPeter Tyser 	u32 pccr1;	/* Peripheral Clock Control Register 1 */
142819833afSPeter Tyser 	u32 ccsr;	/* Clock Control Status Register */
143819833afSPeter Tyser };
144819833afSPeter Tyser 
145819833afSPeter Tyser /*
146819833afSPeter Tyser  * Definitions for the clocksource registers
147819833afSPeter Tyser  */
148819833afSPeter Tyser struct gpt_regs {
149819833afSPeter Tyser 	u32 gpt_tctl;
150819833afSPeter Tyser 	u32 gpt_tprer;
151819833afSPeter Tyser 	u32 gpt_tcmp;
152819833afSPeter Tyser 	u32 gpt_tcr;
153819833afSPeter Tyser 	u32 gpt_tcn;
154819833afSPeter Tyser 	u32 gpt_tstat;
155819833afSPeter Tyser };
156819833afSPeter Tyser 
157819833afSPeter Tyser /*
158819833afSPeter Tyser  *  GPIO Module and I/O Multiplexer
159819833afSPeter Tyser  */
160819833afSPeter Tyser #define PORTA 0
161819833afSPeter Tyser #define PORTB 1
162819833afSPeter Tyser #define PORTC 2
163819833afSPeter Tyser #define PORTD 3
164819833afSPeter Tyser #define PORTE 4
165819833afSPeter Tyser #define PORTF 5
166819833afSPeter Tyser 
167819833afSPeter Tyser struct gpio_regs {
168819833afSPeter Tyser 	struct {
169819833afSPeter Tyser 		u32 ddir;
170819833afSPeter Tyser 		u32 ocr1;
171819833afSPeter Tyser 		u32 ocr2;
172819833afSPeter Tyser 		u32 iconfa1;
173819833afSPeter Tyser 		u32 iconfa2;
174819833afSPeter Tyser 		u32 iconfb1;
175819833afSPeter Tyser 		u32 iconfb2;
176819833afSPeter Tyser 		u32 dr;
177819833afSPeter Tyser 		u32 gius;
178819833afSPeter Tyser 		u32 ssr;
179819833afSPeter Tyser 		u32 icr1;
180819833afSPeter Tyser 		u32 icr2;
181819833afSPeter Tyser 		u32 imr;
182819833afSPeter Tyser 		u32 isr;
183819833afSPeter Tyser 		u32 gpr;
184819833afSPeter Tyser 		u32 swr;
185819833afSPeter Tyser 		u32 puen;
186819833afSPeter Tyser 		u32 res[0x2f];
187819833afSPeter Tyser 	} port[6];
188819833afSPeter Tyser };
189819833afSPeter Tyser 
190819833afSPeter Tyser /* IIM Control Registers */
191819833afSPeter Tyser struct iim_regs {
192819833afSPeter Tyser 	u32 iim_stat;
193819833afSPeter Tyser 	u32 iim_statm;
194819833afSPeter Tyser 	u32 iim_err;
195819833afSPeter Tyser 	u32 iim_emask;
196819833afSPeter Tyser 	u32 iim_fctl;
197819833afSPeter Tyser 	u32 iim_ua;
198819833afSPeter Tyser 	u32 iim_la;
199819833afSPeter Tyser 	u32 iim_sdat;
200819833afSPeter Tyser 	u32 iim_prev;
201819833afSPeter Tyser 	u32 iim_srev;
202819833afSPeter Tyser 	u32 iim_prog_p;
203819833afSPeter Tyser 	u32 iim_scs0;
204819833afSPeter Tyser 	u32 iim_scs1;
205819833afSPeter Tyser 	u32 iim_scs2;
206819833afSPeter Tyser 	u32 iim_scs3;
207565e39c5SLiu Hui-R64343 	u32 res[0x1f1];
208565e39c5SLiu Hui-R64343 	struct fuse_bank {
209565e39c5SLiu Hui-R64343 		u32 fuse_regs[0x20];
210565e39c5SLiu Hui-R64343 		u32 fuse_rsvd[0xe0];
211565e39c5SLiu Hui-R64343 	} bank[1];
212819833afSPeter Tyser };
213565e39c5SLiu Hui-R64343 
214565e39c5SLiu Hui-R64343 struct fuse_bank0_regs {
215565e39c5SLiu Hui-R64343 	u32 fuse0_3[5];
216565e39c5SLiu Hui-R64343 	u32 mac_addr[6];
217565e39c5SLiu Hui-R64343 	u32 fuse10_31[0x16];
218565e39c5SLiu Hui-R64343 };
219565e39c5SLiu Hui-R64343 
220819833afSPeter Tyser #endif
221819833afSPeter Tyser 
222819833afSPeter Tyser #define IMX_IO_BASE		0x10000000
223819833afSPeter Tyser 
224819833afSPeter Tyser #define IMX_AIPI1_BASE		(0x00000 + IMX_IO_BASE)
225819833afSPeter Tyser #define IMX_WDT_BASE		(0x02000 + IMX_IO_BASE)
226819833afSPeter Tyser #define IMX_TIM1_BASE		(0x03000 + IMX_IO_BASE)
227819833afSPeter Tyser #define IMX_TIM2_BASE		(0x04000 + IMX_IO_BASE)
228819833afSPeter Tyser #define IMX_TIM3_BASE		(0x05000 + IMX_IO_BASE)
229*78befb69Strem #define IMX_RTC_BASE		(0x07000 + IMX_IO_BASE)
23040f6fffeSStefano Babic #define UART1_BASE		(0x0a000 + IMX_IO_BASE)
23140f6fffeSStefano Babic #define UART2_BASE		(0x0b000 + IMX_IO_BASE)
23240f6fffeSStefano Babic #define UART3_BASE		(0x0c000 + IMX_IO_BASE)
23340f6fffeSStefano Babic #define UART4_BASE		(0x0d000 + IMX_IO_BASE)
234819833afSPeter Tyser #define IMX_I2C1_BASE		(0x12000 + IMX_IO_BASE)
235819833afSPeter Tyser #define IMX_GPIO_BASE		(0x15000 + IMX_IO_BASE)
236819833afSPeter Tyser #define IMX_TIM4_BASE		(0x19000 + IMX_IO_BASE)
237819833afSPeter Tyser #define IMX_TIM5_BASE		(0x1a000 + IMX_IO_BASE)
238819833afSPeter Tyser #define IMX_UART5_BASE		(0x1b000 + IMX_IO_BASE)
239819833afSPeter Tyser #define IMX_UART6_BASE		(0x1c000 + IMX_IO_BASE)
240819833afSPeter Tyser #define IMX_I2C2_BASE		(0x1D000 + IMX_IO_BASE)
241819833afSPeter Tyser #define IMX_TIM6_BASE		(0x1f000 + IMX_IO_BASE)
242819833afSPeter Tyser #define IMX_AIPI2_BASE		(0x20000 + IMX_IO_BASE)
243819833afSPeter Tyser #define IMX_PLL_BASE		(0x27000 + IMX_IO_BASE)
244819833afSPeter Tyser #define IMX_SYSTEM_CTL_BASE	(0x27800 + IMX_IO_BASE)
245819833afSPeter Tyser #define IMX_IIM_BASE		(0x28000 + IMX_IO_BASE)
246819833afSPeter Tyser #define IMX_FEC_BASE		(0x2b000 + IMX_IO_BASE)
247819833afSPeter Tyser 
248819833afSPeter Tyser #define IMX_ESD_BASE		(0xD8001000)
249819833afSPeter Tyser #define IMX_WEIM_BASE		(0xD8002000)
250819833afSPeter Tyser 
251819833afSPeter Tyser /* FMCR System Control bit definition*/
252819833afSPeter Tyser #define UART4_RXD_CTL	(1 << 25)
253819833afSPeter Tyser #define UART4_RTS_CTL	(1 << 24)
254819833afSPeter Tyser #define KP_COL6_CTL	(1 << 18)
255819833afSPeter Tyser #define KP_ROW7_CTL	(1 << 17)
256819833afSPeter Tyser #define KP_ROW6_CTL	(1 << 16)
257819833afSPeter Tyser #define PC_WAIT_B_CTL	(1 << 14)
258819833afSPeter Tyser #define PC_READY_CTL	(1 << 13)
259819833afSPeter Tyser #define PC_VS1_CTL	(1 << 12)
260819833afSPeter Tyser #define PC_VS2_CTL	(1 << 11)
261819833afSPeter Tyser #define PC_BVD1_CTL	(1 << 10)
262819833afSPeter Tyser #define PC_BVD2_CTL	(1 << 9)
263819833afSPeter Tyser #define IOS16_CTL	(1 << 8)
264819833afSPeter Tyser #define NF_FMS		(1 << 5)
265819833afSPeter Tyser #define NF_16BIT_SEL	(1 << 4)
266819833afSPeter Tyser #define SLCDC_SEL	(1 << 2)
267819833afSPeter Tyser #define SDCS1_SEL	(1 << 1)
268819833afSPeter Tyser #define SDCS0_SEL	(1 << 0)
269819833afSPeter Tyser 
270819833afSPeter Tyser 
271819833afSPeter Tyser /* important definition of some bits of WCR */
272819833afSPeter Tyser #define WCR_WDE 0x04
273819833afSPeter Tyser 
274819833afSPeter Tyser #define CSCR_MPEN		(1 << 0)
275819833afSPeter Tyser #define CSCR_SPEN		(1 << 1)
276819833afSPeter Tyser #define CSCR_FPM_EN		(1 << 2)
277819833afSPeter Tyser #define CSCR_OSC26M_DIS		(1 << 3)
278819833afSPeter Tyser #define CSCR_OSC26M_DIV1P5	(1 << 4)
279819833afSPeter Tyser #define CSCR_AHB_DIV
280819833afSPeter Tyser #define CSCR_ARM_DIV
281819833afSPeter Tyser #define CSCR_ARM_SRC_MPLL	(1 << 15)
282819833afSPeter Tyser #define CSCR_MCU_SEL		(1 << 16)
283819833afSPeter Tyser #define CSCR_SP_SEL		(1 << 17)
284819833afSPeter Tyser #define CSCR_MPLL_RESTART	(1 << 18)
285819833afSPeter Tyser #define CSCR_SPLL_RESTART	(1 << 19)
286819833afSPeter Tyser #define CSCR_MSHC_SEL		(1 << 20)
287819833afSPeter Tyser #define CSCR_H264_SEL		(1 << 21)
288819833afSPeter Tyser #define CSCR_SSI1_SEL		(1 << 22)
289819833afSPeter Tyser #define CSCR_SSI2_SEL		(1 << 23)
290819833afSPeter Tyser #define CSCR_SD_CNT
291819833afSPeter Tyser #define CSCR_USB_DIV
292819833afSPeter Tyser #define CSCR_UPDATE_DIS		(1 << 31)
293819833afSPeter Tyser 
294819833afSPeter Tyser #define MPCTL1_BRMO		(1 << 6)
295819833afSPeter Tyser #define MPCTL1_LF		(1 << 15)
296819833afSPeter Tyser 
297819833afSPeter Tyser #define PCCR0_SSI2_EN	(1 << 0)
298819833afSPeter Tyser #define PCCR0_SSI1_EN	(1 << 1)
299819833afSPeter Tyser #define PCCR0_SLCDC_EN	(1 << 2)
300819833afSPeter Tyser #define PCCR0_SDHC3_EN	(1 << 3)
301819833afSPeter Tyser #define PCCR0_SDHC2_EN	(1 << 4)
302819833afSPeter Tyser #define PCCR0_SDHC1_EN	(1 << 5)
303819833afSPeter Tyser #define PCCR0_SDC_EN	(1 << 6)
304819833afSPeter Tyser #define PCCR0_SAHARA_EN	(1 << 7)
305819833afSPeter Tyser #define PCCR0_RTIC_EN	(1 << 8)
306819833afSPeter Tyser #define PCCR0_RTC_EN	(1 << 9)
307819833afSPeter Tyser #define PCCR0_PWM_EN	(1 << 11)
308819833afSPeter Tyser #define PCCR0_OWIRE_EN	(1 << 12)
309819833afSPeter Tyser #define PCCR0_MSHC_EN	(1 << 13)
310819833afSPeter Tyser #define PCCR0_LCDC_EN	(1 << 14)
311819833afSPeter Tyser #define PCCR0_KPP_EN	(1 << 15)
312819833afSPeter Tyser #define PCCR0_IIM_EN	(1 << 16)
313819833afSPeter Tyser #define PCCR0_I2C2_EN	(1 << 17)
314819833afSPeter Tyser #define PCCR0_I2C1_EN	(1 << 18)
315819833afSPeter Tyser #define PCCR0_GPT6_EN	(1 << 19)
316819833afSPeter Tyser #define PCCR0_GPT5_EN	(1 << 20)
317819833afSPeter Tyser #define PCCR0_GPT4_EN	(1 << 21)
318819833afSPeter Tyser #define PCCR0_GPT3_EN	(1 << 22)
319819833afSPeter Tyser #define PCCR0_GPT2_EN	(1 << 23)
320819833afSPeter Tyser #define PCCR0_GPT1_EN	(1 << 24)
321819833afSPeter Tyser #define PCCR0_GPIO_EN	(1 << 25)
322819833afSPeter Tyser #define PCCR0_FEC_EN	(1 << 26)
323819833afSPeter Tyser #define PCCR0_EMMA_EN	(1 << 27)
324819833afSPeter Tyser #define PCCR0_DMA_EN	(1 << 28)
325819833afSPeter Tyser #define PCCR0_CSPI3_EN	(1 << 29)
326819833afSPeter Tyser #define PCCR0_CSPI2_EN	(1 << 30)
327819833afSPeter Tyser #define PCCR0_CSPI1_EN	(1 << 31)
328819833afSPeter Tyser 
329819833afSPeter Tyser #define PCCR1_MSHC_BAUDEN	(1 << 2)
330819833afSPeter Tyser #define PCCR1_NFC_BAUDEN	(1 << 3)
331819833afSPeter Tyser #define PCCR1_SSI2_BAUDEN	(1 << 4)
332819833afSPeter Tyser #define PCCR1_SSI1_BAUDEN	(1 << 5)
333819833afSPeter Tyser #define PCCR1_H264_BAUDEN	(1 << 6)
334819833afSPeter Tyser #define PCCR1_PERCLK4_EN	(1 << 7)
335819833afSPeter Tyser #define PCCR1_PERCLK3_EN	(1 << 8)
336819833afSPeter Tyser #define PCCR1_PERCLK2_EN	(1 << 9)
337819833afSPeter Tyser #define PCCR1_PERCLK1_EN	(1 << 10)
338819833afSPeter Tyser #define PCCR1_HCLK_USB		(1 << 11)
339819833afSPeter Tyser #define PCCR1_HCLK_SLCDC	(1 << 12)
340819833afSPeter Tyser #define PCCR1_HCLK_SAHARA	(1 << 13)
341819833afSPeter Tyser #define PCCR1_HCLK_RTIC		(1 << 14)
342819833afSPeter Tyser #define PCCR1_HCLK_LCDC		(1 << 15)
343819833afSPeter Tyser #define PCCR1_HCLK_H264		(1 << 16)
344819833afSPeter Tyser #define PCCR1_HCLK_FEC		(1 << 17)
345819833afSPeter Tyser #define PCCR1_HCLK_EMMA		(1 << 18)
346819833afSPeter Tyser #define PCCR1_HCLK_EMI		(1 << 19)
347819833afSPeter Tyser #define PCCR1_HCLK_DMA		(1 << 20)
348819833afSPeter Tyser #define PCCR1_HCLK_CSI		(1 << 21)
349819833afSPeter Tyser #define PCCR1_HCLK_BROM		(1 << 22)
350819833afSPeter Tyser #define PCCR1_HCLK_ATA		(1 << 23)
351819833afSPeter Tyser #define PCCR1_WDT_EN		(1 << 24)
352819833afSPeter Tyser #define PCCR1_USB_EN		(1 << 25)
353819833afSPeter Tyser #define PCCR1_UART6_EN		(1 << 26)
354819833afSPeter Tyser #define PCCR1_UART5_EN		(1 << 27)
355819833afSPeter Tyser #define PCCR1_UART4_EN		(1 << 28)
356819833afSPeter Tyser #define PCCR1_UART3_EN		(1 << 29)
357819833afSPeter Tyser #define PCCR1_UART2_EN		(1 << 30)
358819833afSPeter Tyser #define PCCR1_UART1_EN		(1 << 31)
359819833afSPeter Tyser 
360819833afSPeter Tyser /* SDRAM Controller registers bitfields */
361819833afSPeter Tyser #define ESDCTL_PRCT(x)		(((x) & 0x3f) << 0)
362819833afSPeter Tyser #define ESDCTL_BL		(1 << 7)
363819833afSPeter Tyser #define ESDCTL_FP		(1 << 8)
364819833afSPeter Tyser #define ESDCTL_PWDT(x)		(((x) & 3) << 10)
365819833afSPeter Tyser #define ESDCTL_SREFR(x)		(((x) & 7) << 13)
366819833afSPeter Tyser #define ESDCTL_DSIZ_16_UPPER	(0 << 16)
367819833afSPeter Tyser #define ESDCTL_DSIZ_16_LOWER	(1 << 16)
368819833afSPeter Tyser #define ESDCTL_DSIZ_32		(2 << 16)
369819833afSPeter Tyser #define ESDCTL_COL8		(0 << 20)
370819833afSPeter Tyser #define ESDCTL_COL9		(1 << 20)
371819833afSPeter Tyser #define ESDCTL_COL10		(2 << 20)
372819833afSPeter Tyser #define ESDCTL_ROW11		(0 << 24)
373819833afSPeter Tyser #define ESDCTL_ROW12		(1 << 24)
374819833afSPeter Tyser #define ESDCTL_ROW13		(2 << 24)
375819833afSPeter Tyser #define ESDCTL_ROW14		(3 << 24)
376819833afSPeter Tyser #define ESDCTL_ROW15		(4 << 24)
377819833afSPeter Tyser #define ESDCTL_SP		(1 << 27)
378819833afSPeter Tyser #define ESDCTL_SMODE_NORMAL	(0 << 28)
379819833afSPeter Tyser #define ESDCTL_SMODE_PRECHARGE	(1 << 28)
380819833afSPeter Tyser #define ESDCTL_SMODE_AUTO_REF	(2 << 28)
381819833afSPeter Tyser #define ESDCTL_SMODE_LOAD_MODE	(3 << 28)
382819833afSPeter Tyser #define ESDCTL_SMODE_MAN_REF	(4 << 28)
383819833afSPeter Tyser #define ESDCTL_SDE		(1 << 31)
384819833afSPeter Tyser 
385819833afSPeter Tyser #define ESDCFG_TRC(x)		(((x) & 0xf) << 0)
386819833afSPeter Tyser #define ESDCFG_TRCD(x)		(((x) & 0x7) << 4)
387819833afSPeter Tyser #define ESDCFG_TCAS(x)		(((x) & 0x3) << 8)
388819833afSPeter Tyser #define ESDCFG_TRRD(x)		(((x) & 0x3) << 10)
389819833afSPeter Tyser #define ESDCFG_TRAS(x)		(((x) & 0x7) << 12)
390819833afSPeter Tyser #define ESDCFG_TWR		(1 << 15)
391819833afSPeter Tyser #define ESDCFG_TMRD(x)		(((x) & 0x3) << 16)
392819833afSPeter Tyser #define ESDCFG_TRP(x)		(((x) & 0x3) << 18)
393819833afSPeter Tyser #define ESDCFG_TWTR		(1 << 20)
394819833afSPeter Tyser #define ESDCFG_TXP(x)		(((x) & 0x3) << 21)
395819833afSPeter Tyser 
396819833afSPeter Tyser #define ESDMISC_RST		(1 << 1)
397819833afSPeter Tyser #define ESDMISC_MDDREN		(1 << 2)
398819833afSPeter Tyser #define ESDMISC_MDDR_DL_RST	(1 << 3)
399819833afSPeter Tyser #define ESDMISC_MDDR_MDIS	(1 << 4)
400819833afSPeter Tyser #define ESDMISC_LHD		(1 << 5)
401819833afSPeter Tyser #define ESDMISC_MA10_SHARE	(1 << 6)
402819833afSPeter Tyser #define ESDMISC_SDRAM_RDY	(1 << 31)
403819833afSPeter Tyser 
404819833afSPeter Tyser #define PC5_PF_I2C2_DATA	(GPIO_PORTC | GPIO_OUT | GPIO_PF | 5)
405819833afSPeter Tyser #define PC6_PF_I2C2_CLK		(GPIO_PORTC | GPIO_OUT | GPIO_PF | 6)
406819833afSPeter Tyser #define PC7_PF_USBOTG_DATA5	(GPIO_PORTC | GPIO_OUT | GPIO_PF | 7)
407819833afSPeter Tyser #define PC8_PF_USBOTG_DATA6	(GPIO_PORTC | GPIO_OUT | GPIO_PF | 8)
408819833afSPeter Tyser #define PC9_PF_USBOTG_DATA0	(GPIO_PORTC | GPIO_OUT | GPIO_PF | 9)
409819833afSPeter Tyser #define PC10_PF_USBOTG_DATA2	(GPIO_PORTC | GPIO_OUT | GPIO_PF | 10)
410819833afSPeter Tyser #define PC11_PF_USBOTG_DATA1	(GPIO_PORTC | GPIO_OUT | GPIO_PF | 11)
411819833afSPeter Tyser #define PC12_PF_USBOTG_DATA4	(GPIO_PORTC | GPIO_OUT | GPIO_PF | 12)
412819833afSPeter Tyser #define PC13_PF_USBOTG_DATA3	(GPIO_PORTC | GPIO_OUT | GPIO_PF | 13)
413819833afSPeter Tyser 
414819833afSPeter Tyser #define PD0_AIN_FEC_TXD0	(GPIO_PORTD | GPIO_OUT | GPIO_AIN | 0)
415819833afSPeter Tyser #define PD1_AIN_FEC_TXD1	(GPIO_PORTD | GPIO_OUT | GPIO_AIN | 1)
416819833afSPeter Tyser #define PD2_AIN_FEC_TXD2	(GPIO_PORTD | GPIO_OUT | GPIO_AIN | 2)
417819833afSPeter Tyser #define PD3_AIN_FEC_TXD3	(GPIO_PORTD | GPIO_OUT | GPIO_AIN | 3)
418819833afSPeter Tyser #define PD4_AOUT_FEC_RX_ER	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 4)
419819833afSPeter Tyser #define PD5_AOUT_FEC_RXD1	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 5)
420819833afSPeter Tyser #define PD6_AOUT_FEC_RXD2	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 6)
421819833afSPeter Tyser #define PD7_AOUT_FEC_RXD3	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 7)
422819833afSPeter Tyser #define PD8_AF_FEC_MDIO		(GPIO_PORTD | GPIO_IN | GPIO_AF | 8)
423819833afSPeter Tyser #define PD9_AIN_FEC_MDC		(GPIO_PORTD | GPIO_OUT | GPIO_AIN | 9)
424819833afSPeter Tyser #define PD10_AOUT_FEC_CRS	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 10)
425819833afSPeter Tyser #define PD11_AOUT_FEC_TX_CLK	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 11)
426819833afSPeter Tyser #define PD12_AOUT_FEC_RXD0	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 12)
427819833afSPeter Tyser #define PD13_AOUT_FEC_RX_DV	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 13)
428819833afSPeter Tyser #define PD14_AOUT_FEC_CLR	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 14)
429819833afSPeter Tyser #define PD15_AOUT_FEC_COL	(GPIO_PORTD | GPIO_IN | GPIO_AOUT | 15)
430819833afSPeter Tyser #define PD16_AIN_FEC_TX_ER	(GPIO_PORTD | GPIO_OUT | GPIO_AIN | 16)
431819833afSPeter Tyser #define PF23_AIN_FEC_TX_EN	(GPIO_PORTF | GPIO_OUT | GPIO_AIN | 23)
432819833afSPeter Tyser 
433819833afSPeter Tyser #define PE0_PF_USBOTG_NXT	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 0)
434819833afSPeter Tyser #define PE1_PF_USBOTG_STP	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 1)
435819833afSPeter Tyser #define PE2_PF_USBOTG_DIR	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 2)
436819833afSPeter Tyser #define PE3_PF_UART2_CTS	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 3)
437819833afSPeter Tyser #define PE4_PF_UART2_RTS	(GPIO_PORTE | GPIO_IN  | GPIO_PF | 4)
438819833afSPeter Tyser #define PE6_PF_UART2_TXD	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 6)
439819833afSPeter Tyser #define PE7_PF_UART2_RXD	(GPIO_PORTE | GPIO_IN  | GPIO_PF | 7)
440819833afSPeter Tyser #define PE8_PF_UART3_TXD	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 8)
441819833afSPeter Tyser #define PE9_PF_UART3_RXD	(GPIO_PORTE | GPIO_IN  | GPIO_PF | 9)
442819833afSPeter Tyser #define PE10_PF_UART3_CTS	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 10)
443819833afSPeter Tyser #define PE11_PF_UART3_RTS	(GPIO_PORTE | GPIO_IN  | GPIO_PF | 11)
444819833afSPeter Tyser #define PE12_PF_UART1_TXD	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 12)
445819833afSPeter Tyser #define PE13_PF_UART1_RXD	(GPIO_PORTE | GPIO_IN  | GPIO_PF | 13)
446819833afSPeter Tyser #define PE14_PF_UART1_CTS	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 14)
447819833afSPeter Tyser #define PE15_PF_UART1_RTS	(GPIO_PORTE | GPIO_IN  | GPIO_PF | 15)
448819833afSPeter Tyser #define PE18_PF_SD1_D0		(GPIO_PORTE | GPIO_PF | 18)
449819833afSPeter Tyser #define PE19_PF_SD1_D1		(GPIO_PORTE | GPIO_PF | 19)
450819833afSPeter Tyser #define PE20_PF_SD1_D2		(GPIO_PORTE | GPIO_PF | 20)
451819833afSPeter Tyser #define PE21_PF_SD1_D3		(GPIO_PORTE | GPIO_PF | 21)
452819833afSPeter Tyser #define PE22_PF_SD1_CMD		(GPIO_PORTE | GPIO_PF | 22)
453819833afSPeter Tyser #define PE23_PF_SD1_CLK		(GPIO_PORTE | GPIO_PF | 23)
454819833afSPeter Tyser #define PB4_PF_SD2_D0		(GPIO_PORTB | GPIO_PF | 4)
455819833afSPeter Tyser #define PB5_PF_SD2_D1		(GPIO_PORTB | GPIO_PF | 5)
456819833afSPeter Tyser #define PB6_PF_SD2_D2		(GPIO_PORTB | GPIO_PF | 6)
457819833afSPeter Tyser #define PB7_PF_SD2_D3		(GPIO_PORTB | GPIO_PF | 7)
458819833afSPeter Tyser #define PB8_PF_SD2_CMD		(GPIO_PORTB | GPIO_PF | 8)
459819833afSPeter Tyser #define PB9_PF_SD2_CLK		(GPIO_PORTB | GPIO_PF | 9)
460819833afSPeter Tyser #define PD17_PF_I2C_DATA	(GPIO_PORTD | GPIO_OUT | GPIO_PF | 17)
461819833afSPeter Tyser #define PD18_PF_I2C_CLK		(GPIO_PORTD | GPIO_OUT | GPIO_PF | 18)
462819833afSPeter Tyser #define PE24_PF_USBOTG_CLK	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 24)
463819833afSPeter Tyser #define PE25_PF_USBOTG_DATA7	(GPIO_PORTE | GPIO_OUT | GPIO_PF | 25)
464819833afSPeter Tyser 
465819833afSPeter Tyser /* Clocksource Bitfields */
466819833afSPeter Tyser #define TCTL_SWR	(1 << 15)	/* Software reset */
467819833afSPeter Tyser #define TCTL_FRR	(1 << 8)	/* Freerun / restart */
468819833afSPeter Tyser #define TCTL_CAP	(3 << 6)	/* Capture Edge */
469819833afSPeter Tyser #define TCTL_OM		(1 << 5)	/* output mode */
470819833afSPeter Tyser #define TCTL_IRQEN	(1 << 4)	/* interrupt enable */
471819833afSPeter Tyser #define TCTL_CLKSOURCE	1		/* Clock source bit position */
472819833afSPeter Tyser #define TCTL_TEN	1		/* Timer enable */
473819833afSPeter Tyser #define TPRER_PRES	0xff		/* Prescale */
474819833afSPeter Tyser #define TSTAT_CAPT	(1 << 1)	/* Capture event */
475819833afSPeter Tyser #define TSTAT_COMP	1		/* Compare event */
476819833afSPeter Tyser 
477819833afSPeter Tyser #define GPIO_PIN_MASK	0x1f
478819833afSPeter Tyser 
479819833afSPeter Tyser #define GPIO_PORT_SHIFT	5
480819833afSPeter Tyser #define GPIO_PORT_MASK	(0x7 << GPIO_PORT_SHIFT)
481819833afSPeter Tyser 
482819833afSPeter Tyser #define GPIO_PORTA	(PORTA << GPIO_PORT_SHIFT)
483819833afSPeter Tyser #define GPIO_PORTB	(PORTB << GPIO_PORT_SHIFT)
484819833afSPeter Tyser #define GPIO_PORTC	(PORTC << GPIO_PORT_SHIFT)
485819833afSPeter Tyser #define GPIO_PORTD	(PORTD << GPIO_PORT_SHIFT)
486819833afSPeter Tyser #define GPIO_PORTE	(PORTE << GPIO_PORT_SHIFT)
487819833afSPeter Tyser #define GPIO_PORTF	(PORTF << GPIO_PORT_SHIFT)
488819833afSPeter Tyser 
489819833afSPeter Tyser #define GPIO_OUT	(1 << 8)
490819833afSPeter Tyser #define GPIO_IN		(0 << 8)
491819833afSPeter Tyser #define GPIO_PUEN	(1 << 9)
492819833afSPeter Tyser 
493819833afSPeter Tyser #define GPIO_PF		(1 << 10)
494819833afSPeter Tyser #define GPIO_AF		(1 << 11)
495819833afSPeter Tyser 
496819833afSPeter Tyser #define GPIO_OCR_SHIFT	12
497819833afSPeter Tyser #define GPIO_OCR_MASK	(3 << GPIO_OCR_SHIFT)
498819833afSPeter Tyser #define GPIO_AIN	(0 << GPIO_OCR_SHIFT)
499819833afSPeter Tyser #define GPIO_BIN	(1 << GPIO_OCR_SHIFT)
500819833afSPeter Tyser #define GPIO_CIN	(2 << GPIO_OCR_SHIFT)
501819833afSPeter Tyser #define GPIO_GPIO	(3 << GPIO_OCR_SHIFT)
502819833afSPeter Tyser 
503819833afSPeter Tyser #define GPIO_AOUT_SHIFT	14
504819833afSPeter Tyser #define GPIO_AOUT_MASK	(3 << GPIO_AOUT_SHIFT)
505819833afSPeter Tyser #define GPIO_AOUT	(0 << GPIO_AOUT_SHIFT)
506819833afSPeter Tyser #define GPIO_AOUT_ISR	(1 << GPIO_AOUT_SHIFT)
507819833afSPeter Tyser #define GPIO_AOUT_0	(2 << GPIO_AOUT_SHIFT)
508819833afSPeter Tyser #define GPIO_AOUT_1	(3 << GPIO_AOUT_SHIFT)
509819833afSPeter Tyser 
510819833afSPeter Tyser #define GPIO_BOUT_SHIFT	16
511819833afSPeter Tyser #define GPIO_BOUT_MASK	(3 << GPIO_BOUT_SHIFT)
512819833afSPeter Tyser #define GPIO_BOUT	(0 << GPIO_BOUT_SHIFT)
513819833afSPeter Tyser #define GPIO_BOUT_ISR	(1 << GPIO_BOUT_SHIFT)
514819833afSPeter Tyser #define GPIO_BOUT_0	(2 << GPIO_BOUT_SHIFT)
515819833afSPeter Tyser #define GPIO_BOUT_1	(3 << GPIO_BOUT_SHIFT)
516819833afSPeter Tyser 
517819833afSPeter Tyser #define IIM_STAT_BUSY	(1 << 7)
518819833afSPeter Tyser #define IIM_STAT_PRGD	(1 << 1)
519819833afSPeter Tyser #define IIM_STAT_SNSD	(1 << 0)
520819833afSPeter Tyser #define IIM_ERR_PRGE	(1 << 7)
521819833afSPeter Tyser #define IIM_ERR_WPE	(1 << 6)
522819833afSPeter Tyser #define IIM_ERR_OPE	(1 << 5)
523819833afSPeter Tyser #define IIM_ERR_RPE	(1 << 4)
524819833afSPeter Tyser #define IIM_ERR_WLRE	(1 << 3)
525819833afSPeter Tyser #define IIM_ERR_SNSE	(1 << 2)
526819833afSPeter Tyser #define IIM_ERR_PARITYE	(1 << 1)
527819833afSPeter Tyser 
528819833afSPeter Tyser #endif				/* _IMX_REGS_H */
529