diff options
author | Jonathan Herman <hermanjl@cs.unc.edu> | 2013-01-22 10:38:37 -0500 |
---|---|---|
committer | Jonathan Herman <hermanjl@cs.unc.edu> | 2013-01-22 10:38:37 -0500 |
commit | fcc9d2e5a6c89d22b8b773a64fb4ad21ac318446 (patch) | |
tree | a57612d1888735a2ec7972891b68c1ac5ec8faea /arch/arm/mach-mxs | |
parent | 8dea78da5cee153b8af9c07a2745f6c55057fe12 (diff) |
Diffstat (limited to 'arch/arm/mach-mxs')
44 files changed, 5862 insertions, 0 deletions
diff --git a/arch/arm/mach-mxs/clock-mx23.c b/arch/arm/mach-mxs/clock-mx23.c new file mode 100644 index 00000000000..0163b6d8377 --- /dev/null +++ b/arch/arm/mach-mxs/clock-mx23.c | |||
@@ -0,0 +1,559 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2009-2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or modify | ||
5 | * it under the terms of the GNU General Public License as published by | ||
6 | * the Free Software Foundation; either version 2 of the License, or | ||
7 | * (at your option) any later version. | ||
8 | * | ||
9 | * This program is distributed in the hope that it will be useful, | ||
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
12 | * GNU General Public License for more details. | ||
13 | * | ||
14 | * You should have received a copy of the GNU General Public License along | ||
15 | * with this program; if not, write to the Free Software Foundation, Inc., | ||
16 | * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | ||
17 | */ | ||
18 | |||
19 | #include <linux/mm.h> | ||
20 | #include <linux/delay.h> | ||
21 | #include <linux/clk.h> | ||
22 | #include <linux/io.h> | ||
23 | #include <linux/jiffies.h> | ||
24 | #include <linux/clkdev.h> | ||
25 | |||
26 | #include <asm/clkdev.h> | ||
27 | #include <asm/div64.h> | ||
28 | |||
29 | #include <mach/mx23.h> | ||
30 | #include <mach/common.h> | ||
31 | #include <mach/clock.h> | ||
32 | |||
33 | #include "regs-clkctrl-mx23.h" | ||
34 | |||
35 | #define CLKCTRL_BASE_ADDR MX23_IO_ADDRESS(MX23_CLKCTRL_BASE_ADDR) | ||
36 | #define DIGCTRL_BASE_ADDR MX23_IO_ADDRESS(MX23_DIGCTL_BASE_ADDR) | ||
37 | |||
38 | #define PARENT_RATE_SHIFT 8 | ||
39 | |||
40 | static int _raw_clk_enable(struct clk *clk) | ||
41 | { | ||
42 | u32 reg; | ||
43 | |||
44 | if (clk->enable_reg) { | ||
45 | reg = __raw_readl(clk->enable_reg); | ||
46 | reg &= ~(1 << clk->enable_shift); | ||
47 | __raw_writel(reg, clk->enable_reg); | ||
48 | } | ||
49 | |||
50 | return 0; | ||
51 | } | ||
52 | |||
53 | static void _raw_clk_disable(struct clk *clk) | ||
54 | { | ||
55 | u32 reg; | ||
56 | |||
57 | if (clk->enable_reg) { | ||
58 | reg = __raw_readl(clk->enable_reg); | ||
59 | reg |= 1 << clk->enable_shift; | ||
60 | __raw_writel(reg, clk->enable_reg); | ||
61 | } | ||
62 | } | ||
63 | |||
64 | /* | ||
65 | * ref_xtal_clk | ||
66 | */ | ||
67 | static unsigned long ref_xtal_clk_get_rate(struct clk *clk) | ||
68 | { | ||
69 | return 24000000; | ||
70 | } | ||
71 | |||
72 | static struct clk ref_xtal_clk = { | ||
73 | .get_rate = ref_xtal_clk_get_rate, | ||
74 | }; | ||
75 | |||
76 | /* | ||
77 | * pll_clk | ||
78 | */ | ||
79 | static unsigned long pll_clk_get_rate(struct clk *clk) | ||
80 | { | ||
81 | return 480000000; | ||
82 | } | ||
83 | |||
84 | static int pll_clk_enable(struct clk *clk) | ||
85 | { | ||
86 | __raw_writel(BM_CLKCTRL_PLLCTRL0_POWER | | ||
87 | BM_CLKCTRL_PLLCTRL0_EN_USB_CLKS, | ||
88 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_PLLCTRL0_SET); | ||
89 | |||
90 | /* Only a 10us delay is need. PLLCTRL1 LOCK bitfied is only a timer | ||
91 | * and is incorrect (excessive). Per definition of the PLLCTRL0 | ||
92 | * POWER field, waiting at least 10us. | ||
93 | */ | ||
94 | udelay(10); | ||
95 | |||
96 | return 0; | ||
97 | } | ||
98 | |||
99 | static void pll_clk_disable(struct clk *clk) | ||
100 | { | ||
101 | __raw_writel(BM_CLKCTRL_PLLCTRL0_POWER | | ||
102 | BM_CLKCTRL_PLLCTRL0_EN_USB_CLKS, | ||
103 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_PLLCTRL0_CLR); | ||
104 | } | ||
105 | |||
106 | static struct clk pll_clk = { | ||
107 | .get_rate = pll_clk_get_rate, | ||
108 | .enable = pll_clk_enable, | ||
109 | .disable = pll_clk_disable, | ||
110 | .parent = &ref_xtal_clk, | ||
111 | }; | ||
112 | |||
113 | /* | ||
114 | * ref_clk | ||
115 | */ | ||
116 | #define _CLK_GET_RATE_REF(name, sr, ss) \ | ||
117 | static unsigned long name##_get_rate(struct clk *clk) \ | ||
118 | { \ | ||
119 | unsigned long parent_rate; \ | ||
120 | u32 reg, div; \ | ||
121 | \ | ||
122 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_##sr); \ | ||
123 | div = (reg >> BP_CLKCTRL_##sr##_##ss##FRAC) & 0x3f; \ | ||
124 | parent_rate = clk_get_rate(clk->parent); \ | ||
125 | \ | ||
126 | return SH_DIV((parent_rate >> PARENT_RATE_SHIFT) * 18, \ | ||
127 | div, PARENT_RATE_SHIFT); \ | ||
128 | } | ||
129 | |||
130 | _CLK_GET_RATE_REF(ref_cpu_clk, FRAC, CPU) | ||
131 | _CLK_GET_RATE_REF(ref_emi_clk, FRAC, EMI) | ||
132 | _CLK_GET_RATE_REF(ref_pix_clk, FRAC, PIX) | ||
133 | _CLK_GET_RATE_REF(ref_io_clk, FRAC, IO) | ||
134 | |||
135 | #define _DEFINE_CLOCK_REF(name, er, es) \ | ||
136 | static struct clk name = { \ | ||
137 | .enable_reg = CLKCTRL_BASE_ADDR + HW_CLKCTRL_##er, \ | ||
138 | .enable_shift = BP_CLKCTRL_##er##_CLKGATE##es, \ | ||
139 | .get_rate = name##_get_rate, \ | ||
140 | .enable = _raw_clk_enable, \ | ||
141 | .disable = _raw_clk_disable, \ | ||
142 | .parent = &pll_clk, \ | ||
143 | } | ||
144 | |||
145 | _DEFINE_CLOCK_REF(ref_cpu_clk, FRAC, CPU); | ||
146 | _DEFINE_CLOCK_REF(ref_emi_clk, FRAC, EMI); | ||
147 | _DEFINE_CLOCK_REF(ref_pix_clk, FRAC, PIX); | ||
148 | _DEFINE_CLOCK_REF(ref_io_clk, FRAC, IO); | ||
149 | |||
150 | /* | ||
151 | * General clocks | ||
152 | * | ||
153 | * clk_get_rate | ||
154 | */ | ||
155 | static unsigned long rtc_clk_get_rate(struct clk *clk) | ||
156 | { | ||
157 | /* ref_xtal_clk is implemented as the only parent */ | ||
158 | return clk_get_rate(clk->parent) / 768; | ||
159 | } | ||
160 | |||
161 | static unsigned long clk32k_clk_get_rate(struct clk *clk) | ||
162 | { | ||
163 | return clk->parent->get_rate(clk->parent) / 750; | ||
164 | } | ||
165 | |||
166 | #define _CLK_GET_RATE(name, rs) \ | ||
167 | static unsigned long name##_get_rate(struct clk *clk) \ | ||
168 | { \ | ||
169 | u32 reg, div; \ | ||
170 | \ | ||
171 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_##rs); \ | ||
172 | \ | ||
173 | if (clk->parent == &ref_xtal_clk) \ | ||
174 | div = (reg & BM_CLKCTRL_##rs##_DIV_XTAL) >> \ | ||
175 | BP_CLKCTRL_##rs##_DIV_XTAL; \ | ||
176 | else \ | ||
177 | div = (reg & BM_CLKCTRL_##rs##_DIV_##rs) >> \ | ||
178 | BP_CLKCTRL_##rs##_DIV_##rs; \ | ||
179 | \ | ||
180 | if (!div) \ | ||
181 | return -EINVAL; \ | ||
182 | \ | ||
183 | return clk_get_rate(clk->parent) / div; \ | ||
184 | } | ||
185 | |||
186 | _CLK_GET_RATE(cpu_clk, CPU) | ||
187 | _CLK_GET_RATE(emi_clk, EMI) | ||
188 | |||
189 | #define _CLK_GET_RATE1(name, rs) \ | ||
190 | static unsigned long name##_get_rate(struct clk *clk) \ | ||
191 | { \ | ||
192 | u32 reg, div; \ | ||
193 | \ | ||
194 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_##rs); \ | ||
195 | div = (reg & BM_CLKCTRL_##rs##_DIV) >> BP_CLKCTRL_##rs##_DIV; \ | ||
196 | \ | ||
197 | if (!div) \ | ||
198 | return -EINVAL; \ | ||
199 | \ | ||
200 | return clk_get_rate(clk->parent) / div; \ | ||
201 | } | ||
202 | |||
203 | _CLK_GET_RATE1(hbus_clk, HBUS) | ||
204 | _CLK_GET_RATE1(xbus_clk, XBUS) | ||
205 | _CLK_GET_RATE1(ssp_clk, SSP) | ||
206 | _CLK_GET_RATE1(gpmi_clk, GPMI) | ||
207 | _CLK_GET_RATE1(lcdif_clk, PIX) | ||
208 | |||
209 | #define _CLK_GET_RATE_STUB(name) \ | ||
210 | static unsigned long name##_get_rate(struct clk *clk) \ | ||
211 | { \ | ||
212 | return clk_get_rate(clk->parent); \ | ||
213 | } | ||
214 | |||
215 | _CLK_GET_RATE_STUB(uart_clk) | ||
216 | _CLK_GET_RATE_STUB(audio_clk) | ||
217 | _CLK_GET_RATE_STUB(pwm_clk) | ||
218 | |||
219 | /* | ||
220 | * clk_set_rate | ||
221 | */ | ||
222 | static int cpu_clk_set_rate(struct clk *clk, unsigned long rate) | ||
223 | { | ||
224 | u32 reg, bm_busy, div_max, d, f, div, frac; | ||
225 | unsigned long diff, parent_rate, calc_rate; | ||
226 | int i; | ||
227 | |||
228 | parent_rate = clk_get_rate(clk->parent); | ||
229 | |||
230 | if (clk->parent == &ref_xtal_clk) { | ||
231 | div_max = BM_CLKCTRL_CPU_DIV_XTAL >> BP_CLKCTRL_CPU_DIV_XTAL; | ||
232 | bm_busy = BM_CLKCTRL_CPU_BUSY_REF_XTAL; | ||
233 | div = DIV_ROUND_UP(parent_rate, rate); | ||
234 | if (div == 0 || div > div_max) | ||
235 | return -EINVAL; | ||
236 | } else { | ||
237 | div_max = BM_CLKCTRL_CPU_DIV_CPU >> BP_CLKCTRL_CPU_DIV_CPU; | ||
238 | bm_busy = BM_CLKCTRL_CPU_BUSY_REF_CPU; | ||
239 | rate >>= PARENT_RATE_SHIFT; | ||
240 | parent_rate >>= PARENT_RATE_SHIFT; | ||
241 | diff = parent_rate; | ||
242 | div = frac = 1; | ||
243 | for (d = 1; d <= div_max; d++) { | ||
244 | f = parent_rate * 18 / d / rate; | ||
245 | if ((parent_rate * 18 / d) % rate) | ||
246 | f++; | ||
247 | if (f < 18 || f > 35) | ||
248 | continue; | ||
249 | |||
250 | calc_rate = parent_rate * 18 / f / d; | ||
251 | if (calc_rate > rate) | ||
252 | continue; | ||
253 | |||
254 | if (rate - calc_rate < diff) { | ||
255 | frac = f; | ||
256 | div = d; | ||
257 | diff = rate - calc_rate; | ||
258 | } | ||
259 | |||
260 | if (diff == 0) | ||
261 | break; | ||
262 | } | ||
263 | |||
264 | if (diff == parent_rate) | ||
265 | return -EINVAL; | ||
266 | |||
267 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_FRAC); | ||
268 | reg &= ~BM_CLKCTRL_FRAC_CPUFRAC; | ||
269 | reg |= frac; | ||
270 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_FRAC); | ||
271 | } | ||
272 | |||
273 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_CPU); | ||
274 | reg &= ~BM_CLKCTRL_CPU_DIV_CPU; | ||
275 | reg |= div << BP_CLKCTRL_CPU_DIV_CPU; | ||
276 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_CPU); | ||
277 | |||
278 | for (i = 10000; i; i--) | ||
279 | if (!(__raw_readl(CLKCTRL_BASE_ADDR + | ||
280 | HW_CLKCTRL_CPU) & bm_busy)) | ||
281 | break; | ||
282 | if (!i) { | ||
283 | pr_err("%s: divider writing timeout\n", __func__); | ||
284 | return -ETIMEDOUT; | ||
285 | } | ||
286 | |||
287 | return 0; | ||
288 | } | ||
289 | |||
290 | #define _CLK_SET_RATE(name, dr) \ | ||
291 | static int name##_set_rate(struct clk *clk, unsigned long rate) \ | ||
292 | { \ | ||
293 | u32 reg, div_max, div; \ | ||
294 | unsigned long parent_rate; \ | ||
295 | int i; \ | ||
296 | \ | ||
297 | parent_rate = clk_get_rate(clk->parent); \ | ||
298 | div_max = BM_CLKCTRL_##dr##_DIV >> BP_CLKCTRL_##dr##_DIV; \ | ||
299 | \ | ||
300 | div = DIV_ROUND_UP(parent_rate, rate); \ | ||
301 | if (div == 0 || div > div_max) \ | ||
302 | return -EINVAL; \ | ||
303 | \ | ||
304 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_##dr); \ | ||
305 | reg &= ~BM_CLKCTRL_##dr##_DIV; \ | ||
306 | reg |= div << BP_CLKCTRL_##dr##_DIV; \ | ||
307 | if (reg & (1 << clk->enable_shift)) { \ | ||
308 | pr_err("%s: clock is gated\n", __func__); \ | ||
309 | return -EINVAL; \ | ||
310 | } \ | ||
311 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_##dr); \ | ||
312 | \ | ||
313 | for (i = 10000; i; i--) \ | ||
314 | if (!(__raw_readl(CLKCTRL_BASE_ADDR + \ | ||
315 | HW_CLKCTRL_##dr) & BM_CLKCTRL_##dr##_BUSY)) \ | ||
316 | break; \ | ||
317 | if (!i) { \ | ||
318 | pr_err("%s: divider writing timeout\n", __func__); \ | ||
319 | return -ETIMEDOUT; \ | ||
320 | } \ | ||
321 | \ | ||
322 | return 0; \ | ||
323 | } | ||
324 | |||
325 | _CLK_SET_RATE(xbus_clk, XBUS) | ||
326 | _CLK_SET_RATE(ssp_clk, SSP) | ||
327 | _CLK_SET_RATE(gpmi_clk, GPMI) | ||
328 | _CLK_SET_RATE(lcdif_clk, PIX) | ||
329 | |||
330 | #define _CLK_SET_RATE_STUB(name) \ | ||
331 | static int name##_set_rate(struct clk *clk, unsigned long rate) \ | ||
332 | { \ | ||
333 | return -EINVAL; \ | ||
334 | } | ||
335 | |||
336 | _CLK_SET_RATE_STUB(emi_clk) | ||
337 | _CLK_SET_RATE_STUB(uart_clk) | ||
338 | _CLK_SET_RATE_STUB(audio_clk) | ||
339 | _CLK_SET_RATE_STUB(pwm_clk) | ||
340 | _CLK_SET_RATE_STUB(clk32k_clk) | ||
341 | |||
342 | /* | ||
343 | * clk_set_parent | ||
344 | */ | ||
345 | #define _CLK_SET_PARENT(name, bit) \ | ||
346 | static int name##_set_parent(struct clk *clk, struct clk *parent) \ | ||
347 | { \ | ||
348 | if (parent != clk->parent) { \ | ||
349 | __raw_writel(BM_CLKCTRL_CLKSEQ_BYPASS_##bit, \ | ||
350 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_CLKSEQ_TOG); \ | ||
351 | clk->parent = parent; \ | ||
352 | } \ | ||
353 | \ | ||
354 | return 0; \ | ||
355 | } | ||
356 | |||
357 | _CLK_SET_PARENT(cpu_clk, CPU) | ||
358 | _CLK_SET_PARENT(emi_clk, EMI) | ||
359 | _CLK_SET_PARENT(ssp_clk, SSP) | ||
360 | _CLK_SET_PARENT(gpmi_clk, GPMI) | ||
361 | _CLK_SET_PARENT(lcdif_clk, PIX) | ||
362 | |||
363 | #define _CLK_SET_PARENT_STUB(name) \ | ||
364 | static int name##_set_parent(struct clk *clk, struct clk *parent) \ | ||
365 | { \ | ||
366 | if (parent != clk->parent) \ | ||
367 | return -EINVAL; \ | ||
368 | else \ | ||
369 | return 0; \ | ||
370 | } | ||
371 | |||
372 | _CLK_SET_PARENT_STUB(uart_clk) | ||
373 | _CLK_SET_PARENT_STUB(audio_clk) | ||
374 | _CLK_SET_PARENT_STUB(pwm_clk) | ||
375 | _CLK_SET_PARENT_STUB(clk32k_clk) | ||
376 | |||
377 | /* | ||
378 | * clk definition | ||
379 | */ | ||
380 | static struct clk cpu_clk = { | ||
381 | .get_rate = cpu_clk_get_rate, | ||
382 | .set_rate = cpu_clk_set_rate, | ||
383 | .set_parent = cpu_clk_set_parent, | ||
384 | .parent = &ref_cpu_clk, | ||
385 | }; | ||
386 | |||
387 | static struct clk hbus_clk = { | ||
388 | .get_rate = hbus_clk_get_rate, | ||
389 | .parent = &cpu_clk, | ||
390 | }; | ||
391 | |||
392 | static struct clk xbus_clk = { | ||
393 | .get_rate = xbus_clk_get_rate, | ||
394 | .set_rate = xbus_clk_set_rate, | ||
395 | .parent = &ref_xtal_clk, | ||
396 | }; | ||
397 | |||
398 | static struct clk rtc_clk = { | ||
399 | .get_rate = rtc_clk_get_rate, | ||
400 | .parent = &ref_xtal_clk, | ||
401 | }; | ||
402 | |||
403 | /* usb_clk gate is controlled in DIGCTRL other than CLKCTRL */ | ||
404 | static struct clk usb_clk = { | ||
405 | .enable_reg = DIGCTRL_BASE_ADDR, | ||
406 | .enable_shift = 2, | ||
407 | .enable = _raw_clk_enable, | ||
408 | .disable = _raw_clk_disable, | ||
409 | .parent = &pll_clk, | ||
410 | }; | ||
411 | |||
412 | #define _DEFINE_CLOCK(name, er, es, p) \ | ||
413 | static struct clk name = { \ | ||
414 | .enable_reg = CLKCTRL_BASE_ADDR + HW_CLKCTRL_##er, \ | ||
415 | .enable_shift = BP_CLKCTRL_##er##_##es, \ | ||
416 | .get_rate = name##_get_rate, \ | ||
417 | .set_rate = name##_set_rate, \ | ||
418 | .set_parent = name##_set_parent, \ | ||
419 | .enable = _raw_clk_enable, \ | ||
420 | .disable = _raw_clk_disable, \ | ||
421 | .parent = p, \ | ||
422 | } | ||
423 | |||
424 | _DEFINE_CLOCK(emi_clk, EMI, CLKGATE, &ref_xtal_clk); | ||
425 | _DEFINE_CLOCK(ssp_clk, SSP, CLKGATE, &ref_xtal_clk); | ||
426 | _DEFINE_CLOCK(gpmi_clk, GPMI, CLKGATE, &ref_xtal_clk); | ||
427 | _DEFINE_CLOCK(lcdif_clk, PIX, CLKGATE, &ref_xtal_clk); | ||
428 | _DEFINE_CLOCK(uart_clk, XTAL, UART_CLK_GATE, &ref_xtal_clk); | ||
429 | _DEFINE_CLOCK(audio_clk, XTAL, FILT_CLK24M_GATE, &ref_xtal_clk); | ||
430 | _DEFINE_CLOCK(pwm_clk, XTAL, PWM_CLK24M_GATE, &ref_xtal_clk); | ||
431 | _DEFINE_CLOCK(clk32k_clk, XTAL, TIMROT_CLK32K_GATE, &ref_xtal_clk); | ||
432 | |||
433 | #define _REGISTER_CLOCK(d, n, c) \ | ||
434 | { \ | ||
435 | .dev_id = d, \ | ||
436 | .con_id = n, \ | ||
437 | .clk = &c, \ | ||
438 | }, | ||
439 | |||
440 | static struct clk_lookup lookups[] = { | ||
441 | /* for amba bus driver */ | ||
442 | _REGISTER_CLOCK("duart", "apb_pclk", xbus_clk) | ||
443 | /* for amba-pl011 driver */ | ||
444 | _REGISTER_CLOCK("duart", NULL, uart_clk) | ||
445 | _REGISTER_CLOCK("mxs-auart.0", NULL, uart_clk) | ||
446 | _REGISTER_CLOCK("rtc", NULL, rtc_clk) | ||
447 | _REGISTER_CLOCK("mxs-dma-apbh", NULL, hbus_clk) | ||
448 | _REGISTER_CLOCK("mxs-dma-apbx", NULL, xbus_clk) | ||
449 | _REGISTER_CLOCK("mxs-mmc.0", NULL, ssp_clk) | ||
450 | _REGISTER_CLOCK("mxs-mmc.1", NULL, ssp_clk) | ||
451 | _REGISTER_CLOCK(NULL, "usb", usb_clk) | ||
452 | _REGISTER_CLOCK(NULL, "audio", audio_clk) | ||
453 | _REGISTER_CLOCK("mxs-pwm.0", NULL, pwm_clk) | ||
454 | _REGISTER_CLOCK("mxs-pwm.1", NULL, pwm_clk) | ||
455 | _REGISTER_CLOCK("mxs-pwm.2", NULL, pwm_clk) | ||
456 | _REGISTER_CLOCK("mxs-pwm.3", NULL, pwm_clk) | ||
457 | _REGISTER_CLOCK("mxs-pwm.4", NULL, pwm_clk) | ||
458 | _REGISTER_CLOCK("imx23-fb", NULL, lcdif_clk) | ||
459 | }; | ||
460 | |||
461 | static int clk_misc_init(void) | ||
462 | { | ||
463 | u32 reg; | ||
464 | int i; | ||
465 | |||
466 | /* Fix up parent per register setting */ | ||
467 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_CLKSEQ); | ||
468 | cpu_clk.parent = (reg & BM_CLKCTRL_CLKSEQ_BYPASS_CPU) ? | ||
469 | &ref_xtal_clk : &ref_cpu_clk; | ||
470 | emi_clk.parent = (reg & BM_CLKCTRL_CLKSEQ_BYPASS_EMI) ? | ||
471 | &ref_xtal_clk : &ref_emi_clk; | ||
472 | ssp_clk.parent = (reg & BM_CLKCTRL_CLKSEQ_BYPASS_SSP) ? | ||
473 | &ref_xtal_clk : &ref_io_clk; | ||
474 | gpmi_clk.parent = (reg & BM_CLKCTRL_CLKSEQ_BYPASS_GPMI) ? | ||
475 | &ref_xtal_clk : &ref_io_clk; | ||
476 | lcdif_clk.parent = (reg & BM_CLKCTRL_CLKSEQ_BYPASS_PIX) ? | ||
477 | &ref_xtal_clk : &ref_pix_clk; | ||
478 | |||
479 | /* Use int div over frac when both are available */ | ||
480 | __raw_writel(BM_CLKCTRL_CPU_DIV_XTAL_FRAC_EN, | ||
481 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_CPU_CLR); | ||
482 | __raw_writel(BM_CLKCTRL_CPU_DIV_CPU_FRAC_EN, | ||
483 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_CPU_CLR); | ||
484 | __raw_writel(BM_CLKCTRL_HBUS_DIV_FRAC_EN, | ||
485 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_HBUS_CLR); | ||
486 | |||
487 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_XBUS); | ||
488 | reg &= ~BM_CLKCTRL_XBUS_DIV_FRAC_EN; | ||
489 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_XBUS); | ||
490 | |||
491 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_SSP); | ||
492 | reg &= ~BM_CLKCTRL_SSP_DIV_FRAC_EN; | ||
493 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_SSP); | ||
494 | |||
495 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_GPMI); | ||
496 | reg &= ~BM_CLKCTRL_GPMI_DIV_FRAC_EN; | ||
497 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_GPMI); | ||
498 | |||
499 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_PIX); | ||
500 | reg &= ~BM_CLKCTRL_PIX_DIV_FRAC_EN; | ||
501 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_PIX); | ||
502 | |||
503 | /* | ||
504 | * Set safe hbus clock divider. A divider of 3 ensure that | ||
505 | * the Vddd voltage required for the cpu clock is sufficiently | ||
506 | * high for the hbus clock. | ||
507 | */ | ||
508 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_HBUS); | ||
509 | reg &= BM_CLKCTRL_HBUS_DIV; | ||
510 | reg |= 3 << BP_CLKCTRL_HBUS_DIV; | ||
511 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_HBUS); | ||
512 | |||
513 | for (i = 10000; i; i--) | ||
514 | if (!(__raw_readl(CLKCTRL_BASE_ADDR + | ||
515 | HW_CLKCTRL_HBUS) & BM_CLKCTRL_HBUS_BUSY)) | ||
516 | break; | ||
517 | if (!i) { | ||
518 | pr_err("%s: divider writing timeout\n", __func__); | ||
519 | return -ETIMEDOUT; | ||
520 | } | ||
521 | |||
522 | /* Gate off cpu clock in WFI for power saving */ | ||
523 | __raw_writel(BM_CLKCTRL_CPU_INTERRUPT_WAIT, | ||
524 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_CPU_SET); | ||
525 | |||
526 | /* | ||
527 | * 480 MHz seems too high to be ssp clock source directly, | ||
528 | * so set frac to get a 288 MHz ref_io. | ||
529 | */ | ||
530 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_FRAC); | ||
531 | reg &= ~BM_CLKCTRL_FRAC_IOFRAC; | ||
532 | reg |= 30 << BP_CLKCTRL_FRAC_IOFRAC; | ||
533 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_FRAC); | ||
534 | |||
535 | return 0; | ||
536 | } | ||
537 | |||
538 | int __init mx23_clocks_init(void) | ||
539 | { | ||
540 | clk_misc_init(); | ||
541 | |||
542 | /* | ||
543 | * source ssp clock from ref_io than ref_xtal, | ||
544 | * as ref_xtal only provides 24 MHz as maximum. | ||
545 | */ | ||
546 | clk_set_parent(&ssp_clk, &ref_io_clk); | ||
547 | |||
548 | clk_enable(&cpu_clk); | ||
549 | clk_enable(&hbus_clk); | ||
550 | clk_enable(&xbus_clk); | ||
551 | clk_enable(&emi_clk); | ||
552 | clk_enable(&uart_clk); | ||
553 | |||
554 | clkdev_add_table(lookups, ARRAY_SIZE(lookups)); | ||
555 | |||
556 | mxs_timer_init(&clk32k_clk, MX23_INT_TIMER0); | ||
557 | |||
558 | return 0; | ||
559 | } | ||
diff --git a/arch/arm/mach-mxs/clock-mx28.c b/arch/arm/mach-mxs/clock-mx28.c new file mode 100644 index 00000000000..b3a71245f38 --- /dev/null +++ b/arch/arm/mach-mxs/clock-mx28.c | |||
@@ -0,0 +1,783 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2009-2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or modify | ||
5 | * it under the terms of the GNU General Public License as published by | ||
6 | * the Free Software Foundation; either version 2 of the License, or | ||
7 | * (at your option) any later version. | ||
8 | * | ||
9 | * This program is distributed in the hope that it will be useful, | ||
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
12 | * GNU General Public License for more details. | ||
13 | * | ||
14 | * You should have received a copy of the GNU General Public License along | ||
15 | * with this program; if not, write to the Free Software Foundation, Inc., | ||
16 | * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | ||
17 | */ | ||
18 | |||
19 | #include <linux/mm.h> | ||
20 | #include <linux/delay.h> | ||
21 | #include <linux/clk.h> | ||
22 | #include <linux/io.h> | ||
23 | #include <linux/jiffies.h> | ||
24 | #include <linux/clkdev.h> | ||
25 | |||
26 | #include <asm/clkdev.h> | ||
27 | #include <asm/div64.h> | ||
28 | |||
29 | #include <mach/mx28.h> | ||
30 | #include <mach/common.h> | ||
31 | #include <mach/clock.h> | ||
32 | |||
33 | #include "regs-clkctrl-mx28.h" | ||
34 | |||
35 | #define CLKCTRL_BASE_ADDR MX28_IO_ADDRESS(MX28_CLKCTRL_BASE_ADDR) | ||
36 | #define DIGCTRL_BASE_ADDR MX28_IO_ADDRESS(MX28_DIGCTL_BASE_ADDR) | ||
37 | |||
38 | #define PARENT_RATE_SHIFT 8 | ||
39 | |||
40 | static struct clk pll2_clk; | ||
41 | static struct clk cpu_clk; | ||
42 | static struct clk emi_clk; | ||
43 | static struct clk saif0_clk; | ||
44 | static struct clk saif1_clk; | ||
45 | static struct clk clk32k_clk; | ||
46 | |||
47 | static int _raw_clk_enable(struct clk *clk) | ||
48 | { | ||
49 | u32 reg; | ||
50 | |||
51 | if (clk->enable_reg) { | ||
52 | reg = __raw_readl(clk->enable_reg); | ||
53 | reg &= ~(1 << clk->enable_shift); | ||
54 | __raw_writel(reg, clk->enable_reg); | ||
55 | } | ||
56 | |||
57 | return 0; | ||
58 | } | ||
59 | |||
60 | static void _raw_clk_disable(struct clk *clk) | ||
61 | { | ||
62 | u32 reg; | ||
63 | |||
64 | if (clk->enable_reg) { | ||
65 | reg = __raw_readl(clk->enable_reg); | ||
66 | reg |= 1 << clk->enable_shift; | ||
67 | __raw_writel(reg, clk->enable_reg); | ||
68 | } | ||
69 | } | ||
70 | |||
71 | /* | ||
72 | * ref_xtal_clk | ||
73 | */ | ||
74 | static unsigned long ref_xtal_clk_get_rate(struct clk *clk) | ||
75 | { | ||
76 | return 24000000; | ||
77 | } | ||
78 | |||
79 | static struct clk ref_xtal_clk = { | ||
80 | .get_rate = ref_xtal_clk_get_rate, | ||
81 | }; | ||
82 | |||
83 | /* | ||
84 | * pll_clk | ||
85 | */ | ||
86 | static unsigned long pll0_clk_get_rate(struct clk *clk) | ||
87 | { | ||
88 | return 480000000; | ||
89 | } | ||
90 | |||
91 | static unsigned long pll1_clk_get_rate(struct clk *clk) | ||
92 | { | ||
93 | return 480000000; | ||
94 | } | ||
95 | |||
96 | static unsigned long pll2_clk_get_rate(struct clk *clk) | ||
97 | { | ||
98 | return 50000000; | ||
99 | } | ||
100 | |||
101 | #define _CLK_ENABLE_PLL(name, r, g) \ | ||
102 | static int name##_enable(struct clk *clk) \ | ||
103 | { \ | ||
104 | __raw_writel(BM_CLKCTRL_##r##CTRL0_POWER, \ | ||
105 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_##r##CTRL0_SET); \ | ||
106 | udelay(10); \ | ||
107 | \ | ||
108 | if (clk == &pll2_clk) \ | ||
109 | __raw_writel(BM_CLKCTRL_##r##CTRL0_##g, \ | ||
110 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_##r##CTRL0_CLR); \ | ||
111 | else \ | ||
112 | __raw_writel(BM_CLKCTRL_##r##CTRL0_##g, \ | ||
113 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_##r##CTRL0_SET); \ | ||
114 | \ | ||
115 | return 0; \ | ||
116 | } | ||
117 | |||
118 | _CLK_ENABLE_PLL(pll0_clk, PLL0, EN_USB_CLKS) | ||
119 | _CLK_ENABLE_PLL(pll1_clk, PLL1, EN_USB_CLKS) | ||
120 | _CLK_ENABLE_PLL(pll2_clk, PLL2, CLKGATE) | ||
121 | |||
122 | #define _CLK_DISABLE_PLL(name, r, g) \ | ||
123 | static void name##_disable(struct clk *clk) \ | ||
124 | { \ | ||
125 | __raw_writel(BM_CLKCTRL_##r##CTRL0_POWER, \ | ||
126 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_##r##CTRL0_CLR); \ | ||
127 | \ | ||
128 | if (clk == &pll2_clk) \ | ||
129 | __raw_writel(BM_CLKCTRL_##r##CTRL0_##g, \ | ||
130 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_##r##CTRL0_SET); \ | ||
131 | else \ | ||
132 | __raw_writel(BM_CLKCTRL_##r##CTRL0_##g, \ | ||
133 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_##r##CTRL0_CLR); \ | ||
134 | \ | ||
135 | } | ||
136 | |||
137 | _CLK_DISABLE_PLL(pll0_clk, PLL0, EN_USB_CLKS) | ||
138 | _CLK_DISABLE_PLL(pll1_clk, PLL1, EN_USB_CLKS) | ||
139 | _CLK_DISABLE_PLL(pll2_clk, PLL2, CLKGATE) | ||
140 | |||
141 | #define _DEFINE_CLOCK_PLL(name) \ | ||
142 | static struct clk name = { \ | ||
143 | .get_rate = name##_get_rate, \ | ||
144 | .enable = name##_enable, \ | ||
145 | .disable = name##_disable, \ | ||
146 | .parent = &ref_xtal_clk, \ | ||
147 | } | ||
148 | |||
149 | _DEFINE_CLOCK_PLL(pll0_clk); | ||
150 | _DEFINE_CLOCK_PLL(pll1_clk); | ||
151 | _DEFINE_CLOCK_PLL(pll2_clk); | ||
152 | |||
153 | /* | ||
154 | * ref_clk | ||
155 | */ | ||
156 | #define _CLK_GET_RATE_REF(name, sr, ss) \ | ||
157 | static unsigned long name##_get_rate(struct clk *clk) \ | ||
158 | { \ | ||
159 | unsigned long parent_rate; \ | ||
160 | u32 reg, div; \ | ||
161 | \ | ||
162 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_##sr); \ | ||
163 | div = (reg >> BP_CLKCTRL_##sr##_##ss##FRAC) & 0x3f; \ | ||
164 | parent_rate = clk_get_rate(clk->parent); \ | ||
165 | \ | ||
166 | return SH_DIV((parent_rate >> PARENT_RATE_SHIFT) * 18, \ | ||
167 | div, PARENT_RATE_SHIFT); \ | ||
168 | } | ||
169 | |||
170 | _CLK_GET_RATE_REF(ref_cpu_clk, FRAC0, CPU) | ||
171 | _CLK_GET_RATE_REF(ref_emi_clk, FRAC0, EMI) | ||
172 | _CLK_GET_RATE_REF(ref_io0_clk, FRAC0, IO0) | ||
173 | _CLK_GET_RATE_REF(ref_io1_clk, FRAC0, IO1) | ||
174 | _CLK_GET_RATE_REF(ref_pix_clk, FRAC1, PIX) | ||
175 | _CLK_GET_RATE_REF(ref_gpmi_clk, FRAC1, GPMI) | ||
176 | |||
177 | #define _DEFINE_CLOCK_REF(name, er, es) \ | ||
178 | static struct clk name = { \ | ||
179 | .enable_reg = CLKCTRL_BASE_ADDR + HW_CLKCTRL_##er, \ | ||
180 | .enable_shift = BP_CLKCTRL_##er##_CLKGATE##es, \ | ||
181 | .get_rate = name##_get_rate, \ | ||
182 | .enable = _raw_clk_enable, \ | ||
183 | .disable = _raw_clk_disable, \ | ||
184 | .parent = &pll0_clk, \ | ||
185 | } | ||
186 | |||
187 | _DEFINE_CLOCK_REF(ref_cpu_clk, FRAC0, CPU); | ||
188 | _DEFINE_CLOCK_REF(ref_emi_clk, FRAC0, EMI); | ||
189 | _DEFINE_CLOCK_REF(ref_io0_clk, FRAC0, IO0); | ||
190 | _DEFINE_CLOCK_REF(ref_io1_clk, FRAC0, IO1); | ||
191 | _DEFINE_CLOCK_REF(ref_pix_clk, FRAC1, PIX); | ||
192 | _DEFINE_CLOCK_REF(ref_gpmi_clk, FRAC1, GPMI); | ||
193 | |||
194 | /* | ||
195 | * General clocks | ||
196 | * | ||
197 | * clk_get_rate | ||
198 | */ | ||
199 | static unsigned long lradc_clk_get_rate(struct clk *clk) | ||
200 | { | ||
201 | return clk_get_rate(clk->parent) / 16; | ||
202 | } | ||
203 | |||
204 | static unsigned long rtc_clk_get_rate(struct clk *clk) | ||
205 | { | ||
206 | /* ref_xtal_clk is implemented as the only parent */ | ||
207 | return clk_get_rate(clk->parent) / 768; | ||
208 | } | ||
209 | |||
210 | static unsigned long clk32k_clk_get_rate(struct clk *clk) | ||
211 | { | ||
212 | return clk->parent->get_rate(clk->parent) / 750; | ||
213 | } | ||
214 | |||
215 | static unsigned long spdif_clk_get_rate(struct clk *clk) | ||
216 | { | ||
217 | return clk_get_rate(clk->parent) / 4; | ||
218 | } | ||
219 | |||
220 | #define _CLK_GET_RATE(name, rs) \ | ||
221 | static unsigned long name##_get_rate(struct clk *clk) \ | ||
222 | { \ | ||
223 | u32 reg, div; \ | ||
224 | \ | ||
225 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_##rs); \ | ||
226 | \ | ||
227 | if (clk->parent == &ref_xtal_clk) \ | ||
228 | div = (reg & BM_CLKCTRL_##rs##_DIV_XTAL) >> \ | ||
229 | BP_CLKCTRL_##rs##_DIV_XTAL; \ | ||
230 | else \ | ||
231 | div = (reg & BM_CLKCTRL_##rs##_DIV_##rs) >> \ | ||
232 | BP_CLKCTRL_##rs##_DIV_##rs; \ | ||
233 | \ | ||
234 | if (!div) \ | ||
235 | return -EINVAL; \ | ||
236 | \ | ||
237 | return clk_get_rate(clk->parent) / div; \ | ||
238 | } | ||
239 | |||
240 | _CLK_GET_RATE(cpu_clk, CPU) | ||
241 | _CLK_GET_RATE(emi_clk, EMI) | ||
242 | |||
243 | #define _CLK_GET_RATE1(name, rs) \ | ||
244 | static unsigned long name##_get_rate(struct clk *clk) \ | ||
245 | { \ | ||
246 | u32 reg, div; \ | ||
247 | \ | ||
248 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_##rs); \ | ||
249 | div = (reg & BM_CLKCTRL_##rs##_DIV) >> BP_CLKCTRL_##rs##_DIV; \ | ||
250 | \ | ||
251 | if (!div) \ | ||
252 | return -EINVAL; \ | ||
253 | \ | ||
254 | if (clk == &saif0_clk || clk == &saif1_clk) \ | ||
255 | return clk_get_rate(clk->parent) >> 16 * div; \ | ||
256 | else \ | ||
257 | return clk_get_rate(clk->parent) / div; \ | ||
258 | } | ||
259 | |||
260 | _CLK_GET_RATE1(hbus_clk, HBUS) | ||
261 | _CLK_GET_RATE1(xbus_clk, XBUS) | ||
262 | _CLK_GET_RATE1(ssp0_clk, SSP0) | ||
263 | _CLK_GET_RATE1(ssp1_clk, SSP1) | ||
264 | _CLK_GET_RATE1(ssp2_clk, SSP2) | ||
265 | _CLK_GET_RATE1(ssp3_clk, SSP3) | ||
266 | _CLK_GET_RATE1(gpmi_clk, GPMI) | ||
267 | _CLK_GET_RATE1(lcdif_clk, DIS_LCDIF) | ||
268 | _CLK_GET_RATE1(saif0_clk, SAIF0) | ||
269 | _CLK_GET_RATE1(saif1_clk, SAIF1) | ||
270 | |||
271 | #define _CLK_GET_RATE_STUB(name) \ | ||
272 | static unsigned long name##_get_rate(struct clk *clk) \ | ||
273 | { \ | ||
274 | return clk_get_rate(clk->parent); \ | ||
275 | } | ||
276 | |||
277 | _CLK_GET_RATE_STUB(uart_clk) | ||
278 | _CLK_GET_RATE_STUB(pwm_clk) | ||
279 | _CLK_GET_RATE_STUB(can0_clk) | ||
280 | _CLK_GET_RATE_STUB(can1_clk) | ||
281 | _CLK_GET_RATE_STUB(fec_clk) | ||
282 | |||
283 | /* | ||
284 | * clk_set_rate | ||
285 | */ | ||
286 | /* fool compiler */ | ||
287 | #define BM_CLKCTRL_CPU_DIV 0 | ||
288 | #define BP_CLKCTRL_CPU_DIV 0 | ||
289 | #define BM_CLKCTRL_CPU_BUSY 0 | ||
290 | |||
291 | #define _CLK_SET_RATE(name, dr, fr, fs) \ | ||
292 | static int name##_set_rate(struct clk *clk, unsigned long rate) \ | ||
293 | { \ | ||
294 | u32 reg, bm_busy, div_max, d, f, div, frac; \ | ||
295 | unsigned long diff, parent_rate, calc_rate; \ | ||
296 | int i; \ | ||
297 | \ | ||
298 | div_max = BM_CLKCTRL_##dr##_DIV >> BP_CLKCTRL_##dr##_DIV; \ | ||
299 | bm_busy = BM_CLKCTRL_##dr##_BUSY; \ | ||
300 | \ | ||
301 | if (clk->parent == &ref_xtal_clk) { \ | ||
302 | parent_rate = clk_get_rate(clk->parent); \ | ||
303 | div = DIV_ROUND_UP(parent_rate, rate); \ | ||
304 | if (clk == &cpu_clk) { \ | ||
305 | div_max = BM_CLKCTRL_CPU_DIV_XTAL >> \ | ||
306 | BP_CLKCTRL_CPU_DIV_XTAL; \ | ||
307 | bm_busy = BM_CLKCTRL_CPU_BUSY_REF_XTAL; \ | ||
308 | } \ | ||
309 | if (div == 0 || div > div_max) \ | ||
310 | return -EINVAL; \ | ||
311 | } else { \ | ||
312 | /* \ | ||
313 | * hack alert: this block modifies clk->parent, too, \ | ||
314 | * so the base to use it the grand parent. \ | ||
315 | */ \ | ||
316 | parent_rate = clk_get_rate(clk->parent->parent); \ | ||
317 | rate >>= PARENT_RATE_SHIFT; \ | ||
318 | parent_rate >>= PARENT_RATE_SHIFT; \ | ||
319 | diff = parent_rate; \ | ||
320 | div = frac = 1; \ | ||
321 | if (clk == &cpu_clk) { \ | ||
322 | div_max = BM_CLKCTRL_CPU_DIV_CPU >> \ | ||
323 | BP_CLKCTRL_CPU_DIV_CPU; \ | ||
324 | bm_busy = BM_CLKCTRL_CPU_BUSY_REF_CPU; \ | ||
325 | } \ | ||
326 | for (d = 1; d <= div_max; d++) { \ | ||
327 | f = parent_rate * 18 / d / rate; \ | ||
328 | if ((parent_rate * 18 / d) % rate) \ | ||
329 | f++; \ | ||
330 | if (f < 18 || f > 35) \ | ||
331 | continue; \ | ||
332 | \ | ||
333 | calc_rate = parent_rate * 18 / f / d; \ | ||
334 | if (calc_rate > rate) \ | ||
335 | continue; \ | ||
336 | \ | ||
337 | if (rate - calc_rate < diff) { \ | ||
338 | frac = f; \ | ||
339 | div = d; \ | ||
340 | diff = rate - calc_rate; \ | ||
341 | } \ | ||
342 | \ | ||
343 | if (diff == 0) \ | ||
344 | break; \ | ||
345 | } \ | ||
346 | \ | ||
347 | if (diff == parent_rate) \ | ||
348 | return -EINVAL; \ | ||
349 | \ | ||
350 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_##fr); \ | ||
351 | reg &= ~BM_CLKCTRL_##fr##_##fs##FRAC; \ | ||
352 | reg |= frac; \ | ||
353 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_##fr); \ | ||
354 | } \ | ||
355 | \ | ||
356 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_##dr); \ | ||
357 | if (clk == &cpu_clk) { \ | ||
358 | reg &= ~BM_CLKCTRL_CPU_DIV_CPU; \ | ||
359 | reg |= div << BP_CLKCTRL_CPU_DIV_CPU; \ | ||
360 | } else { \ | ||
361 | reg &= ~BM_CLKCTRL_##dr##_DIV; \ | ||
362 | reg |= div << BP_CLKCTRL_##dr##_DIV; \ | ||
363 | if (reg & (1 << clk->enable_shift)) { \ | ||
364 | pr_err("%s: clock is gated\n", __func__); \ | ||
365 | return -EINVAL; \ | ||
366 | } \ | ||
367 | } \ | ||
368 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_##dr); \ | ||
369 | \ | ||
370 | for (i = 10000; i; i--) \ | ||
371 | if (!(__raw_readl(CLKCTRL_BASE_ADDR + \ | ||
372 | HW_CLKCTRL_##dr) & bm_busy)) \ | ||
373 | break; \ | ||
374 | if (!i) { \ | ||
375 | pr_err("%s: divider writing timeout\n", __func__); \ | ||
376 | return -ETIMEDOUT; \ | ||
377 | } \ | ||
378 | \ | ||
379 | return 0; \ | ||
380 | } | ||
381 | |||
382 | _CLK_SET_RATE(cpu_clk, CPU, FRAC0, CPU) | ||
383 | _CLK_SET_RATE(ssp0_clk, SSP0, FRAC0, IO0) | ||
384 | _CLK_SET_RATE(ssp1_clk, SSP1, FRAC0, IO0) | ||
385 | _CLK_SET_RATE(ssp2_clk, SSP2, FRAC0, IO1) | ||
386 | _CLK_SET_RATE(ssp3_clk, SSP3, FRAC0, IO1) | ||
387 | _CLK_SET_RATE(lcdif_clk, DIS_LCDIF, FRAC1, PIX) | ||
388 | _CLK_SET_RATE(gpmi_clk, GPMI, FRAC1, GPMI) | ||
389 | |||
390 | #define _CLK_SET_RATE1(name, dr) \ | ||
391 | static int name##_set_rate(struct clk *clk, unsigned long rate) \ | ||
392 | { \ | ||
393 | u32 reg, div_max, div; \ | ||
394 | unsigned long parent_rate; \ | ||
395 | int i; \ | ||
396 | \ | ||
397 | parent_rate = clk_get_rate(clk->parent); \ | ||
398 | div_max = BM_CLKCTRL_##dr##_DIV >> BP_CLKCTRL_##dr##_DIV; \ | ||
399 | \ | ||
400 | div = DIV_ROUND_UP(parent_rate, rate); \ | ||
401 | if (div == 0 || div > div_max) \ | ||
402 | return -EINVAL; \ | ||
403 | \ | ||
404 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_##dr); \ | ||
405 | reg &= ~BM_CLKCTRL_##dr##_DIV; \ | ||
406 | reg |= div << BP_CLKCTRL_##dr##_DIV; \ | ||
407 | if (reg & (1 << clk->enable_shift)) { \ | ||
408 | pr_err("%s: clock is gated\n", __func__); \ | ||
409 | return -EINVAL; \ | ||
410 | } \ | ||
411 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_##dr); \ | ||
412 | \ | ||
413 | for (i = 10000; i; i--) \ | ||
414 | if (!(__raw_readl(CLKCTRL_BASE_ADDR + \ | ||
415 | HW_CLKCTRL_##dr) & BM_CLKCTRL_##dr##_BUSY)) \ | ||
416 | break; \ | ||
417 | if (!i) { \ | ||
418 | pr_err("%s: divider writing timeout\n", __func__); \ | ||
419 | return -ETIMEDOUT; \ | ||
420 | } \ | ||
421 | \ | ||
422 | return 0; \ | ||
423 | } | ||
424 | |||
425 | _CLK_SET_RATE1(xbus_clk, XBUS) | ||
426 | |||
427 | /* saif clock uses 16 bits frac div */ | ||
428 | #define _CLK_SET_RATE_SAIF(name, rs) \ | ||
429 | static int name##_set_rate(struct clk *clk, unsigned long rate) \ | ||
430 | { \ | ||
431 | u16 div; \ | ||
432 | u32 reg; \ | ||
433 | u64 lrate; \ | ||
434 | unsigned long parent_rate; \ | ||
435 | int i; \ | ||
436 | \ | ||
437 | parent_rate = clk_get_rate(clk->parent); \ | ||
438 | if (rate > parent_rate) \ | ||
439 | return -EINVAL; \ | ||
440 | \ | ||
441 | lrate = (u64)rate << 16; \ | ||
442 | do_div(lrate, parent_rate); \ | ||
443 | div = (u16)lrate; \ | ||
444 | \ | ||
445 | if (!div) \ | ||
446 | return -EINVAL; \ | ||
447 | \ | ||
448 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_##rs); \ | ||
449 | reg &= ~BM_CLKCTRL_##rs##_DIV; \ | ||
450 | reg |= div << BP_CLKCTRL_##rs##_DIV; \ | ||
451 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_##rs); \ | ||
452 | \ | ||
453 | for (i = 10000; i; i--) \ | ||
454 | if (!(__raw_readl(CLKCTRL_BASE_ADDR + \ | ||
455 | HW_CLKCTRL_##rs) & BM_CLKCTRL_##rs##_BUSY)) \ | ||
456 | break; \ | ||
457 | if (!i) { \ | ||
458 | pr_err("%s: divider writing timeout\n", __func__); \ | ||
459 | return -ETIMEDOUT; \ | ||
460 | } \ | ||
461 | \ | ||
462 | return 0; \ | ||
463 | } | ||
464 | |||
465 | _CLK_SET_RATE_SAIF(saif0_clk, SAIF0) | ||
466 | _CLK_SET_RATE_SAIF(saif1_clk, SAIF1) | ||
467 | |||
468 | #define _CLK_SET_RATE_STUB(name) \ | ||
469 | static int name##_set_rate(struct clk *clk, unsigned long rate) \ | ||
470 | { \ | ||
471 | return -EINVAL; \ | ||
472 | } | ||
473 | |||
474 | _CLK_SET_RATE_STUB(emi_clk) | ||
475 | _CLK_SET_RATE_STUB(uart_clk) | ||
476 | _CLK_SET_RATE_STUB(pwm_clk) | ||
477 | _CLK_SET_RATE_STUB(spdif_clk) | ||
478 | _CLK_SET_RATE_STUB(clk32k_clk) | ||
479 | _CLK_SET_RATE_STUB(can0_clk) | ||
480 | _CLK_SET_RATE_STUB(can1_clk) | ||
481 | _CLK_SET_RATE_STUB(fec_clk) | ||
482 | |||
483 | /* | ||
484 | * clk_set_parent | ||
485 | */ | ||
486 | #define _CLK_SET_PARENT(name, bit) \ | ||
487 | static int name##_set_parent(struct clk *clk, struct clk *parent) \ | ||
488 | { \ | ||
489 | if (parent != clk->parent) { \ | ||
490 | __raw_writel(BM_CLKCTRL_CLKSEQ_BYPASS_##bit, \ | ||
491 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_CLKSEQ_TOG); \ | ||
492 | clk->parent = parent; \ | ||
493 | } \ | ||
494 | \ | ||
495 | return 0; \ | ||
496 | } | ||
497 | |||
498 | _CLK_SET_PARENT(cpu_clk, CPU) | ||
499 | _CLK_SET_PARENT(emi_clk, EMI) | ||
500 | _CLK_SET_PARENT(ssp0_clk, SSP0) | ||
501 | _CLK_SET_PARENT(ssp1_clk, SSP1) | ||
502 | _CLK_SET_PARENT(ssp2_clk, SSP2) | ||
503 | _CLK_SET_PARENT(ssp3_clk, SSP3) | ||
504 | _CLK_SET_PARENT(lcdif_clk, DIS_LCDIF) | ||
505 | _CLK_SET_PARENT(gpmi_clk, GPMI) | ||
506 | _CLK_SET_PARENT(saif0_clk, SAIF0) | ||
507 | _CLK_SET_PARENT(saif1_clk, SAIF1) | ||
508 | |||
509 | #define _CLK_SET_PARENT_STUB(name) \ | ||
510 | static int name##_set_parent(struct clk *clk, struct clk *parent) \ | ||
511 | { \ | ||
512 | if (parent != clk->parent) \ | ||
513 | return -EINVAL; \ | ||
514 | else \ | ||
515 | return 0; \ | ||
516 | } | ||
517 | |||
518 | _CLK_SET_PARENT_STUB(pwm_clk) | ||
519 | _CLK_SET_PARENT_STUB(uart_clk) | ||
520 | _CLK_SET_PARENT_STUB(clk32k_clk) | ||
521 | _CLK_SET_PARENT_STUB(spdif_clk) | ||
522 | _CLK_SET_PARENT_STUB(fec_clk) | ||
523 | _CLK_SET_PARENT_STUB(can0_clk) | ||
524 | _CLK_SET_PARENT_STUB(can1_clk) | ||
525 | |||
526 | /* | ||
527 | * clk definition | ||
528 | */ | ||
529 | static struct clk cpu_clk = { | ||
530 | .get_rate = cpu_clk_get_rate, | ||
531 | .set_rate = cpu_clk_set_rate, | ||
532 | .set_parent = cpu_clk_set_parent, | ||
533 | .parent = &ref_cpu_clk, | ||
534 | }; | ||
535 | |||
536 | static struct clk hbus_clk = { | ||
537 | .get_rate = hbus_clk_get_rate, | ||
538 | .parent = &cpu_clk, | ||
539 | }; | ||
540 | |||
541 | static struct clk xbus_clk = { | ||
542 | .get_rate = xbus_clk_get_rate, | ||
543 | .set_rate = xbus_clk_set_rate, | ||
544 | .parent = &ref_xtal_clk, | ||
545 | }; | ||
546 | |||
547 | static struct clk lradc_clk = { | ||
548 | .get_rate = lradc_clk_get_rate, | ||
549 | .parent = &clk32k_clk, | ||
550 | }; | ||
551 | |||
552 | static struct clk rtc_clk = { | ||
553 | .get_rate = rtc_clk_get_rate, | ||
554 | .parent = &ref_xtal_clk, | ||
555 | }; | ||
556 | |||
557 | /* usb_clk gate is controlled in DIGCTRL other than CLKCTRL */ | ||
558 | static struct clk usb0_clk = { | ||
559 | .enable_reg = DIGCTRL_BASE_ADDR, | ||
560 | .enable_shift = 2, | ||
561 | .enable = _raw_clk_enable, | ||
562 | .disable = _raw_clk_disable, | ||
563 | .parent = &pll0_clk, | ||
564 | }; | ||
565 | |||
566 | static struct clk usb1_clk = { | ||
567 | .enable_reg = DIGCTRL_BASE_ADDR, | ||
568 | .enable_shift = 16, | ||
569 | .enable = _raw_clk_enable, | ||
570 | .disable = _raw_clk_disable, | ||
571 | .parent = &pll1_clk, | ||
572 | }; | ||
573 | |||
574 | #define _DEFINE_CLOCK(name, er, es, p) \ | ||
575 | static struct clk name = { \ | ||
576 | .enable_reg = CLKCTRL_BASE_ADDR + HW_CLKCTRL_##er, \ | ||
577 | .enable_shift = BP_CLKCTRL_##er##_##es, \ | ||
578 | .get_rate = name##_get_rate, \ | ||
579 | .set_rate = name##_set_rate, \ | ||
580 | .set_parent = name##_set_parent, \ | ||
581 | .enable = _raw_clk_enable, \ | ||
582 | .disable = _raw_clk_disable, \ | ||
583 | .parent = p, \ | ||
584 | } | ||
585 | |||
586 | _DEFINE_CLOCK(emi_clk, EMI, CLKGATE, &ref_xtal_clk); | ||
587 | _DEFINE_CLOCK(ssp0_clk, SSP0, CLKGATE, &ref_xtal_clk); | ||
588 | _DEFINE_CLOCK(ssp1_clk, SSP1, CLKGATE, &ref_xtal_clk); | ||
589 | _DEFINE_CLOCK(ssp2_clk, SSP2, CLKGATE, &ref_xtal_clk); | ||
590 | _DEFINE_CLOCK(ssp3_clk, SSP3, CLKGATE, &ref_xtal_clk); | ||
591 | _DEFINE_CLOCK(lcdif_clk, DIS_LCDIF, CLKGATE, &ref_xtal_clk); | ||
592 | _DEFINE_CLOCK(gpmi_clk, GPMI, CLKGATE, &ref_xtal_clk); | ||
593 | _DEFINE_CLOCK(saif0_clk, SAIF0, CLKGATE, &ref_xtal_clk); | ||
594 | _DEFINE_CLOCK(saif1_clk, SAIF1, CLKGATE, &ref_xtal_clk); | ||
595 | _DEFINE_CLOCK(can0_clk, FLEXCAN, STOP_CAN0, &ref_xtal_clk); | ||
596 | _DEFINE_CLOCK(can1_clk, FLEXCAN, STOP_CAN1, &ref_xtal_clk); | ||
597 | _DEFINE_CLOCK(pwm_clk, XTAL, PWM_CLK24M_GATE, &ref_xtal_clk); | ||
598 | _DEFINE_CLOCK(uart_clk, XTAL, UART_CLK_GATE, &ref_xtal_clk); | ||
599 | _DEFINE_CLOCK(clk32k_clk, XTAL, TIMROT_CLK32K_GATE, &ref_xtal_clk); | ||
600 | _DEFINE_CLOCK(spdif_clk, SPDIF, CLKGATE, &pll0_clk); | ||
601 | _DEFINE_CLOCK(fec_clk, ENET, DISABLE, &hbus_clk); | ||
602 | |||
603 | #define _REGISTER_CLOCK(d, n, c) \ | ||
604 | { \ | ||
605 | .dev_id = d, \ | ||
606 | .con_id = n, \ | ||
607 | .clk = &c, \ | ||
608 | }, | ||
609 | |||
610 | static struct clk_lookup lookups[] = { | ||
611 | /* for amba bus driver */ | ||
612 | _REGISTER_CLOCK("duart", "apb_pclk", xbus_clk) | ||
613 | /* for amba-pl011 driver */ | ||
614 | _REGISTER_CLOCK("duart", NULL, uart_clk) | ||
615 | _REGISTER_CLOCK("imx28-fec.0", NULL, fec_clk) | ||
616 | _REGISTER_CLOCK("imx28-fec.1", NULL, fec_clk) | ||
617 | _REGISTER_CLOCK("mxs-auart.0", NULL, uart_clk) | ||
618 | _REGISTER_CLOCK("mxs-auart.1", NULL, uart_clk) | ||
619 | _REGISTER_CLOCK("mxs-auart.2", NULL, uart_clk) | ||
620 | _REGISTER_CLOCK("mxs-auart.3", NULL, uart_clk) | ||
621 | _REGISTER_CLOCK("mxs-auart.4", NULL, uart_clk) | ||
622 | _REGISTER_CLOCK("rtc", NULL, rtc_clk) | ||
623 | _REGISTER_CLOCK("pll2", NULL, pll2_clk) | ||
624 | _REGISTER_CLOCK("mxs-dma-apbh", NULL, hbus_clk) | ||
625 | _REGISTER_CLOCK("mxs-dma-apbx", NULL, xbus_clk) | ||
626 | _REGISTER_CLOCK("mxs-mmc.0", NULL, ssp0_clk) | ||
627 | _REGISTER_CLOCK("mxs-mmc.1", NULL, ssp1_clk) | ||
628 | _REGISTER_CLOCK("flexcan.0", NULL, can0_clk) | ||
629 | _REGISTER_CLOCK("flexcan.1", NULL, can1_clk) | ||
630 | _REGISTER_CLOCK(NULL, "usb0", usb0_clk) | ||
631 | _REGISTER_CLOCK(NULL, "usb1", usb1_clk) | ||
632 | _REGISTER_CLOCK("mxs-pwm.0", NULL, pwm_clk) | ||
633 | _REGISTER_CLOCK("mxs-pwm.1", NULL, pwm_clk) | ||
634 | _REGISTER_CLOCK("mxs-pwm.2", NULL, pwm_clk) | ||
635 | _REGISTER_CLOCK("mxs-pwm.3", NULL, pwm_clk) | ||
636 | _REGISTER_CLOCK("mxs-pwm.4", NULL, pwm_clk) | ||
637 | _REGISTER_CLOCK("mxs-pwm.5", NULL, pwm_clk) | ||
638 | _REGISTER_CLOCK("mxs-pwm.6", NULL, pwm_clk) | ||
639 | _REGISTER_CLOCK("mxs-pwm.7", NULL, pwm_clk) | ||
640 | _REGISTER_CLOCK(NULL, "lradc", lradc_clk) | ||
641 | _REGISTER_CLOCK(NULL, "spdif", spdif_clk) | ||
642 | _REGISTER_CLOCK("imx28-fb", NULL, lcdif_clk) | ||
643 | }; | ||
644 | |||
645 | static int clk_misc_init(void) | ||
646 | { | ||
647 | u32 reg; | ||
648 | int i; | ||
649 | |||
650 | /* Fix up parent per register setting */ | ||
651 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_CLKSEQ); | ||
652 | cpu_clk.parent = (reg & BM_CLKCTRL_CLKSEQ_BYPASS_CPU) ? | ||
653 | &ref_xtal_clk : &ref_cpu_clk; | ||
654 | emi_clk.parent = (reg & BM_CLKCTRL_CLKSEQ_BYPASS_EMI) ? | ||
655 | &ref_xtal_clk : &ref_emi_clk; | ||
656 | ssp0_clk.parent = (reg & BM_CLKCTRL_CLKSEQ_BYPASS_SSP0) ? | ||
657 | &ref_xtal_clk : &ref_io0_clk; | ||
658 | ssp1_clk.parent = (reg & BM_CLKCTRL_CLKSEQ_BYPASS_SSP1) ? | ||
659 | &ref_xtal_clk : &ref_io0_clk; | ||
660 | ssp2_clk.parent = (reg & BM_CLKCTRL_CLKSEQ_BYPASS_SSP2) ? | ||
661 | &ref_xtal_clk : &ref_io1_clk; | ||
662 | ssp3_clk.parent = (reg & BM_CLKCTRL_CLKSEQ_BYPASS_SSP3) ? | ||
663 | &ref_xtal_clk : &ref_io1_clk; | ||
664 | lcdif_clk.parent = (reg & BM_CLKCTRL_CLKSEQ_BYPASS_DIS_LCDIF) ? | ||
665 | &ref_xtal_clk : &ref_pix_clk; | ||
666 | gpmi_clk.parent = (reg & BM_CLKCTRL_CLKSEQ_BYPASS_GPMI) ? | ||
667 | &ref_xtal_clk : &ref_gpmi_clk; | ||
668 | saif0_clk.parent = (reg & BM_CLKCTRL_CLKSEQ_BYPASS_SAIF0) ? | ||
669 | &ref_xtal_clk : &pll0_clk; | ||
670 | saif1_clk.parent = (reg & BM_CLKCTRL_CLKSEQ_BYPASS_SAIF1) ? | ||
671 | &ref_xtal_clk : &pll0_clk; | ||
672 | |||
673 | /* Use int div over frac when both are available */ | ||
674 | __raw_writel(BM_CLKCTRL_CPU_DIV_XTAL_FRAC_EN, | ||
675 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_CPU_CLR); | ||
676 | __raw_writel(BM_CLKCTRL_CPU_DIV_CPU_FRAC_EN, | ||
677 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_CPU_CLR); | ||
678 | __raw_writel(BM_CLKCTRL_HBUS_DIV_FRAC_EN, | ||
679 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_HBUS_CLR); | ||
680 | |||
681 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_XBUS); | ||
682 | reg &= ~BM_CLKCTRL_XBUS_DIV_FRAC_EN; | ||
683 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_XBUS); | ||
684 | |||
685 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_SSP0); | ||
686 | reg &= ~BM_CLKCTRL_SSP0_DIV_FRAC_EN; | ||
687 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_SSP0); | ||
688 | |||
689 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_SSP1); | ||
690 | reg &= ~BM_CLKCTRL_SSP1_DIV_FRAC_EN; | ||
691 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_SSP1); | ||
692 | |||
693 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_SSP2); | ||
694 | reg &= ~BM_CLKCTRL_SSP2_DIV_FRAC_EN; | ||
695 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_SSP2); | ||
696 | |||
697 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_SSP3); | ||
698 | reg &= ~BM_CLKCTRL_SSP3_DIV_FRAC_EN; | ||
699 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_SSP3); | ||
700 | |||
701 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_GPMI); | ||
702 | reg &= ~BM_CLKCTRL_GPMI_DIV_FRAC_EN; | ||
703 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_GPMI); | ||
704 | |||
705 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_DIS_LCDIF); | ||
706 | reg &= ~BM_CLKCTRL_DIS_LCDIF_DIV_FRAC_EN; | ||
707 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_DIS_LCDIF); | ||
708 | |||
709 | /* SAIF has to use frac div for functional operation */ | ||
710 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_SAIF0); | ||
711 | reg &= ~BM_CLKCTRL_SAIF0_DIV_FRAC_EN; | ||
712 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_SAIF0); | ||
713 | |||
714 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_SAIF1); | ||
715 | reg &= ~BM_CLKCTRL_SAIF1_DIV_FRAC_EN; | ||
716 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_SAIF1); | ||
717 | |||
718 | /* | ||
719 | * Set safe hbus clock divider. A divider of 3 ensure that | ||
720 | * the Vddd voltage required for the cpu clock is sufficiently | ||
721 | * high for the hbus clock. | ||
722 | */ | ||
723 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_HBUS); | ||
724 | reg &= BM_CLKCTRL_HBUS_DIV; | ||
725 | reg |= 3 << BP_CLKCTRL_HBUS_DIV; | ||
726 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_HBUS); | ||
727 | |||
728 | for (i = 10000; i; i--) | ||
729 | if (!(__raw_readl(CLKCTRL_BASE_ADDR + | ||
730 | HW_CLKCTRL_HBUS) & BM_CLKCTRL_HBUS_ASM_BUSY)) | ||
731 | break; | ||
732 | if (!i) { | ||
733 | pr_err("%s: divider writing timeout\n", __func__); | ||
734 | return -ETIMEDOUT; | ||
735 | } | ||
736 | |||
737 | /* Gate off cpu clock in WFI for power saving */ | ||
738 | __raw_writel(BM_CLKCTRL_CPU_INTERRUPT_WAIT, | ||
739 | CLKCTRL_BASE_ADDR + HW_CLKCTRL_CPU_SET); | ||
740 | |||
741 | /* Extra fec clock setting */ | ||
742 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_ENET); | ||
743 | reg &= ~BM_CLKCTRL_ENET_SLEEP; | ||
744 | reg |= BM_CLKCTRL_ENET_CLK_OUT_EN; | ||
745 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_ENET); | ||
746 | |||
747 | /* | ||
748 | * 480 MHz seems too high to be ssp clock source directly, | ||
749 | * so set frac0 to get a 288 MHz ref_io0. | ||
750 | */ | ||
751 | reg = __raw_readl(CLKCTRL_BASE_ADDR + HW_CLKCTRL_FRAC0); | ||
752 | reg &= ~BM_CLKCTRL_FRAC0_IO0FRAC; | ||
753 | reg |= 30 << BP_CLKCTRL_FRAC0_IO0FRAC; | ||
754 | __raw_writel(reg, CLKCTRL_BASE_ADDR + HW_CLKCTRL_FRAC0); | ||
755 | |||
756 | return 0; | ||
757 | } | ||
758 | |||
759 | int __init mx28_clocks_init(void) | ||
760 | { | ||
761 | clk_misc_init(); | ||
762 | |||
763 | /* | ||
764 | * source ssp clock from ref_io0 than ref_xtal, | ||
765 | * as ref_xtal only provides 24 MHz as maximum. | ||
766 | */ | ||
767 | clk_set_parent(&ssp0_clk, &ref_io0_clk); | ||
768 | clk_set_parent(&ssp1_clk, &ref_io0_clk); | ||
769 | |||
770 | clk_enable(&cpu_clk); | ||
771 | clk_enable(&hbus_clk); | ||
772 | clk_enable(&xbus_clk); | ||
773 | clk_enable(&emi_clk); | ||
774 | clk_enable(&uart_clk); | ||
775 | |||
776 | clk_set_parent(&lcdif_clk, &ref_pix_clk); | ||
777 | |||
778 | clkdev_add_table(lookups, ARRAY_SIZE(lookups)); | ||
779 | |||
780 | mxs_timer_init(&clk32k_clk, MX28_INT_TIMER0); | ||
781 | |||
782 | return 0; | ||
783 | } | ||
diff --git a/arch/arm/mach-mxs/clock.c b/arch/arm/mach-mxs/clock.c new file mode 100644 index 00000000000..a7093c88e6a --- /dev/null +++ b/arch/arm/mach-mxs/clock.c | |||
@@ -0,0 +1,198 @@ | |||
1 | /* | ||
2 | * Based on arch/arm/plat-omap/clock.c | ||
3 | * | ||
4 | * Copyright (C) 2004 - 2005 Nokia corporation | ||
5 | * Written by Tuukka Tikkanen <tuukka.tikkanen@elektrobit.com> | ||
6 | * Modified for omap shared clock framework by Tony Lindgren <tony@atomide.com> | ||
7 | * Copyright 2007 Freescale Semiconductor, Inc. All Rights Reserved. | ||
8 | * Copyright 2008 Juergen Beisert, kernel@pengutronix.de | ||
9 | * | ||
10 | * This program is free software; you can redistribute it and/or | ||
11 | * modify it under the terms of the GNU General Public License | ||
12 | * as published by the Free Software Foundation; either version 2 | ||
13 | * of the License, or (at your option) any later version. | ||
14 | * This program is distributed in the hope that it will be useful, | ||
15 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
16 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
17 | * GNU General Public License for more details. | ||
18 | * | ||
19 | * You should have received a copy of the GNU General Public License | ||
20 | * along with this program; if not, write to the Free Software | ||
21 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, | ||
22 | * MA 02110-1301, USA. | ||
23 | */ | ||
24 | |||
25 | /* #define DEBUG */ | ||
26 | |||
27 | #include <linux/clk.h> | ||
28 | #include <linux/err.h> | ||
29 | #include <linux/errno.h> | ||
30 | #include <linux/init.h> | ||
31 | #include <linux/io.h> | ||
32 | #include <linux/kernel.h> | ||
33 | #include <linux/list.h> | ||
34 | #include <linux/module.h> | ||
35 | #include <linux/mutex.h> | ||
36 | #include <linux/platform_device.h> | ||
37 | #include <linux/proc_fs.h> | ||
38 | #include <linux/semaphore.h> | ||
39 | #include <linux/string.h> | ||
40 | |||
41 | #include <mach/clock.h> | ||
42 | |||
43 | static LIST_HEAD(clocks); | ||
44 | static DEFINE_MUTEX(clocks_mutex); | ||
45 | |||
46 | /*------------------------------------------------------------------------- | ||
47 | * Standard clock functions defined in include/linux/clk.h | ||
48 | *-------------------------------------------------------------------------*/ | ||
49 | |||
50 | static void __clk_disable(struct clk *clk) | ||
51 | { | ||
52 | if (clk == NULL || IS_ERR(clk)) | ||
53 | return; | ||
54 | WARN_ON(!clk->usecount); | ||
55 | |||
56 | if (!(--clk->usecount)) { | ||
57 | if (clk->disable) | ||
58 | clk->disable(clk); | ||
59 | __clk_disable(clk->parent); | ||
60 | } | ||
61 | } | ||
62 | |||
63 | static int __clk_enable(struct clk *clk) | ||
64 | { | ||
65 | if (clk == NULL || IS_ERR(clk)) | ||
66 | return -EINVAL; | ||
67 | |||
68 | if (clk->usecount++ == 0) { | ||
69 | __clk_enable(clk->parent); | ||
70 | |||
71 | if (clk->enable) | ||
72 | clk->enable(clk); | ||
73 | } | ||
74 | return 0; | ||
75 | } | ||
76 | |||
77 | /* This function increments the reference count on the clock and enables the | ||
78 | * clock if not already enabled. The parent clock tree is recursively enabled | ||
79 | */ | ||
80 | int clk_enable(struct clk *clk) | ||
81 | { | ||
82 | int ret = 0; | ||
83 | |||
84 | if (clk == NULL || IS_ERR(clk)) | ||
85 | return -EINVAL; | ||
86 | |||
87 | mutex_lock(&clocks_mutex); | ||
88 | ret = __clk_enable(clk); | ||
89 | mutex_unlock(&clocks_mutex); | ||
90 | |||
91 | return ret; | ||
92 | } | ||
93 | EXPORT_SYMBOL(clk_enable); | ||
94 | |||
95 | /* This function decrements the reference count on the clock and disables | ||
96 | * the clock when reference count is 0. The parent clock tree is | ||
97 | * recursively disabled | ||
98 | */ | ||
99 | void clk_disable(struct clk *clk) | ||
100 | { | ||
101 | if (clk == NULL || IS_ERR(clk)) | ||
102 | return; | ||
103 | |||
104 | mutex_lock(&clocks_mutex); | ||
105 | __clk_disable(clk); | ||
106 | mutex_unlock(&clocks_mutex); | ||
107 | } | ||
108 | EXPORT_SYMBOL(clk_disable); | ||
109 | |||
110 | /* Retrieve the *current* clock rate. If the clock itself | ||
111 | * does not provide a special calculation routine, ask | ||
112 | * its parent and so on, until one is able to return | ||
113 | * a valid clock rate | ||
114 | */ | ||
115 | unsigned long clk_get_rate(struct clk *clk) | ||
116 | { | ||
117 | if (clk == NULL || IS_ERR(clk)) | ||
118 | return 0UL; | ||
119 | |||
120 | if (clk->get_rate) | ||
121 | return clk->get_rate(clk); | ||
122 | |||
123 | return clk_get_rate(clk->parent); | ||
124 | } | ||
125 | EXPORT_SYMBOL(clk_get_rate); | ||
126 | |||
127 | /* Round the requested clock rate to the nearest supported | ||
128 | * rate that is less than or equal to the requested rate. | ||
129 | * This is dependent on the clock's current parent. | ||
130 | */ | ||
131 | long clk_round_rate(struct clk *clk, unsigned long rate) | ||
132 | { | ||
133 | if (clk == NULL || IS_ERR(clk) || !clk->round_rate) | ||
134 | return 0; | ||
135 | |||
136 | return clk->round_rate(clk, rate); | ||
137 | } | ||
138 | EXPORT_SYMBOL(clk_round_rate); | ||
139 | |||
140 | /* Set the clock to the requested clock rate. The rate must | ||
141 | * match a supported rate exactly based on what clk_round_rate returns | ||
142 | */ | ||
143 | int clk_set_rate(struct clk *clk, unsigned long rate) | ||
144 | { | ||
145 | int ret = -EINVAL; | ||
146 | |||
147 | if (clk == NULL || IS_ERR(clk) || clk->set_rate == NULL || rate == 0) | ||
148 | return ret; | ||
149 | |||
150 | mutex_lock(&clocks_mutex); | ||
151 | ret = clk->set_rate(clk, rate); | ||
152 | mutex_unlock(&clocks_mutex); | ||
153 | |||
154 | return ret; | ||
155 | } | ||
156 | EXPORT_SYMBOL(clk_set_rate); | ||
157 | |||
158 | /* Set the clock's parent to another clock source */ | ||
159 | int clk_set_parent(struct clk *clk, struct clk *parent) | ||
160 | { | ||
161 | int ret = -EINVAL; | ||
162 | struct clk *old; | ||
163 | |||
164 | if (clk == NULL || IS_ERR(clk) || parent == NULL || | ||
165 | IS_ERR(parent) || clk->set_parent == NULL) | ||
166 | return ret; | ||
167 | |||
168 | if (clk->usecount) | ||
169 | clk_enable(parent); | ||
170 | |||
171 | mutex_lock(&clocks_mutex); | ||
172 | ret = clk->set_parent(clk, parent); | ||
173 | if (ret == 0) { | ||
174 | old = clk->parent; | ||
175 | clk->parent = parent; | ||
176 | } else { | ||
177 | old = parent; | ||
178 | } | ||
179 | mutex_unlock(&clocks_mutex); | ||
180 | |||
181 | if (clk->usecount) | ||
182 | clk_disable(old); | ||
183 | |||
184 | return ret; | ||
185 | } | ||
186 | EXPORT_SYMBOL(clk_set_parent); | ||
187 | |||
188 | /* Retrieve the clock's parent clock source */ | ||
189 | struct clk *clk_get_parent(struct clk *clk) | ||
190 | { | ||
191 | struct clk *ret = NULL; | ||
192 | |||
193 | if (clk == NULL || IS_ERR(clk)) | ||
194 | return ret; | ||
195 | |||
196 | return clk->parent; | ||
197 | } | ||
198 | EXPORT_SYMBOL(clk_get_parent); | ||
diff --git a/arch/arm/mach-mxs/devices-mx23.h b/arch/arm/mach-mxs/devices-mx23.h new file mode 100644 index 00000000000..c6f345febd3 --- /dev/null +++ b/arch/arm/mach-mxs/devices-mx23.h | |||
@@ -0,0 +1,31 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2010 Pengutronix | ||
3 | * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de> | ||
4 | * | ||
5 | * Copyright 2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify it under | ||
8 | * the terms of the GNU General Public License version 2 as published by the | ||
9 | * Free Software Foundation. | ||
10 | */ | ||
11 | #include <mach/mx23.h> | ||
12 | #include <mach/devices-common.h> | ||
13 | #include <mach/mxsfb.h> | ||
14 | |||
15 | extern const struct amba_device mx23_duart_device __initconst; | ||
16 | #define mx23_add_duart() \ | ||
17 | mxs_add_duart(&mx23_duart_device) | ||
18 | |||
19 | extern const struct mxs_auart_data mx23_auart_data[] __initconst; | ||
20 | #define mx23_add_auart(id) mxs_add_auart(&mx23_auart_data[id]) | ||
21 | #define mx23_add_auart0() mx23_add_auart(0) | ||
22 | #define mx23_add_auart1() mx23_add_auart(1) | ||
23 | |||
24 | extern const struct mxs_mxs_mmc_data mx23_mxs_mmc_data[] __initconst; | ||
25 | #define mx23_add_mxs_mmc(id, pdata) \ | ||
26 | mxs_add_mxs_mmc(&mx23_mxs_mmc_data[id], pdata) | ||
27 | |||
28 | #define mx23_add_mxs_pwm(id) mxs_add_mxs_pwm(MX23_PWM_BASE_ADDR, id) | ||
29 | |||
30 | struct platform_device *__init mx23_add_mxsfb( | ||
31 | const struct mxsfb_platform_data *pdata); | ||
diff --git a/arch/arm/mach-mxs/devices-mx28.h b/arch/arm/mach-mxs/devices-mx28.h new file mode 100644 index 00000000000..79b94523954 --- /dev/null +++ b/arch/arm/mach-mxs/devices-mx28.h | |||
@@ -0,0 +1,47 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2010 Pengutronix | ||
3 | * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de> | ||
4 | * | ||
5 | * Copyright 2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify it under | ||
8 | * the terms of the GNU General Public License version 2 as published by the | ||
9 | * Free Software Foundation. | ||
10 | */ | ||
11 | #include <mach/mx28.h> | ||
12 | #include <mach/devices-common.h> | ||
13 | #include <mach/mxsfb.h> | ||
14 | |||
15 | extern const struct amba_device mx28_duart_device __initconst; | ||
16 | #define mx28_add_duart() \ | ||
17 | mxs_add_duart(&mx28_duart_device) | ||
18 | |||
19 | extern const struct mxs_auart_data mx28_auart_data[] __initconst; | ||
20 | #define mx28_add_auart(id) mxs_add_auart(&mx28_auart_data[id]) | ||
21 | #define mx28_add_auart0() mx28_add_auart(0) | ||
22 | #define mx28_add_auart1() mx28_add_auart(1) | ||
23 | #define mx28_add_auart2() mx28_add_auart(2) | ||
24 | #define mx28_add_auart3() mx28_add_auart(3) | ||
25 | #define mx28_add_auart4() mx28_add_auart(4) | ||
26 | |||
27 | extern const struct mxs_fec_data mx28_fec_data[] __initconst; | ||
28 | #define mx28_add_fec(id, pdata) \ | ||
29 | mxs_add_fec(&mx28_fec_data[id], pdata) | ||
30 | |||
31 | extern const struct mxs_flexcan_data mx28_flexcan_data[] __initconst; | ||
32 | #define mx28_add_flexcan(id, pdata) \ | ||
33 | mxs_add_flexcan(&mx28_flexcan_data[id], pdata) | ||
34 | #define mx28_add_flexcan0(pdata) mx28_add_flexcan(0, pdata) | ||
35 | #define mx28_add_flexcan1(pdata) mx28_add_flexcan(1, pdata) | ||
36 | |||
37 | extern const struct mxs_mxs_i2c_data mx28_mxs_i2c_data[] __initconst; | ||
38 | #define mx28_add_mxs_i2c(id) mxs_add_mxs_i2c(&mx28_mxs_i2c_data[id]) | ||
39 | |||
40 | extern const struct mxs_mxs_mmc_data mx28_mxs_mmc_data[] __initconst; | ||
41 | #define mx28_add_mxs_mmc(id, pdata) \ | ||
42 | mxs_add_mxs_mmc(&mx28_mxs_mmc_data[id], pdata) | ||
43 | |||
44 | #define mx28_add_mxs_pwm(id) mxs_add_mxs_pwm(MX28_PWM_BASE_ADDR, id) | ||
45 | |||
46 | struct platform_device *__init mx28_add_mxsfb( | ||
47 | const struct mxsfb_platform_data *pdata); | ||
diff --git a/arch/arm/mach-mxs/devices.c b/arch/arm/mach-mxs/devices.c new file mode 100644 index 00000000000..fe3e847930c --- /dev/null +++ b/arch/arm/mach-mxs/devices.c | |||
@@ -0,0 +1,101 @@ | |||
1 | /* | ||
2 | * Copyright 2008 Sascha Hauer, kernel@pengutronix.de | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or | ||
5 | * modify it under the terms of the GNU General Public License | ||
6 | * as published by the Free Software Foundation; either version 2 | ||
7 | * of the License, or (at your option) any later version. | ||
8 | * This program is distributed in the hope that it will be useful, | ||
9 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
10 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
11 | * GNU General Public License for more details. | ||
12 | * | ||
13 | * You should have received a copy of the GNU General Public License | ||
14 | * along with this program; if not, write to the Free Software | ||
15 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, | ||
16 | * Boston, MA 02110-1301, USA. | ||
17 | */ | ||
18 | |||
19 | #include <linux/kernel.h> | ||
20 | #include <linux/slab.h> | ||
21 | #include <linux/init.h> | ||
22 | #include <linux/platform_device.h> | ||
23 | #include <linux/amba/bus.h> | ||
24 | |||
25 | struct platform_device *__init mxs_add_platform_device_dmamask( | ||
26 | const char *name, int id, | ||
27 | const struct resource *res, unsigned int num_resources, | ||
28 | const void *data, size_t size_data, u64 dmamask) | ||
29 | { | ||
30 | int ret = -ENOMEM; | ||
31 | struct platform_device *pdev; | ||
32 | |||
33 | pdev = platform_device_alloc(name, id); | ||
34 | if (!pdev) | ||
35 | goto err; | ||
36 | |||
37 | if (dmamask) { | ||
38 | /* | ||
39 | * This memory isn't freed when the device is put, | ||
40 | * I don't have a nice idea for that though. Conceptually | ||
41 | * dma_mask in struct device should not be a pointer. | ||
42 | * See http://thread.gmane.org/gmane.linux.kernel.pci/9081 | ||
43 | */ | ||
44 | pdev->dev.dma_mask = | ||
45 | kmalloc(sizeof(*pdev->dev.dma_mask), GFP_KERNEL); | ||
46 | if (!pdev->dev.dma_mask) | ||
47 | /* ret is still -ENOMEM; */ | ||
48 | goto err; | ||
49 | |||
50 | *pdev->dev.dma_mask = dmamask; | ||
51 | pdev->dev.coherent_dma_mask = dmamask; | ||
52 | } | ||
53 | |||
54 | if (res) { | ||
55 | ret = platform_device_add_resources(pdev, res, num_resources); | ||
56 | if (ret) | ||
57 | goto err; | ||
58 | } | ||
59 | |||
60 | if (data) { | ||
61 | ret = platform_device_add_data(pdev, data, size_data); | ||
62 | if (ret) | ||
63 | goto err; | ||
64 | } | ||
65 | |||
66 | ret = platform_device_add(pdev); | ||
67 | if (ret) { | ||
68 | err: | ||
69 | if (dmamask) | ||
70 | kfree(pdev->dev.dma_mask); | ||
71 | platform_device_put(pdev); | ||
72 | return ERR_PTR(ret); | ||
73 | } | ||
74 | |||
75 | return pdev; | ||
76 | } | ||
77 | |||
78 | int __init mxs_add_amba_device(const struct amba_device *dev) | ||
79 | { | ||
80 | struct amba_device *adev = kmalloc(sizeof(*adev), GFP_KERNEL); | ||
81 | |||
82 | if (!adev) { | ||
83 | pr_err("%s: failed to allocate memory", __func__); | ||
84 | return -ENOMEM; | ||
85 | } | ||
86 | |||
87 | *adev = *dev; | ||
88 | |||
89 | return amba_device_register(adev, &iomem_resource); | ||
90 | } | ||
91 | |||
92 | struct device mxs_apbh_bus = { | ||
93 | .init_name = "mxs_apbh", | ||
94 | .parent = &platform_bus, | ||
95 | }; | ||
96 | |||
97 | static int __init mxs_device_init(void) | ||
98 | { | ||
99 | return device_register(&mxs_apbh_bus); | ||
100 | } | ||
101 | core_initcall(mxs_device_init); | ||
diff --git a/arch/arm/mach-mxs/devices/Kconfig b/arch/arm/mach-mxs/devices/Kconfig new file mode 100644 index 00000000000..acf9eea124c --- /dev/null +++ b/arch/arm/mach-mxs/devices/Kconfig | |||
@@ -0,0 +1,25 @@ | |||
1 | config MXS_HAVE_AMBA_DUART | ||
2 | bool | ||
3 | select ARM_AMBA | ||
4 | |||
5 | config MXS_HAVE_PLATFORM_AUART | ||
6 | bool | ||
7 | |||
8 | config MXS_HAVE_PLATFORM_FEC | ||
9 | bool | ||
10 | |||
11 | config MXS_HAVE_PLATFORM_FLEXCAN | ||
12 | select HAVE_CAN_FLEXCAN if CAN | ||
13 | bool | ||
14 | |||
15 | config MXS_HAVE_PLATFORM_MXS_I2C | ||
16 | bool | ||
17 | |||
18 | config MXS_HAVE_PLATFORM_MXS_MMC | ||
19 | bool | ||
20 | |||
21 | config MXS_HAVE_PLATFORM_MXS_PWM | ||
22 | bool | ||
23 | |||
24 | config MXS_HAVE_PLATFORM_MXSFB | ||
25 | bool | ||
diff --git a/arch/arm/mach-mxs/devices/Makefile b/arch/arm/mach-mxs/devices/Makefile new file mode 100644 index 00000000000..351915c683f --- /dev/null +++ b/arch/arm/mach-mxs/devices/Makefile | |||
@@ -0,0 +1,10 @@ | |||
1 | obj-$(CONFIG_MXS_HAVE_AMBA_DUART) += amba-duart.o | ||
2 | obj-$(CONFIG_MXS_HAVE_PLATFORM_AUART) += platform-auart.o | ||
3 | obj-y += platform-dma.o | ||
4 | obj-$(CONFIG_MXS_HAVE_PLATFORM_FEC) += platform-fec.o | ||
5 | obj-$(CONFIG_MXS_HAVE_PLATFORM_FLEXCAN) += platform-flexcan.o | ||
6 | obj-$(CONFIG_MXS_HAVE_PLATFORM_MXS_I2C) += platform-mxs-i2c.o | ||
7 | obj-$(CONFIG_MXS_HAVE_PLATFORM_MXS_MMC) += platform-mxs-mmc.o | ||
8 | obj-$(CONFIG_MXS_HAVE_PLATFORM_MXS_PWM) += platform-mxs-pwm.o | ||
9 | obj-y += platform-gpio-mxs.o | ||
10 | obj-$(CONFIG_MXS_HAVE_PLATFORM_MXSFB) += platform-mxsfb.o | ||
diff --git a/arch/arm/mach-mxs/devices/amba-duart.c b/arch/arm/mach-mxs/devices/amba-duart.c new file mode 100644 index 00000000000..a559db09b49 --- /dev/null +++ b/arch/arm/mach-mxs/devices/amba-duart.c | |||
@@ -0,0 +1,40 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2009-2010 Pengutronix | ||
3 | * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de> | ||
4 | * | ||
5 | * Copyright 2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify it under | ||
8 | * the terms of the GNU General Public License version 2 as published by the | ||
9 | * Free Software Foundation. | ||
10 | */ | ||
11 | #include <asm/irq.h> | ||
12 | #include <mach/mx23.h> | ||
13 | #include <mach/mx28.h> | ||
14 | #include <mach/devices-common.h> | ||
15 | |||
16 | #define MXS_AMBA_DUART_DEVICE(name, soc) \ | ||
17 | const struct amba_device name##_device __initconst = { \ | ||
18 | .dev = { \ | ||
19 | .init_name = "duart", \ | ||
20 | }, \ | ||
21 | .res = { \ | ||
22 | .start = soc ## _DUART_BASE_ADDR, \ | ||
23 | .end = (soc ## _DUART_BASE_ADDR) + SZ_8K - 1, \ | ||
24 | .flags = IORESOURCE_MEM, \ | ||
25 | }, \ | ||
26 | .irq = {soc ## _INT_DUART, NO_IRQ}, \ | ||
27 | } | ||
28 | |||
29 | #ifdef CONFIG_SOC_IMX23 | ||
30 | MXS_AMBA_DUART_DEVICE(mx23_duart, MX23); | ||
31 | #endif | ||
32 | |||
33 | #ifdef CONFIG_SOC_IMX28 | ||
34 | MXS_AMBA_DUART_DEVICE(mx28_duart, MX28); | ||
35 | #endif | ||
36 | |||
37 | int __init mxs_add_duart(const struct amba_device *dev) | ||
38 | { | ||
39 | return mxs_add_amba_device(dev); | ||
40 | } | ||
diff --git a/arch/arm/mach-mxs/devices/platform-auart.c b/arch/arm/mach-mxs/devices/platform-auart.c new file mode 100644 index 00000000000..27608f5d2ac --- /dev/null +++ b/arch/arm/mach-mxs/devices/platform-auart.c | |||
@@ -0,0 +1,65 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2010 Pengutronix | ||
3 | * Sascha Hauer <s.hauer@pengutronix.de> | ||
4 | * | ||
5 | * This program is free software; you can redistribute it and/or modify it under | ||
6 | * the terms of the GNU General Public License version 2 as published by the | ||
7 | * Free Software Foundation. | ||
8 | */ | ||
9 | #include <linux/dma-mapping.h> | ||
10 | #include <asm/sizes.h> | ||
11 | #include <mach/mx23.h> | ||
12 | #include <mach/mx28.h> | ||
13 | #include <mach/devices-common.h> | ||
14 | |||
15 | #define mxs_auart_data_entry_single(soc, _id, hwid) \ | ||
16 | { \ | ||
17 | .id = _id, \ | ||
18 | .iobase = soc ## _AUART ## hwid ## _BASE_ADDR, \ | ||
19 | .irq = soc ## _INT_AUART ## hwid, \ | ||
20 | } | ||
21 | |||
22 | #define mxs_auart_data_entry(soc, _id, hwid) \ | ||
23 | [_id] = mxs_auart_data_entry_single(soc, _id, hwid) | ||
24 | |||
25 | #ifdef CONFIG_SOC_IMX23 | ||
26 | const struct mxs_auart_data mx23_auart_data[] __initconst = { | ||
27 | #define mx23_auart_data_entry(_id, hwid) \ | ||
28 | mxs_auart_data_entry(MX23, _id, hwid) | ||
29 | mx23_auart_data_entry(0, 1), | ||
30 | mx23_auart_data_entry(1, 2), | ||
31 | }; | ||
32 | #endif | ||
33 | |||
34 | #ifdef CONFIG_SOC_IMX28 | ||
35 | const struct mxs_auart_data mx28_auart_data[] __initconst = { | ||
36 | #define mx28_auart_data_entry(_id) \ | ||
37 | mxs_auart_data_entry(MX28, _id, _id) | ||
38 | mx28_auart_data_entry(0), | ||
39 | mx28_auart_data_entry(1), | ||
40 | mx28_auart_data_entry(2), | ||
41 | mx28_auart_data_entry(3), | ||
42 | mx28_auart_data_entry(4), | ||
43 | }; | ||
44 | #endif | ||
45 | |||
46 | struct platform_device *__init mxs_add_auart( | ||
47 | const struct mxs_auart_data *data) | ||
48 | { | ||
49 | struct resource res[] = { | ||
50 | { | ||
51 | .start = data->iobase, | ||
52 | .end = data->iobase + SZ_8K - 1, | ||
53 | .flags = IORESOURCE_MEM, | ||
54 | }, { | ||
55 | .start = data->irq, | ||
56 | .end = data->irq, | ||
57 | .flags = IORESOURCE_IRQ, | ||
58 | }, | ||
59 | }; | ||
60 | |||
61 | return mxs_add_platform_device_dmamask("mxs-auart", data->id, | ||
62 | res, ARRAY_SIZE(res), NULL, 0, | ||
63 | DMA_BIT_MASK(32)); | ||
64 | } | ||
65 | |||
diff --git a/arch/arm/mach-mxs/devices/platform-dma.c b/arch/arm/mach-mxs/devices/platform-dma.c new file mode 100644 index 00000000000..6a0202b1016 --- /dev/null +++ b/arch/arm/mach-mxs/devices/platform-dma.c | |||
@@ -0,0 +1,50 @@ | |||
1 | /* | ||
2 | * Copyright 2011 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or modify it under | ||
5 | * the terms of the GNU General Public License version 2 as published by the | ||
6 | * Free Software Foundation. | ||
7 | */ | ||
8 | #include <linux/compiler.h> | ||
9 | #include <linux/dma-mapping.h> | ||
10 | #include <linux/err.h> | ||
11 | #include <linux/init.h> | ||
12 | |||
13 | #include <mach/mx23.h> | ||
14 | #include <mach/mx28.h> | ||
15 | #include <mach/devices-common.h> | ||
16 | |||
17 | static struct platform_device *__init mxs_add_dma(const char *devid, | ||
18 | resource_size_t base) | ||
19 | { | ||
20 | struct resource res[] = { | ||
21 | { | ||
22 | .start = base, | ||
23 | .end = base + SZ_8K - 1, | ||
24 | .flags = IORESOURCE_MEM, | ||
25 | } | ||
26 | }; | ||
27 | |||
28 | return mxs_add_platform_device_dmamask(devid, -1, | ||
29 | res, ARRAY_SIZE(res), NULL, 0, | ||
30 | DMA_BIT_MASK(32)); | ||
31 | } | ||
32 | |||
33 | static int __init mxs_add_mxs_dma(void) | ||
34 | { | ||
35 | char *apbh = "mxs-dma-apbh"; | ||
36 | char *apbx = "mxs-dma-apbx"; | ||
37 | |||
38 | if (cpu_is_mx23()) { | ||
39 | mxs_add_dma(apbh, MX23_APBH_DMA_BASE_ADDR); | ||
40 | mxs_add_dma(apbx, MX23_APBX_DMA_BASE_ADDR); | ||
41 | } | ||
42 | |||
43 | if (cpu_is_mx28()) { | ||
44 | mxs_add_dma(apbh, MX28_APBH_DMA_BASE_ADDR); | ||
45 | mxs_add_dma(apbx, MX28_APBX_DMA_BASE_ADDR); | ||
46 | } | ||
47 | |||
48 | return 0; | ||
49 | } | ||
50 | arch_initcall(mxs_add_mxs_dma); | ||
diff --git a/arch/arm/mach-mxs/devices/platform-fec.c b/arch/arm/mach-mxs/devices/platform-fec.c new file mode 100644 index 00000000000..ae96a4fd8f1 --- /dev/null +++ b/arch/arm/mach-mxs/devices/platform-fec.c | |||
@@ -0,0 +1,52 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2010 Pengutronix | ||
3 | * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de> | ||
4 | * | ||
5 | * This program is free software; you can redistribute it and/or modify it under | ||
6 | * the terms of the GNU General Public License version 2 as published by the | ||
7 | * Free Software Foundation. | ||
8 | */ | ||
9 | #include <linux/dma-mapping.h> | ||
10 | #include <asm/sizes.h> | ||
11 | #include <mach/mx28.h> | ||
12 | #include <mach/devices-common.h> | ||
13 | |||
14 | #define mxs_fec_data_entry_single(soc, _id) \ | ||
15 | { \ | ||
16 | .id = _id, \ | ||
17 | .iobase = soc ## _ENET_MAC ## _id ## _BASE_ADDR, \ | ||
18 | .irq = soc ## _INT_ENET_MAC ## _id, \ | ||
19 | } | ||
20 | |||
21 | #define mxs_fec_data_entry(soc, _id) \ | ||
22 | [_id] = mxs_fec_data_entry_single(soc, _id) | ||
23 | |||
24 | #ifdef CONFIG_SOC_IMX28 | ||
25 | const struct mxs_fec_data mx28_fec_data[] __initconst = { | ||
26 | #define mx28_fec_data_entry(_id) \ | ||
27 | mxs_fec_data_entry(MX28, _id) | ||
28 | mx28_fec_data_entry(0), | ||
29 | mx28_fec_data_entry(1), | ||
30 | }; | ||
31 | #endif | ||
32 | |||
33 | struct platform_device *__init mxs_add_fec( | ||
34 | const struct mxs_fec_data *data, | ||
35 | const struct fec_platform_data *pdata) | ||
36 | { | ||
37 | struct resource res[] = { | ||
38 | { | ||
39 | .start = data->iobase, | ||
40 | .end = data->iobase + SZ_16K - 1, | ||
41 | .flags = IORESOURCE_MEM, | ||
42 | }, { | ||
43 | .start = data->irq, | ||
44 | .end = data->irq, | ||
45 | .flags = IORESOURCE_IRQ, | ||
46 | }, | ||
47 | }; | ||
48 | |||
49 | return mxs_add_platform_device_dmamask("imx28-fec", data->id, | ||
50 | res, ARRAY_SIZE(res), pdata, sizeof(*pdata), | ||
51 | DMA_BIT_MASK(32)); | ||
52 | } | ||
diff --git a/arch/arm/mach-mxs/devices/platform-flexcan.c b/arch/arm/mach-mxs/devices/platform-flexcan.c new file mode 100644 index 00000000000..43a6b4bae6f --- /dev/null +++ b/arch/arm/mach-mxs/devices/platform-flexcan.c | |||
@@ -0,0 +1,51 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2010, 2011 Pengutronix, | ||
3 | * Marc Kleine-Budde <kernel@pengutronix.de> | ||
4 | * | ||
5 | * This program is free software; you can redistribute it and/or modify it under | ||
6 | * the terms of the GNU General Public License version 2 as published by the | ||
7 | * Free Software Foundation. | ||
8 | */ | ||
9 | #include <asm/sizes.h> | ||
10 | #include <mach/mx28.h> | ||
11 | #include <mach/devices-common.h> | ||
12 | |||
13 | #define mxs_flexcan_data_entry_single(soc, _id, _hwid, _size) \ | ||
14 | { \ | ||
15 | .id = _id, \ | ||
16 | .iobase = soc ## _CAN ## _hwid ## _BASE_ADDR, \ | ||
17 | .iosize = _size, \ | ||
18 | .irq = soc ## _INT_CAN ## _hwid, \ | ||
19 | } | ||
20 | |||
21 | #define mxs_flexcan_data_entry(soc, _id, _hwid, _size) \ | ||
22 | [_id] = mxs_flexcan_data_entry_single(soc, _id, _hwid, _size) | ||
23 | |||
24 | #ifdef CONFIG_SOC_IMX28 | ||
25 | const struct mxs_flexcan_data mx28_flexcan_data[] __initconst = { | ||
26 | #define mx28_flexcan_data_entry(_id, _hwid) \ | ||
27 | mxs_flexcan_data_entry_single(MX28, _id, _hwid, SZ_8K) | ||
28 | mx28_flexcan_data_entry(0, 0), | ||
29 | mx28_flexcan_data_entry(1, 1), | ||
30 | }; | ||
31 | #endif /* ifdef CONFIG_SOC_IMX28 */ | ||
32 | |||
33 | struct platform_device *__init mxs_add_flexcan( | ||
34 | const struct mxs_flexcan_data *data, | ||
35 | const struct flexcan_platform_data *pdata) | ||
36 | { | ||
37 | struct resource res[] = { | ||
38 | { | ||
39 | .start = data->iobase, | ||
40 | .end = data->iobase + data->iosize - 1, | ||
41 | .flags = IORESOURCE_MEM, | ||
42 | }, { | ||
43 | .start = data->irq, | ||
44 | .end = data->irq, | ||
45 | .flags = IORESOURCE_IRQ, | ||
46 | }, | ||
47 | }; | ||
48 | |||
49 | return mxs_add_platform_device("flexcan", data->id, | ||
50 | res, ARRAY_SIZE(res), pdata, sizeof(*pdata)); | ||
51 | } | ||
diff --git a/arch/arm/mach-mxs/devices/platform-gpio-mxs.c b/arch/arm/mach-mxs/devices/platform-gpio-mxs.c new file mode 100644 index 00000000000..ed0885e414e --- /dev/null +++ b/arch/arm/mach-mxs/devices/platform-gpio-mxs.c | |||
@@ -0,0 +1,53 @@ | |||
1 | /* | ||
2 | * Copyright 2011 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or modify it under | ||
5 | * the terms of the GNU General Public License version 2 as published by the | ||
6 | * Free Software Foundation. | ||
7 | */ | ||
8 | #include <linux/compiler.h> | ||
9 | #include <linux/err.h> | ||
10 | #include <linux/init.h> | ||
11 | |||
12 | #include <mach/mx23.h> | ||
13 | #include <mach/mx28.h> | ||
14 | #include <mach/devices-common.h> | ||
15 | |||
16 | struct platform_device *__init mxs_add_gpio( | ||
17 | int id, resource_size_t iobase, int irq) | ||
18 | { | ||
19 | struct resource res[] = { | ||
20 | { | ||
21 | .start = iobase, | ||
22 | .end = iobase + SZ_8K - 1, | ||
23 | .flags = IORESOURCE_MEM, | ||
24 | }, { | ||
25 | .start = irq, | ||
26 | .end = irq, | ||
27 | .flags = IORESOURCE_IRQ, | ||
28 | }, | ||
29 | }; | ||
30 | |||
31 | return platform_device_register_resndata(&mxs_apbh_bus, | ||
32 | "gpio-mxs", id, res, ARRAY_SIZE(res), NULL, 0); | ||
33 | } | ||
34 | |||
35 | static int __init mxs_add_mxs_gpio(void) | ||
36 | { | ||
37 | if (cpu_is_mx23()) { | ||
38 | mxs_add_gpio(0, MX23_PINCTRL_BASE_ADDR, MX23_INT_GPIO0); | ||
39 | mxs_add_gpio(1, MX23_PINCTRL_BASE_ADDR, MX23_INT_GPIO1); | ||
40 | mxs_add_gpio(2, MX23_PINCTRL_BASE_ADDR, MX23_INT_GPIO2); | ||
41 | } | ||
42 | |||
43 | if (cpu_is_mx28()) { | ||
44 | mxs_add_gpio(0, MX28_PINCTRL_BASE_ADDR, MX28_INT_GPIO0); | ||
45 | mxs_add_gpio(1, MX28_PINCTRL_BASE_ADDR, MX28_INT_GPIO1); | ||
46 | mxs_add_gpio(2, MX28_PINCTRL_BASE_ADDR, MX28_INT_GPIO2); | ||
47 | mxs_add_gpio(3, MX28_PINCTRL_BASE_ADDR, MX28_INT_GPIO3); | ||
48 | mxs_add_gpio(4, MX28_PINCTRL_BASE_ADDR, MX28_INT_GPIO4); | ||
49 | } | ||
50 | |||
51 | return 0; | ||
52 | } | ||
53 | postcore_initcall(mxs_add_mxs_gpio); | ||
diff --git a/arch/arm/mach-mxs/devices/platform-mxs-i2c.c b/arch/arm/mach-mxs/devices/platform-mxs-i2c.c new file mode 100644 index 00000000000..79222ec8ede --- /dev/null +++ b/arch/arm/mach-mxs/devices/platform-mxs-i2c.c | |||
@@ -0,0 +1,52 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2011 Pengutronix | ||
3 | * Wolfram Sang <w.sang@pengutronix.de> | ||
4 | * | ||
5 | * This program is free software; you can redistribute it and/or modify it under | ||
6 | * the terms of the GNU General Public License version 2 as published by the | ||
7 | * Free Software Foundation. | ||
8 | */ | ||
9 | #include <asm/sizes.h> | ||
10 | #include <mach/mx28.h> | ||
11 | #include <mach/devices-common.h> | ||
12 | |||
13 | #define mxs_i2c_data_entry_single(soc, _id) \ | ||
14 | { \ | ||
15 | .id = _id, \ | ||
16 | .iobase = soc ## _I2C ## _id ## _BASE_ADDR, \ | ||
17 | .errirq = soc ## _INT_I2C ## _id ## _ERROR, \ | ||
18 | .dmairq = soc ## _INT_I2C ## _id ## _DMA, \ | ||
19 | } | ||
20 | |||
21 | #define mxs_i2c_data_entry(soc, _id) \ | ||
22 | [_id] = mxs_i2c_data_entry_single(soc, _id) | ||
23 | |||
24 | #ifdef CONFIG_SOC_IMX28 | ||
25 | const struct mxs_mxs_i2c_data mx28_mxs_i2c_data[] __initconst = { | ||
26 | mxs_i2c_data_entry(MX28, 0), | ||
27 | mxs_i2c_data_entry(MX28, 1), | ||
28 | }; | ||
29 | #endif | ||
30 | |||
31 | struct platform_device *__init mxs_add_mxs_i2c( | ||
32 | const struct mxs_mxs_i2c_data *data) | ||
33 | { | ||
34 | struct resource res[] = { | ||
35 | { | ||
36 | .start = data->iobase, | ||
37 | .end = data->iobase + SZ_8K - 1, | ||
38 | .flags = IORESOURCE_MEM, | ||
39 | }, { | ||
40 | .start = data->errirq, | ||
41 | .end = data->errirq, | ||
42 | .flags = IORESOURCE_IRQ, | ||
43 | }, { | ||
44 | .start = data->dmairq, | ||
45 | .end = data->dmairq, | ||
46 | .flags = IORESOURCE_IRQ, | ||
47 | }, | ||
48 | }; | ||
49 | |||
50 | return mxs_add_platform_device("mxs-i2c", data->id, res, | ||
51 | ARRAY_SIZE(res), NULL, 0); | ||
52 | } | ||
diff --git a/arch/arm/mach-mxs/devices/platform-mxs-mmc.c b/arch/arm/mach-mxs/devices/platform-mxs-mmc.c new file mode 100644 index 00000000000..382dacbeca2 --- /dev/null +++ b/arch/arm/mach-mxs/devices/platform-mxs-mmc.c | |||
@@ -0,0 +1,73 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2010 Pengutronix | ||
3 | * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de> | ||
4 | * | ||
5 | * Copyright 2011 Freescale Semiconductor, Inc. All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify it under | ||
8 | * the terms of the GNU General Public License version 2 as published by the | ||
9 | * Free Software Foundation. | ||
10 | */ | ||
11 | |||
12 | #include <linux/compiler.h> | ||
13 | #include <linux/err.h> | ||
14 | #include <linux/init.h> | ||
15 | |||
16 | #include <mach/mx23.h> | ||
17 | #include <mach/mx28.h> | ||
18 | #include <mach/devices-common.h> | ||
19 | |||
20 | #define mxs_mxs_mmc_data_entry_single(soc, _id, hwid) \ | ||
21 | { \ | ||
22 | .id = _id, \ | ||
23 | .iobase = soc ## _SSP ## hwid ## _BASE_ADDR, \ | ||
24 | .dma = soc ## _DMA_SSP ## hwid, \ | ||
25 | .irq_err = soc ## _INT_SSP ## hwid ## _ERROR, \ | ||
26 | .irq_dma = soc ## _INT_SSP ## hwid ## _DMA, \ | ||
27 | } | ||
28 | |||
29 | #define mxs_mxs_mmc_data_entry(soc, _id, hwid) \ | ||
30 | [_id] = mxs_mxs_mmc_data_entry_single(soc, _id, hwid) | ||
31 | |||
32 | |||
33 | #ifdef CONFIG_SOC_IMX23 | ||
34 | const struct mxs_mxs_mmc_data mx23_mxs_mmc_data[] __initconst = { | ||
35 | mxs_mxs_mmc_data_entry(MX23, 0, 1), | ||
36 | mxs_mxs_mmc_data_entry(MX23, 1, 2), | ||
37 | }; | ||
38 | #endif | ||
39 | |||
40 | #ifdef CONFIG_SOC_IMX28 | ||
41 | const struct mxs_mxs_mmc_data mx28_mxs_mmc_data[] __initconst = { | ||
42 | mxs_mxs_mmc_data_entry(MX28, 0, 0), | ||
43 | mxs_mxs_mmc_data_entry(MX28, 1, 1), | ||
44 | }; | ||
45 | #endif | ||
46 | |||
47 | struct platform_device *__init mxs_add_mxs_mmc( | ||
48 | const struct mxs_mxs_mmc_data *data, | ||
49 | const struct mxs_mmc_platform_data *pdata) | ||
50 | { | ||
51 | struct resource res[] = { | ||
52 | { | ||
53 | .start = data->iobase, | ||
54 | .end = data->iobase + SZ_8K - 1, | ||
55 | .flags = IORESOURCE_MEM, | ||
56 | }, { | ||
57 | .start = data->dma, | ||
58 | .end = data->dma, | ||
59 | .flags = IORESOURCE_DMA, | ||
60 | }, { | ||
61 | .start = data->irq_err, | ||
62 | .end = data->irq_err, | ||
63 | .flags = IORESOURCE_IRQ, | ||
64 | }, { | ||
65 | .start = data->irq_dma, | ||
66 | .end = data->irq_dma, | ||
67 | .flags = IORESOURCE_IRQ, | ||
68 | }, | ||
69 | }; | ||
70 | |||
71 | return mxs_add_platform_device("mxs-mmc", data->id, | ||
72 | res, ARRAY_SIZE(res), pdata, sizeof(*pdata)); | ||
73 | } | ||
diff --git a/arch/arm/mach-mxs/devices/platform-mxs-pwm.c b/arch/arm/mach-mxs/devices/platform-mxs-pwm.c new file mode 100644 index 00000000000..680f5a90293 --- /dev/null +++ b/arch/arm/mach-mxs/devices/platform-mxs-pwm.c | |||
@@ -0,0 +1,22 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2010 Pengutronix | ||
3 | * Sascha Hauer <s.hauer@pengutronix.de> | ||
4 | * | ||
5 | * This program is free software; you can redistribute it and/or modify it under | ||
6 | * the terms of the GNU General Public License version 2 as published by the | ||
7 | * Free Software Foundation. | ||
8 | */ | ||
9 | #include <asm/sizes.h> | ||
10 | #include <mach/devices-common.h> | ||
11 | |||
12 | struct platform_device *__init mxs_add_mxs_pwm(resource_size_t iobase, int id) | ||
13 | { | ||
14 | struct resource res = { | ||
15 | .flags = IORESOURCE_MEM, | ||
16 | }; | ||
17 | |||
18 | res.start = iobase + 0x10 + 0x20 * id; | ||
19 | res.end = res.start + 0x1f; | ||
20 | |||
21 | return mxs_add_platform_device("mxs-pwm", id, &res, 1, NULL, 0); | ||
22 | } | ||
diff --git a/arch/arm/mach-mxs/devices/platform-mxsfb.c b/arch/arm/mach-mxs/devices/platform-mxsfb.c new file mode 100644 index 00000000000..5a75b7180f7 --- /dev/null +++ b/arch/arm/mach-mxs/devices/platform-mxsfb.c | |||
@@ -0,0 +1,47 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2011 Pengutronix, Sascha Hauer <s.hauer@pengutronix.de> | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or modify it under | ||
5 | * the terms of the GNU General Public License version 2 as published by the | ||
6 | * Free Software Foundation. | ||
7 | */ | ||
8 | #include <linux/dma-mapping.h> | ||
9 | #include <asm/sizes.h> | ||
10 | #include <mach/mx23.h> | ||
11 | #include <mach/mx28.h> | ||
12 | #include <mach/devices-common.h> | ||
13 | #include <mach/mxsfb.h> | ||
14 | |||
15 | #ifdef CONFIG_SOC_IMX23 | ||
16 | struct platform_device *__init mx23_add_mxsfb( | ||
17 | const struct mxsfb_platform_data *pdata) | ||
18 | { | ||
19 | struct resource res[] = { | ||
20 | { | ||
21 | .start = MX23_LCDIF_BASE_ADDR, | ||
22 | .end = MX23_LCDIF_BASE_ADDR + SZ_8K - 1, | ||
23 | .flags = IORESOURCE_MEM, | ||
24 | }, | ||
25 | }; | ||
26 | |||
27 | return mxs_add_platform_device_dmamask("imx23-fb", -1, | ||
28 | res, ARRAY_SIZE(res), pdata, sizeof(*pdata), DMA_BIT_MASK(32)); | ||
29 | } | ||
30 | #endif /* ifdef CONFIG_SOC_IMX23 */ | ||
31 | |||
32 | #ifdef CONFIG_SOC_IMX28 | ||
33 | struct platform_device *__init mx28_add_mxsfb( | ||
34 | const struct mxsfb_platform_data *pdata) | ||
35 | { | ||
36 | struct resource res[] = { | ||
37 | { | ||
38 | .start = MX28_LCDIF_BASE_ADDR, | ||
39 | .end = MX28_LCDIF_BASE_ADDR + SZ_8K - 1, | ||
40 | .flags = IORESOURCE_MEM, | ||
41 | }, | ||
42 | }; | ||
43 | |||
44 | return mxs_add_platform_device_dmamask("imx28-fb", -1, | ||
45 | res, ARRAY_SIZE(res), pdata, sizeof(*pdata), DMA_BIT_MASK(32)); | ||
46 | } | ||
47 | #endif /* ifdef CONFIG_SOC_IMX28 */ | ||
diff --git a/arch/arm/mach-mxs/include/mach/clock.h b/arch/arm/mach-mxs/include/mach/clock.h new file mode 100644 index 00000000000..592c9ab5d76 --- /dev/null +++ b/arch/arm/mach-mxs/include/mach/clock.h | |||
@@ -0,0 +1,62 @@ | |||
1 | /* | ||
2 | * Copyright 2005-2007 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | * Copyright 2008 Juergen Beisert, kernel@pengutronix.de | ||
4 | * | ||
5 | * This program is free software; you can redistribute it and/or | ||
6 | * modify it under the terms of the GNU General Public License | ||
7 | * as published by the Free Software Foundation; either version 2 | ||
8 | * of the License, or (at your option) any later version. | ||
9 | * This program is distributed in the hope that it will be useful, | ||
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
12 | * GNU General Public License for more details. | ||
13 | * | ||
14 | * You should have received a copy of the GNU General Public License | ||
15 | * along with this program; if not, write to the Free Software | ||
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, | ||
17 | * MA 02110-1301, USA. | ||
18 | */ | ||
19 | |||
20 | #ifndef __MACH_MXS_CLOCK_H__ | ||
21 | #define __MACH_MXS_CLOCK_H__ | ||
22 | |||
23 | #ifndef __ASSEMBLY__ | ||
24 | #include <linux/list.h> | ||
25 | |||
26 | struct module; | ||
27 | |||
28 | struct clk { | ||
29 | int id; | ||
30 | /* Source clock this clk depends on */ | ||
31 | struct clk *parent; | ||
32 | /* Reference count of clock enable/disable */ | ||
33 | __s8 usecount; | ||
34 | /* Register bit position for clock's enable/disable control. */ | ||
35 | u8 enable_shift; | ||
36 | /* Register address for clock's enable/disable control. */ | ||
37 | void __iomem *enable_reg; | ||
38 | u32 flags; | ||
39 | /* get the current clock rate (always a fresh value) */ | ||
40 | unsigned long (*get_rate) (struct clk *); | ||
41 | /* Function ptr to set the clock to a new rate. The rate must match a | ||
42 | supported rate returned from round_rate. Leave blank if clock is not | ||
43 | programmable */ | ||
44 | int (*set_rate) (struct clk *, unsigned long); | ||
45 | /* Function ptr to round the requested clock rate to the nearest | ||
46 | supported rate that is less than or equal to the requested rate. */ | ||
47 | unsigned long (*round_rate) (struct clk *, unsigned long); | ||
48 | /* Function ptr to enable the clock. Leave blank if clock can not | ||
49 | be gated. */ | ||
50 | int (*enable) (struct clk *); | ||
51 | /* Function ptr to disable the clock. Leave blank if clock can not | ||
52 | be gated. */ | ||
53 | void (*disable) (struct clk *); | ||
54 | /* Function ptr to set the parent clock of the clock. */ | ||
55 | int (*set_parent) (struct clk *, struct clk *); | ||
56 | }; | ||
57 | |||
58 | int clk_register(struct clk *clk); | ||
59 | void clk_unregister(struct clk *clk); | ||
60 | |||
61 | #endif /* __ASSEMBLY__ */ | ||
62 | #endif /* __MACH_MXS_CLOCK_H__ */ | ||
diff --git a/arch/arm/mach-mxs/include/mach/devices-common.h b/arch/arm/mach-mxs/include/mach/devices-common.h new file mode 100644 index 00000000000..812d7a813a7 --- /dev/null +++ b/arch/arm/mach-mxs/include/mach/devices-common.h | |||
@@ -0,0 +1,94 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2009-2010 Pengutronix | ||
3 | * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de> | ||
4 | * | ||
5 | * This program is free software; you can redistribute it and/or modify it under | ||
6 | * the terms of the GNU General Public License version 2 as published by the | ||
7 | * Free Software Foundation. | ||
8 | */ | ||
9 | #include <linux/kernel.h> | ||
10 | #include <linux/platform_device.h> | ||
11 | #include <linux/init.h> | ||
12 | #include <linux/amba/bus.h> | ||
13 | |||
14 | extern struct device mxs_apbh_bus; | ||
15 | |||
16 | struct platform_device *mxs_add_platform_device_dmamask( | ||
17 | const char *name, int id, | ||
18 | const struct resource *res, unsigned int num_resources, | ||
19 | const void *data, size_t size_data, u64 dmamask); | ||
20 | |||
21 | static inline struct platform_device *mxs_add_platform_device( | ||
22 | const char *name, int id, | ||
23 | const struct resource *res, unsigned int num_resources, | ||
24 | const void *data, size_t size_data) | ||
25 | { | ||
26 | return mxs_add_platform_device_dmamask( | ||
27 | name, id, res, num_resources, data, size_data, 0); | ||
28 | } | ||
29 | |||
30 | int __init mxs_add_amba_device(const struct amba_device *dev); | ||
31 | |||
32 | /* duart */ | ||
33 | int __init mxs_add_duart(const struct amba_device *dev); | ||
34 | |||
35 | /* auart */ | ||
36 | struct mxs_auart_data { | ||
37 | int id; | ||
38 | resource_size_t iobase; | ||
39 | resource_size_t iosize; | ||
40 | resource_size_t irq; | ||
41 | }; | ||
42 | struct platform_device *__init mxs_add_auart( | ||
43 | const struct mxs_auart_data *data); | ||
44 | |||
45 | /* fec */ | ||
46 | #include <linux/fec.h> | ||
47 | struct mxs_fec_data { | ||
48 | int id; | ||
49 | resource_size_t iobase; | ||
50 | resource_size_t iosize; | ||
51 | resource_size_t irq; | ||
52 | }; | ||
53 | struct platform_device *__init mxs_add_fec( | ||
54 | const struct mxs_fec_data *data, | ||
55 | const struct fec_platform_data *pdata); | ||
56 | |||
57 | /* flexcan */ | ||
58 | #include <linux/can/platform/flexcan.h> | ||
59 | struct mxs_flexcan_data { | ||
60 | int id; | ||
61 | resource_size_t iobase; | ||
62 | resource_size_t iosize; | ||
63 | resource_size_t irq; | ||
64 | }; | ||
65 | struct platform_device *__init mxs_add_flexcan( | ||
66 | const struct mxs_flexcan_data *data, | ||
67 | const struct flexcan_platform_data *pdata); | ||
68 | |||
69 | /* i2c */ | ||
70 | struct mxs_mxs_i2c_data { | ||
71 | int id; | ||
72 | resource_size_t iobase; | ||
73 | resource_size_t errirq; | ||
74 | resource_size_t dmairq; | ||
75 | }; | ||
76 | struct platform_device * __init mxs_add_mxs_i2c( | ||
77 | const struct mxs_mxs_i2c_data *data); | ||
78 | |||
79 | /* mmc */ | ||
80 | #include <mach/mmc.h> | ||
81 | struct mxs_mxs_mmc_data { | ||
82 | int id; | ||
83 | resource_size_t iobase; | ||
84 | resource_size_t dma; | ||
85 | resource_size_t irq_err; | ||
86 | resource_size_t irq_dma; | ||
87 | }; | ||
88 | struct platform_device *__init mxs_add_mxs_mmc( | ||
89 | const struct mxs_mxs_mmc_data *data, | ||
90 | const struct mxs_mmc_platform_data *pdata); | ||
91 | |||
92 | /* pwm */ | ||
93 | struct platform_device *__init mxs_add_mxs_pwm( | ||
94 | resource_size_t iobase, int id); | ||
diff --git a/arch/arm/mach-mxs/include/mach/dma.h b/arch/arm/mach-mxs/include/mach/dma.h new file mode 100644 index 00000000000..203d7c4a3e1 --- /dev/null +++ b/arch/arm/mach-mxs/include/mach/dma.h | |||
@@ -0,0 +1,28 @@ | |||
1 | /* | ||
2 | * Copyright 2011 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or modify | ||
5 | * it under the terms of the GNU General Public License version 2 as | ||
6 | * published by the Free Software Foundation. | ||
7 | */ | ||
8 | |||
9 | #ifndef __MACH_MXS_DMA_H__ | ||
10 | #define __MACH_MXS_DMA_H__ | ||
11 | |||
12 | #include <linux/dmaengine.h> | ||
13 | |||
14 | struct mxs_dma_data { | ||
15 | int chan_irq; | ||
16 | }; | ||
17 | |||
18 | static inline int mxs_dma_is_apbh(struct dma_chan *chan) | ||
19 | { | ||
20 | return !strcmp(dev_name(chan->device->dev), "mxs-dma-apbh"); | ||
21 | } | ||
22 | |||
23 | static inline int mxs_dma_is_apbx(struct dma_chan *chan) | ||
24 | { | ||
25 | return !strcmp(dev_name(chan->device->dev), "mxs-dma-apbx"); | ||
26 | } | ||
27 | |||
28 | #endif /* __MACH_MXS_DMA_H__ */ | ||
diff --git a/arch/arm/mach-mxs/include/mach/entry-macro.S b/arch/arm/mach-mxs/include/mach/entry-macro.S new file mode 100644 index 00000000000..9f0da12e657 --- /dev/null +++ b/arch/arm/mach-mxs/include/mach/entry-macro.S | |||
@@ -0,0 +1,41 @@ | |||
1 | /* | ||
2 | * Low-level IRQ helper macros for Freescale MXS-based | ||
3 | * | ||
4 | * Copyright (C) 2009-2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License as published by | ||
8 | * the Free Software Foundation; either version 2 of the License, or | ||
9 | * (at your option) any later version. | ||
10 | * | ||
11 | * This program is distributed in the hope that it will be useful, | ||
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
14 | * GNU General Public License for more details. | ||
15 | * | ||
16 | * You should have received a copy of the GNU General Public License along | ||
17 | * with this program; if not, write to the Free Software Foundation, Inc., | ||
18 | * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | ||
19 | */ | ||
20 | |||
21 | #include <mach/mxs.h> | ||
22 | |||
23 | #define MXS_ICOLL_VBASE MXS_IO_ADDRESS(MXS_ICOLL_BASE_ADDR) | ||
24 | #define HW_ICOLL_STAT_OFFSET 0x70 | ||
25 | |||
26 | .macro disable_fiq | ||
27 | .endm | ||
28 | |||
29 | .macro get_irqnr_and_base, irqnr, irqstat, base, tmp | ||
30 | ldr \irqnr, [\base, #HW_ICOLL_STAT_OFFSET] | ||
31 | cmp \irqnr, #0x7F | ||
32 | strne \irqnr, [\base] | ||
33 | moveqs \irqnr, #0 | ||
34 | .endm | ||
35 | |||
36 | .macro get_irqnr_preamble, base, tmp | ||
37 | ldr \base, =MXS_ICOLL_VBASE | ||
38 | .endm | ||
39 | |||
40 | .macro arch_ret_to_user, tmp1, tmp2 | ||
41 | .endm | ||
diff --git a/arch/arm/mach-mxs/include/mach/gpio.h b/arch/arm/mach-mxs/include/mach/gpio.h new file mode 100644 index 00000000000..828ccccb6aa --- /dev/null +++ b/arch/arm/mach-mxs/include/mach/gpio.h | |||
@@ -0,0 +1,35 @@ | |||
1 | /* | ||
2 | * Copyright 2007 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | * Copyright 2008 Juergen Beisert, kernel@pengutronix.de | ||
4 | * | ||
5 | * This program is free software; you can redistribute it and/or | ||
6 | * modify it under the terms of the GNU General Public License | ||
7 | * as published by the Free Software Foundation; either version 2 | ||
8 | * of the License, or (at your option) any later version. | ||
9 | * This program is distributed in the hope that it will be useful, | ||
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
12 | * GNU General Public License for more details. | ||
13 | * | ||
14 | * You should have received a copy of the GNU General Public License | ||
15 | * along with this program; if not, write to the Free Software | ||
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, | ||
17 | * MA 02110-1301, USA. | ||
18 | */ | ||
19 | |||
20 | #ifndef __MACH_MXS_GPIO_H__ | ||
21 | #define __MACH_MXS_GPIO_H__ | ||
22 | |||
23 | #include <asm-generic/gpio.h> | ||
24 | |||
25 | #define MXS_GPIO_NR(bank, nr) ((bank) * 32 + (nr)) | ||
26 | |||
27 | /* use gpiolib dispatchers */ | ||
28 | #define gpio_get_value __gpio_get_value | ||
29 | #define gpio_set_value __gpio_set_value | ||
30 | #define gpio_cansleep __gpio_cansleep | ||
31 | #define gpio_to_irq __gpio_to_irq | ||
32 | |||
33 | #define irq_to_gpio(irq) ((irq) - MXS_GPIO_IRQ_START) | ||
34 | |||
35 | #endif /* __MACH_MXS_GPIO_H__ */ | ||
diff --git a/arch/arm/mach-mxs/include/mach/io.h b/arch/arm/mach-mxs/include/mach/io.h new file mode 100644 index 00000000000..289b7227e07 --- /dev/null +++ b/arch/arm/mach-mxs/include/mach/io.h | |||
@@ -0,0 +1,22 @@ | |||
1 | /* | ||
2 | * Copyright 2004-2007 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | */ | ||
4 | |||
5 | /* | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #ifndef __MACH_MXS_IO_H__ | ||
12 | #define __MACH_MXS_IO_H__ | ||
13 | |||
14 | /* Allow IO space to be anywhere in the memory */ | ||
15 | #define IO_SPACE_LIMIT 0xffffffff | ||
16 | |||
17 | /* io address mapping macro */ | ||
18 | #define __io(a) __typesafe_io(a) | ||
19 | |||
20 | #define __mem_pci(a) (a) | ||
21 | |||
22 | #endif /* __MACH_MXS_IO_H__ */ | ||
diff --git a/arch/arm/mach-mxs/include/mach/iomux-mx23.h b/arch/arm/mach-mxs/include/mach/iomux-mx23.h new file mode 100644 index 00000000000..b0190a4822f --- /dev/null +++ b/arch/arm/mach-mxs/include/mach/iomux-mx23.h | |||
@@ -0,0 +1,355 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2009-2010 Amit Kucheria <amit.kucheria@canonical.com> | ||
3 | * Copyright (C) 2010 Freescale Semiconductor, Inc. | ||
4 | * | ||
5 | * The code contained herein is licensed under the GNU General Public | ||
6 | * License. You may obtain a copy of the GNU General Public License | ||
7 | * Version 2 or later at the following locations: | ||
8 | * | ||
9 | * http://www.opensource.org/licenses/gpl-license.html | ||
10 | * http://www.gnu.org/copyleft/gpl.html | ||
11 | */ | ||
12 | |||
13 | #ifndef __MACH_IOMUX_MX23_H__ | ||
14 | #define __MACH_IOMUX_MX23_H__ | ||
15 | |||
16 | #include <mach/iomux.h> | ||
17 | |||
18 | /* | ||
19 | * The naming convention for the pad modes is MX23_PAD_<padname>__<padmode> | ||
20 | * If <padname> or <padmode> refers to a GPIO, it is named GPIO_<unit>_<num> | ||
21 | * See also iomux.h | ||
22 | * | ||
23 | * BANK PIN MUX | ||
24 | */ | ||
25 | /* MUXSEL_0 */ | ||
26 | #define MX23_PAD_GPMI_D00__GPMI_D00 MXS_IOMUX_PAD_NAKED(0, 0, PAD_MUXSEL_0) | ||
27 | #define MX23_PAD_GPMI_D01__GPMI_D01 MXS_IOMUX_PAD_NAKED(0, 1, PAD_MUXSEL_0) | ||
28 | #define MX23_PAD_GPMI_D02__GPMI_D02 MXS_IOMUX_PAD_NAKED(0, 2, PAD_MUXSEL_0) | ||
29 | #define MX23_PAD_GPMI_D03__GPMI_D03 MXS_IOMUX_PAD_NAKED(0, 3, PAD_MUXSEL_0) | ||
30 | #define MX23_PAD_GPMI_D04__GPMI_D04 MXS_IOMUX_PAD_NAKED(0, 4, PAD_MUXSEL_0) | ||
31 | #define MX23_PAD_GPMI_D05__GPMI_D05 MXS_IOMUX_PAD_NAKED(0, 5, PAD_MUXSEL_0) | ||
32 | #define MX23_PAD_GPMI_D06__GPMI_D06 MXS_IOMUX_PAD_NAKED(0, 6, PAD_MUXSEL_0) | ||
33 | #define MX23_PAD_GPMI_D07__GPMI_D07 MXS_IOMUX_PAD_NAKED(0, 7, PAD_MUXSEL_0) | ||
34 | #define MX23_PAD_GPMI_D08__GPMI_D08 MXS_IOMUX_PAD_NAKED(0, 8, PAD_MUXSEL_0) | ||
35 | #define MX23_PAD_GPMI_D09__GPMI_D09 MXS_IOMUX_PAD_NAKED(0, 9, PAD_MUXSEL_0) | ||
36 | #define MX23_PAD_GPMI_D10__GPMI_D10 MXS_IOMUX_PAD_NAKED(0, 10, PAD_MUXSEL_0) | ||
37 | #define MX23_PAD_GPMI_D11__GPMI_D11 MXS_IOMUX_PAD_NAKED(0, 11, PAD_MUXSEL_0) | ||
38 | #define MX23_PAD_GPMI_D12__GPMI_D12 MXS_IOMUX_PAD_NAKED(0, 12, PAD_MUXSEL_0) | ||
39 | #define MX23_PAD_GPMI_D13__GPMI_D13 MXS_IOMUX_PAD_NAKED(0, 13, PAD_MUXSEL_0) | ||
40 | #define MX23_PAD_GPMI_D14__GPMI_D14 MXS_IOMUX_PAD_NAKED(0, 14, PAD_MUXSEL_0) | ||
41 | #define MX23_PAD_GPMI_D15__GPMI_D15 MXS_IOMUX_PAD_NAKED(0, 15, PAD_MUXSEL_0) | ||
42 | #define MX23_PAD_GPMI_CLE__GPMI_CLE MXS_IOMUX_PAD_NAKED(0, 16, PAD_MUXSEL_0) | ||
43 | #define MX23_PAD_GPMI_ALE__GPMI_ALE MXS_IOMUX_PAD_NAKED(0, 17, PAD_MUXSEL_0) | ||
44 | #define MX23_PAD_GPMI_CE2N__GPMI_CE2N MXS_IOMUX_PAD_NAKED(0, 18, PAD_MUXSEL_0) | ||
45 | #define MX23_PAD_GPMI_RDY0__GPMI_RDY0 MXS_IOMUX_PAD_NAKED(0, 19, PAD_MUXSEL_0) | ||
46 | #define MX23_PAD_GPMI_RDY1__GPMI_RDY1 MXS_IOMUX_PAD_NAKED(0, 20, PAD_MUXSEL_0) | ||
47 | #define MX23_PAD_GPMI_RDY2__GPMI_RDY2 MXS_IOMUX_PAD_NAKED(0, 21, PAD_MUXSEL_0) | ||
48 | #define MX23_PAD_GPMI_RDY3__GPMI_RDY3 MXS_IOMUX_PAD_NAKED(0, 22, PAD_MUXSEL_0) | ||
49 | #define MX23_PAD_GPMI_WPN__GPMI_WPN MXS_IOMUX_PAD_NAKED(0, 23, PAD_MUXSEL_0) | ||
50 | #define MX23_PAD_GPMI_WRN__GPMI_WRN MXS_IOMUX_PAD_NAKED(0, 24, PAD_MUXSEL_0) | ||
51 | #define MX23_PAD_GPMI_RDN__GPMI_RDN MXS_IOMUX_PAD_NAKED(0, 25, PAD_MUXSEL_0) | ||
52 | #define MX23_PAD_AUART1_CTS__AUART1_CTS MXS_IOMUX_PAD_NAKED(0, 26, PAD_MUXSEL_0) | ||
53 | #define MX23_PAD_AUART1_RTS__AUART1_RTS MXS_IOMUX_PAD_NAKED(0, 27, PAD_MUXSEL_0) | ||
54 | #define MX23_PAD_AUART1_RX__AUART1_RX MXS_IOMUX_PAD_NAKED(0, 28, PAD_MUXSEL_0) | ||
55 | #define MX23_PAD_AUART1_TX__AUART1_TX MXS_IOMUX_PAD_NAKED(0, 29, PAD_MUXSEL_0) | ||
56 | #define MX23_PAD_I2C_SCL__I2C_SCL MXS_IOMUX_PAD_NAKED(0, 30, PAD_MUXSEL_0) | ||
57 | #define MX23_PAD_I2C_SDA__I2C_SDA MXS_IOMUX_PAD_NAKED(0, 31, PAD_MUXSEL_0) | ||
58 | |||
59 | #define MX23_PAD_LCD_D00__LCD_D00 MXS_IOMUX_PAD_NAKED(1, 0, PAD_MUXSEL_0) | ||
60 | #define MX23_PAD_LCD_D01__LCD_D01 MXS_IOMUX_PAD_NAKED(1, 1, PAD_MUXSEL_0) | ||
61 | #define MX23_PAD_LCD_D02__LCD_D02 MXS_IOMUX_PAD_NAKED(1, 2, PAD_MUXSEL_0) | ||
62 | #define MX23_PAD_LCD_D03__LCD_D03 MXS_IOMUX_PAD_NAKED(1, 3, PAD_MUXSEL_0) | ||
63 | #define MX23_PAD_LCD_D04__LCD_D04 MXS_IOMUX_PAD_NAKED(1, 4, PAD_MUXSEL_0) | ||
64 | #define MX23_PAD_LCD_D05__LCD_D05 MXS_IOMUX_PAD_NAKED(1, 5, PAD_MUXSEL_0) | ||
65 | #define MX23_PAD_LCD_D06__LCD_D06 MXS_IOMUX_PAD_NAKED(1, 6, PAD_MUXSEL_0) | ||
66 | #define MX23_PAD_LCD_D07__LCD_D07 MXS_IOMUX_PAD_NAKED(1, 7, PAD_MUXSEL_0) | ||
67 | #define MX23_PAD_LCD_D08__LCD_D08 MXS_IOMUX_PAD_NAKED(1, 8, PAD_MUXSEL_0) | ||
68 | #define MX23_PAD_LCD_D09__LCD_D09 MXS_IOMUX_PAD_NAKED(1, 9, PAD_MUXSEL_0) | ||
69 | #define MX23_PAD_LCD_D10__LCD_D10 MXS_IOMUX_PAD_NAKED(1, 10, PAD_MUXSEL_0) | ||
70 | #define MX23_PAD_LCD_D11__LCD_D11 MXS_IOMUX_PAD_NAKED(1, 11, PAD_MUXSEL_0) | ||
71 | #define MX23_PAD_LCD_D12__LCD_D12 MXS_IOMUX_PAD_NAKED(1, 12, PAD_MUXSEL_0) | ||
72 | #define MX23_PAD_LCD_D13__LCD_D13 MXS_IOMUX_PAD_NAKED(1, 13, PAD_MUXSEL_0) | ||
73 | #define MX23_PAD_LCD_D14__LCD_D14 MXS_IOMUX_PAD_NAKED(1, 14, PAD_MUXSEL_0) | ||
74 | #define MX23_PAD_LCD_D15__LCD_D15 MXS_IOMUX_PAD_NAKED(1, 15, PAD_MUXSEL_0) | ||
75 | #define MX23_PAD_LCD_D16__LCD_D16 MXS_IOMUX_PAD_NAKED(1, 16, PAD_MUXSEL_0) | ||
76 | #define MX23_PAD_LCD_D17__LCD_D17 MXS_IOMUX_PAD_NAKED(1, 17, PAD_MUXSEL_0) | ||
77 | #define MX23_PAD_LCD_RESET__LCD_RESET MXS_IOMUX_PAD_NAKED(1, 18, PAD_MUXSEL_0) | ||
78 | #define MX23_PAD_LCD_RS__LCD_RS MXS_IOMUX_PAD_NAKED(1, 19, PAD_MUXSEL_0) | ||
79 | #define MX23_PAD_LCD_WR__LCD_WR MXS_IOMUX_PAD_NAKED(1, 20, PAD_MUXSEL_0) | ||
80 | #define MX23_PAD_LCD_CS__LCD_CS MXS_IOMUX_PAD_NAKED(1, 21, PAD_MUXSEL_0) | ||
81 | #define MX23_PAD_LCD_DOTCK__LCD_DOTCK MXS_IOMUX_PAD_NAKED(1, 22, PAD_MUXSEL_0) | ||
82 | #define MX23_PAD_LCD_ENABLE__LCD_ENABLE MXS_IOMUX_PAD_NAKED(1, 23, PAD_MUXSEL_0) | ||
83 | #define MX23_PAD_LCD_HSYNC__LCD_HSYNC MXS_IOMUX_PAD_NAKED(1, 24, PAD_MUXSEL_0) | ||
84 | #define MX23_PAD_LCD_VSYNC__LCD_VSYNC MXS_IOMUX_PAD_NAKED(1, 25, PAD_MUXSEL_0) | ||
85 | #define MX23_PAD_PWM0__PWM0 MXS_IOMUX_PAD_NAKED(1, 26, PAD_MUXSEL_0) | ||
86 | #define MX23_PAD_PWM1__PWM1 MXS_IOMUX_PAD_NAKED(1, 27, PAD_MUXSEL_0) | ||
87 | #define MX23_PAD_PWM2__PWM2 MXS_IOMUX_PAD_NAKED(1, 28, PAD_MUXSEL_0) | ||
88 | #define MX23_PAD_PWM3__PWM3 MXS_IOMUX_PAD_NAKED(1, 29, PAD_MUXSEL_0) | ||
89 | #define MX23_PAD_PWM4__PWM4 MXS_IOMUX_PAD_NAKED(1, 30, PAD_MUXSEL_0) | ||
90 | |||
91 | #define MX23_PAD_SSP1_CMD__SSP1_CMD MXS_IOMUX_PAD_NAKED(2, 0, PAD_MUXSEL_0) | ||
92 | #define MX23_PAD_SSP1_DETECT__SSP1_DETECT MXS_IOMUX_PAD_NAKED(2, 1, PAD_MUXSEL_0) | ||
93 | #define MX23_PAD_SSP1_DATA0__SSP1_DATA0 MXS_IOMUX_PAD_NAKED(2, 2, PAD_MUXSEL_0) | ||
94 | #define MX23_PAD_SSP1_DATA1__SSP1_DATA1 MXS_IOMUX_PAD_NAKED(2, 3, PAD_MUXSEL_0) | ||
95 | #define MX23_PAD_SSP1_DATA2__SSP1_DATA2 MXS_IOMUX_PAD_NAKED(2, 4, PAD_MUXSEL_0) | ||
96 | #define MX23_PAD_SSP1_DATA3__SSP1_DATA3 MXS_IOMUX_PAD_NAKED(2, 5, PAD_MUXSEL_0) | ||
97 | #define MX23_PAD_SSP1_SCK__SSP1_SCK MXS_IOMUX_PAD_NAKED(2, 6, PAD_MUXSEL_0) | ||
98 | #define MX23_PAD_ROTARYA__ROTARYA MXS_IOMUX_PAD_NAKED(2, 7, PAD_MUXSEL_0) | ||
99 | #define MX23_PAD_ROTARYB__ROTARYB MXS_IOMUX_PAD_NAKED(2, 8, PAD_MUXSEL_0) | ||
100 | #define MX23_PAD_EMI_A00__EMI_A00 MXS_IOMUX_PAD_NAKED(2, 9, PAD_MUXSEL_0) | ||
101 | #define MX23_PAD_EMI_A01__EMI_A01 MXS_IOMUX_PAD_NAKED(2, 10, PAD_MUXSEL_0) | ||
102 | #define MX23_PAD_EMI_A02__EMI_A02 MXS_IOMUX_PAD_NAKED(2, 11, PAD_MUXSEL_0) | ||
103 | #define MX23_PAD_EMI_A03__EMI_A03 MXS_IOMUX_PAD_NAKED(2, 12, PAD_MUXSEL_0) | ||
104 | #define MX23_PAD_EMI_A04__EMI_A04 MXS_IOMUX_PAD_NAKED(2, 13, PAD_MUXSEL_0) | ||
105 | #define MX23_PAD_EMI_A05__EMI_A05 MXS_IOMUX_PAD_NAKED(2, 14, PAD_MUXSEL_0) | ||
106 | #define MX23_PAD_EMI_A06__EMI_A06 MXS_IOMUX_PAD_NAKED(2, 15, PAD_MUXSEL_0) | ||
107 | #define MX23_PAD_EMI_A07__EMI_A07 MXS_IOMUX_PAD_NAKED(2, 16, PAD_MUXSEL_0) | ||
108 | #define MX23_PAD_EMI_A08__EMI_A08 MXS_IOMUX_PAD_NAKED(2, 17, PAD_MUXSEL_0) | ||
109 | #define MX23_PAD_EMI_A09__EMI_A09 MXS_IOMUX_PAD_NAKED(2, 18, PAD_MUXSEL_0) | ||
110 | #define MX23_PAD_EMI_A10__EMI_A10 MXS_IOMUX_PAD_NAKED(2, 19, PAD_MUXSEL_0) | ||
111 | #define MX23_PAD_EMI_A11__EMI_A11 MXS_IOMUX_PAD_NAKED(2, 20, PAD_MUXSEL_0) | ||
112 | #define MX23_PAD_EMI_A12__EMI_A12 MXS_IOMUX_PAD_NAKED(2, 21, PAD_MUXSEL_0) | ||
113 | #define MX23_PAD_EMI_BA0__EMI_BA0 MXS_IOMUX_PAD_NAKED(2, 22, PAD_MUXSEL_0) | ||
114 | #define MX23_PAD_EMI_BA1__EMI_BA1 MXS_IOMUX_PAD_NAKED(2, 23, PAD_MUXSEL_0) | ||
115 | #define MX23_PAD_EMI_CASN__EMI_CASN MXS_IOMUX_PAD_NAKED(2, 24, PAD_MUXSEL_0) | ||
116 | #define MX23_PAD_EMI_CE0N__EMI_CE0N MXS_IOMUX_PAD_NAKED(2, 25, PAD_MUXSEL_0) | ||
117 | #define MX23_PAD_EMI_CE1N__EMI_CE1N MXS_IOMUX_PAD_NAKED(2, 26, PAD_MUXSEL_0) | ||
118 | #define MX23_PAD_GPMI_CE1N__GPMI_CE1N MXS_IOMUX_PAD_NAKED(2, 27, PAD_MUXSEL_0) | ||
119 | #define MX23_PAD_GPMI_CE0N__GPMI_CE0N MXS_IOMUX_PAD_NAKED(2, 28, PAD_MUXSEL_0) | ||
120 | #define MX23_PAD_EMI_CKE__EMI_CKE MXS_IOMUX_PAD_NAKED(2, 29, PAD_MUXSEL_0) | ||
121 | #define MX23_PAD_EMI_RASN__EMI_RASN MXS_IOMUX_PAD_NAKED(2, 30, PAD_MUXSEL_0) | ||
122 | #define MX23_PAD_EMI_WEN__EMI_WEN MXS_IOMUX_PAD_NAKED(2, 31, PAD_MUXSEL_0) | ||
123 | |||
124 | #define MX23_PAD_EMI_D00__EMI_D00 MXS_IOMUX_PAD_NAKED(3, 0, PAD_MUXSEL_0) | ||
125 | #define MX23_PAD_EMI_D01__EMI_D01 MXS_IOMUX_PAD_NAKED(3, 1, PAD_MUXSEL_0) | ||
126 | #define MX23_PAD_EMI_D02__EMI_D02 MXS_IOMUX_PAD_NAKED(3, 2, PAD_MUXSEL_0) | ||
127 | #define MX23_PAD_EMI_D03__EMI_D03 MXS_IOMUX_PAD_NAKED(3, 3, PAD_MUXSEL_0) | ||
128 | #define MX23_PAD_EMI_D04__EMI_D04 MXS_IOMUX_PAD_NAKED(3, 4, PAD_MUXSEL_0) | ||
129 | #define MX23_PAD_EMI_D05__EMI_D05 MXS_IOMUX_PAD_NAKED(3, 5, PAD_MUXSEL_0) | ||
130 | #define MX23_PAD_EMI_D06__EMI_D06 MXS_IOMUX_PAD_NAKED(3, 6, PAD_MUXSEL_0) | ||
131 | #define MX23_PAD_EMI_D07__EMI_D07 MXS_IOMUX_PAD_NAKED(3, 7, PAD_MUXSEL_0) | ||
132 | #define MX23_PAD_EMI_D08__EMI_D08 MXS_IOMUX_PAD_NAKED(3, 8, PAD_MUXSEL_0) | ||
133 | #define MX23_PAD_EMI_D09__EMI_D09 MXS_IOMUX_PAD_NAKED(3, 9, PAD_MUXSEL_0) | ||
134 | #define MX23_PAD_EMI_D10__EMI_D10 MXS_IOMUX_PAD_NAKED(3, 10, PAD_MUXSEL_0) | ||
135 | #define MX23_PAD_EMI_D11__EMI_D11 MXS_IOMUX_PAD_NAKED(3, 11, PAD_MUXSEL_0) | ||
136 | #define MX23_PAD_EMI_D12__EMI_D12 MXS_IOMUX_PAD_NAKED(3, 12, PAD_MUXSEL_0) | ||
137 | #define MX23_PAD_EMI_D13__EMI_D13 MXS_IOMUX_PAD_NAKED(3, 13, PAD_MUXSEL_0) | ||
138 | #define MX23_PAD_EMI_D14__EMI_D14 MXS_IOMUX_PAD_NAKED(3, 14, PAD_MUXSEL_0) | ||
139 | #define MX23_PAD_EMI_D15__EMI_D15 MXS_IOMUX_PAD_NAKED(3, 15, PAD_MUXSEL_0) | ||
140 | #define MX23_PAD_EMI_DQM0__EMI_DQM0 MXS_IOMUX_PAD_NAKED(3, 16, PAD_MUXSEL_0) | ||
141 | #define MX23_PAD_EMI_DQM1__EMI_DQM1 MXS_IOMUX_PAD_NAKED(3, 17, PAD_MUXSEL_0) | ||
142 | #define MX23_PAD_EMI_DQS0__EMI_DQS0 MXS_IOMUX_PAD_NAKED(3, 18, PAD_MUXSEL_0) | ||
143 | #define MX23_PAD_EMI_DQS1__EMI_DQS1 MXS_IOMUX_PAD_NAKED(3, 19, PAD_MUXSEL_0) | ||
144 | #define MX23_PAD_EMI_CLK__EMI_CLK MXS_IOMUX_PAD_NAKED(3, 20, PAD_MUXSEL_0) | ||
145 | #define MX23_PAD_EMI_CLKN__EMI_CLKN MXS_IOMUX_PAD_NAKED(3, 21, PAD_MUXSEL_0) | ||
146 | |||
147 | /* MUXSEL_1 */ | ||
148 | #define MX23_PAD_GPMI_D00__LCD_D8 MXS_IOMUX_PAD_NAKED(0, 0, PAD_MUXSEL_1) | ||
149 | #define MX23_PAD_GPMI_D01__LCD_D9 MXS_IOMUX_PAD_NAKED(0, 1, PAD_MUXSEL_1) | ||
150 | #define MX23_PAD_GPMI_D02__LCD_D10 MXS_IOMUX_PAD_NAKED(0, 2, PAD_MUXSEL_1) | ||
151 | #define MX23_PAD_GPMI_D03__LCD_D11 MXS_IOMUX_PAD_NAKED(0, 3, PAD_MUXSEL_1) | ||
152 | #define MX23_PAD_GPMI_D04__LCD_D12 MXS_IOMUX_PAD_NAKED(0, 4, PAD_MUXSEL_1) | ||
153 | #define MX23_PAD_GPMI_D05__LCD_D13 MXS_IOMUX_PAD_NAKED(0, 5, PAD_MUXSEL_1) | ||
154 | #define MX23_PAD_GPMI_D06__LCD_D14 MXS_IOMUX_PAD_NAKED(0, 6, PAD_MUXSEL_1) | ||
155 | #define MX23_PAD_GPMI_D07__LCD_D15 MXS_IOMUX_PAD_NAKED(0, 7, PAD_MUXSEL_1) | ||
156 | #define MX23_PAD_GPMI_D08__LCD_D18 MXS_IOMUX_PAD_NAKED(0, 8, PAD_MUXSEL_1) | ||
157 | #define MX23_PAD_GPMI_D09__LCD_D19 MXS_IOMUX_PAD_NAKED(0, 9, PAD_MUXSEL_1) | ||
158 | #define MX23_PAD_GPMI_D10__LCD_D20 MXS_IOMUX_PAD_NAKED(0, 10, PAD_MUXSEL_1) | ||
159 | #define MX23_PAD_GPMI_D11__LCD_D21 MXS_IOMUX_PAD_NAKED(0, 11, PAD_MUXSEL_1) | ||
160 | #define MX23_PAD_GPMI_D12__LCD_D22 MXS_IOMUX_PAD_NAKED(0, 12, PAD_MUXSEL_1) | ||
161 | #define MX23_PAD_GPMI_D13__LCD_D23 MXS_IOMUX_PAD_NAKED(0, 13, PAD_MUXSEL_1) | ||
162 | #define MX23_PAD_GPMI_D14__AUART2_RX MXS_IOMUX_PAD_NAKED(0, 14, PAD_MUXSEL_1) | ||
163 | #define MX23_PAD_GPMI_D15__AUART2_TX MXS_IOMUX_PAD_NAKED(0, 15, PAD_MUXSEL_1) | ||
164 | #define MX23_PAD_GPMI_CLE__LCD_D16 MXS_IOMUX_PAD_NAKED(0, 16, PAD_MUXSEL_1) | ||
165 | #define MX23_PAD_GPMI_ALE__LCD_D17 MXS_IOMUX_PAD_NAKED(0, 17, PAD_MUXSEL_1) | ||
166 | #define MX23_PAD_GPMI_CE2N__ATA_A2 MXS_IOMUX_PAD_NAKED(0, 18, PAD_MUXSEL_1) | ||
167 | #define MX23_PAD_AUART1_RTS__IR_CLK MXS_IOMUX_PAD_NAKED(0, 27, PAD_MUXSEL_1) | ||
168 | #define MX23_PAD_AUART1_RX__IR_RX MXS_IOMUX_PAD_NAKED(0, 28, PAD_MUXSEL_1) | ||
169 | #define MX23_PAD_AUART1_TX__IR_TX MXS_IOMUX_PAD_NAKED(0, 29, PAD_MUXSEL_1) | ||
170 | #define MX23_PAD_I2C_SCL__GPMI_RDY2 MXS_IOMUX_PAD_NAKED(0, 30, PAD_MUXSEL_1) | ||
171 | #define MX23_PAD_I2C_SDA__GPMI_CE2N MXS_IOMUX_PAD_NAKED(0, 31, PAD_MUXSEL_1) | ||
172 | |||
173 | #define MX23_PAD_LCD_D00__ETM_DA8 MXS_IOMUX_PAD_NAKED(1, 0, PAD_MUXSEL_1) | ||
174 | #define MX23_PAD_LCD_D01__ETM_DA9 MXS_IOMUX_PAD_NAKED(1, 1, PAD_MUXSEL_1) | ||
175 | #define MX23_PAD_LCD_D02__ETM_DA10 MXS_IOMUX_PAD_NAKED(1, 2, PAD_MUXSEL_1) | ||
176 | #define MX23_PAD_LCD_D03__ETM_DA11 MXS_IOMUX_PAD_NAKED(1, 3, PAD_MUXSEL_1) | ||
177 | #define MX23_PAD_LCD_D04__ETM_DA12 MXS_IOMUX_PAD_NAKED(1, 4, PAD_MUXSEL_1) | ||
178 | #define MX23_PAD_LCD_D05__ETM_DA13 MXS_IOMUX_PAD_NAKED(1, 5, PAD_MUXSEL_1) | ||
179 | #define MX23_PAD_LCD_D06__ETM_DA14 MXS_IOMUX_PAD_NAKED(1, 6, PAD_MUXSEL_1) | ||
180 | #define MX23_PAD_LCD_D07__ETM_DA15 MXS_IOMUX_PAD_NAKED(1, 7, PAD_MUXSEL_1) | ||
181 | #define MX23_PAD_LCD_D08__ETM_DA0 MXS_IOMUX_PAD_NAKED(1, 8, PAD_MUXSEL_1) | ||
182 | #define MX23_PAD_LCD_D09__ETM_DA1 MXS_IOMUX_PAD_NAKED(1, 9, PAD_MUXSEL_1) | ||
183 | #define MX23_PAD_LCD_D10__ETM_DA2 MXS_IOMUX_PAD_NAKED(1, 10, PAD_MUXSEL_1) | ||
184 | #define MX23_PAD_LCD_D11__ETM_DA3 MXS_IOMUX_PAD_NAKED(1, 11, PAD_MUXSEL_1) | ||
185 | #define MX23_PAD_LCD_D12__ETM_DA4 MXS_IOMUX_PAD_NAKED(1, 12, PAD_MUXSEL_1) | ||
186 | #define MX23_PAD_LCD_D13__ETM_DA5 MXS_IOMUX_PAD_NAKED(1, 13, PAD_MUXSEL_1) | ||
187 | #define MX23_PAD_LCD_D14__ETM_DA6 MXS_IOMUX_PAD_NAKED(1, 14, PAD_MUXSEL_1) | ||
188 | #define MX23_PAD_LCD_D15__ETM_DA7 MXS_IOMUX_PAD_NAKED(1, 15, PAD_MUXSEL_1) | ||
189 | #define MX23_PAD_LCD_RESET__ETM_TCTL MXS_IOMUX_PAD_NAKED(1, 18, PAD_MUXSEL_1) | ||
190 | #define MX23_PAD_LCD_RS__ETM_TCLK MXS_IOMUX_PAD_NAKED(1, 19, PAD_MUXSEL_1) | ||
191 | #define MX23_PAD_LCD_DOTCK__GPMI_RDY3 MXS_IOMUX_PAD_NAKED(1, 22, PAD_MUXSEL_1) | ||
192 | #define MX23_PAD_LCD_ENABLE__I2C_SCL MXS_IOMUX_PAD_NAKED(1, 23, PAD_MUXSEL_1) | ||
193 | #define MX23_PAD_LCD_HSYNC__I2C_SDA MXS_IOMUX_PAD_NAKED(1, 24, PAD_MUXSEL_1) | ||
194 | #define MX23_PAD_LCD_VSYNC__LCD_BUSY MXS_IOMUX_PAD_NAKED(1, 25, PAD_MUXSEL_1) | ||
195 | #define MX23_PAD_PWM0__ROTARYA MXS_IOMUX_PAD_NAKED(1, 26, PAD_MUXSEL_1) | ||
196 | #define MX23_PAD_PWM1__ROTARYB MXS_IOMUX_PAD_NAKED(1, 27, PAD_MUXSEL_1) | ||
197 | #define MX23_PAD_PWM2__GPMI_RDY3 MXS_IOMUX_PAD_NAKED(1, 28, PAD_MUXSEL_1) | ||
198 | #define MX23_PAD_PWM3__ETM_TCTL MXS_IOMUX_PAD_NAKED(1, 29, PAD_MUXSEL_1) | ||
199 | #define MX23_PAD_PWM4__ETM_TCLK MXS_IOMUX_PAD_NAKED(1, 30, PAD_MUXSEL_1) | ||
200 | |||
201 | #define MX23_PAD_SSP1_DETECT__GPMI_CE3N MXS_IOMUX_PAD_NAKED(2, 1, PAD_MUXSEL_1) | ||
202 | #define MX23_PAD_SSP1_DATA1__I2C_SCL MXS_IOMUX_PAD_NAKED(2, 3, PAD_MUXSEL_1) | ||
203 | #define MX23_PAD_SSP1_DATA2__I2C_SDA MXS_IOMUX_PAD_NAKED(2, 4, PAD_MUXSEL_1) | ||
204 | #define MX23_PAD_ROTARYA__AUART2_RTS MXS_IOMUX_PAD_NAKED(2, 7, PAD_MUXSEL_1) | ||
205 | #define MX23_PAD_ROTARYB__AUART2_CTS MXS_IOMUX_PAD_NAKED(2, 8, PAD_MUXSEL_1) | ||
206 | |||
207 | /* MUXSEL_2 */ | ||
208 | #define MX23_PAD_GPMI_D00__SSP2_DATA0 MXS_IOMUX_PAD_NAKED(0, 0, PAD_MUXSEL_2) | ||
209 | #define MX23_PAD_GPMI_D01__SSP2_DATA1 MXS_IOMUX_PAD_NAKED(0, 1, PAD_MUXSEL_2) | ||
210 | #define MX23_PAD_GPMI_D02__SSP2_DATA2 MXS_IOMUX_PAD_NAKED(0, 2, PAD_MUXSEL_2) | ||
211 | #define MX23_PAD_GPMI_D03__SSP2_DATA3 MXS_IOMUX_PAD_NAKED(0, 3, PAD_MUXSEL_2) | ||
212 | #define MX23_PAD_GPMI_D04__SSP2_DATA4 MXS_IOMUX_PAD_NAKED(0, 4, PAD_MUXSEL_2) | ||
213 | #define MX23_PAD_GPMI_D05__SSP2_DATA5 MXS_IOMUX_PAD_NAKED(0, 5, PAD_MUXSEL_2) | ||
214 | #define MX23_PAD_GPMI_D06__SSP2_DATA6 MXS_IOMUX_PAD_NAKED(0, 6, PAD_MUXSEL_2) | ||
215 | #define MX23_PAD_GPMI_D07__SSP2_DATA7 MXS_IOMUX_PAD_NAKED(0, 7, PAD_MUXSEL_2) | ||
216 | #define MX23_PAD_GPMI_D08__SSP1_DATA4 MXS_IOMUX_PAD_NAKED(0, 8, PAD_MUXSEL_2) | ||
217 | #define MX23_PAD_GPMI_D09__SSP1_DATA5 MXS_IOMUX_PAD_NAKED(0, 9, PAD_MUXSEL_2) | ||
218 | #define MX23_PAD_GPMI_D10__SSP1_DATA6 MXS_IOMUX_PAD_NAKED(0, 10, PAD_MUXSEL_2) | ||
219 | #define MX23_PAD_GPMI_D11__SSP1_DATA7 MXS_IOMUX_PAD_NAKED(0, 11, PAD_MUXSEL_2) | ||
220 | #define MX23_PAD_GPMI_D15__GPMI_CE3N MXS_IOMUX_PAD_NAKED(0, 15, PAD_MUXSEL_2) | ||
221 | #define MX23_PAD_GPMI_RDY0__SSP2_DETECT MXS_IOMUX_PAD_NAKED(0, 19, PAD_MUXSEL_2) | ||
222 | #define MX23_PAD_GPMI_RDY1__SSP2_CMD MXS_IOMUX_PAD_NAKED(0, 20, PAD_MUXSEL_2) | ||
223 | #define MX23_PAD_GPMI_WRN__SSP2_SCK MXS_IOMUX_PAD_NAKED(0, 24, PAD_MUXSEL_2) | ||
224 | #define MX23_PAD_AUART1_CTS__SSP1_DATA4 MXS_IOMUX_PAD_NAKED(0, 26, PAD_MUXSEL_2) | ||
225 | #define MX23_PAD_AUART1_RTS__SSP1_DATA5 MXS_IOMUX_PAD_NAKED(0, 27, PAD_MUXSEL_2) | ||
226 | #define MX23_PAD_AUART1_RX__SSP1_DATA6 MXS_IOMUX_PAD_NAKED(0, 28, PAD_MUXSEL_2) | ||
227 | #define MX23_PAD_AUART1_TX__SSP1_DATA7 MXS_IOMUX_PAD_NAKED(0, 29, PAD_MUXSEL_2) | ||
228 | #define MX23_PAD_I2C_SCL__AUART1_TX MXS_IOMUX_PAD_NAKED(0, 30, PAD_MUXSEL_2) | ||
229 | #define MX23_PAD_I2C_SDA__AUART1_RX MXS_IOMUX_PAD_NAKED(0, 31, PAD_MUXSEL_2) | ||
230 | |||
231 | #define MX23_PAD_LCD_D08__SAIF2_SDATA0 MXS_IOMUX_PAD_NAKED(1, 8, PAD_MUXSEL_2) | ||
232 | #define MX23_PAD_LCD_D09__SAIF1_SDATA0 MXS_IOMUX_PAD_NAKED(1, 9, PAD_MUXSEL_2) | ||
233 | #define MX23_PAD_LCD_D10__SAIF_MCLK_BITCLK MXS_IOMUX_PAD_NAKED(1, 10, PAD_MUXSEL_2) | ||
234 | #define MX23_PAD_LCD_D11__SAIF_LRCLK MXS_IOMUX_PAD_NAKED(1, 11, PAD_MUXSEL_2) | ||
235 | #define MX23_PAD_LCD_D12__SAIF2_SDATA1 MXS_IOMUX_PAD_NAKED(1, 12, PAD_MUXSEL_2) | ||
236 | #define MX23_PAD_LCD_D13__SAIF2_SDATA2 MXS_IOMUX_PAD_NAKED(1, 13, PAD_MUXSEL_2) | ||
237 | #define MX23_PAD_LCD_D14__SAIF1_SDATA2 MXS_IOMUX_PAD_NAKED(1, 14, PAD_MUXSEL_2) | ||
238 | #define MX23_PAD_LCD_D15__SAIF1_SDATA1 MXS_IOMUX_PAD_NAKED(1, 15, PAD_MUXSEL_2) | ||
239 | #define MX23_PAD_LCD_D16__SAIF_ALT_BITCLK MXS_IOMUX_PAD_NAKED(1, 16, PAD_MUXSEL_2) | ||
240 | #define MX23_PAD_LCD_RESET__GPMI_CE3N MXS_IOMUX_PAD_NAKED(1, 18, PAD_MUXSEL_2) | ||
241 | #define MX23_PAD_PWM0__DUART_RX MXS_IOMUX_PAD_NAKED(1, 26, PAD_MUXSEL_2) | ||
242 | #define MX23_PAD_PWM1__DUART_TX MXS_IOMUX_PAD_NAKED(1, 27, PAD_MUXSEL_2) | ||
243 | #define MX23_PAD_PWM3__AUART1_CTS MXS_IOMUX_PAD_NAKED(1, 29, PAD_MUXSEL_2) | ||
244 | #define MX23_PAD_PWM4__AUART1_RTS MXS_IOMUX_PAD_NAKED(1, 30, PAD_MUXSEL_2) | ||
245 | |||
246 | #define MX23_PAD_SSP1_CMD__JTAG_TDO MXS_IOMUX_PAD_NAKED(2, 0, PAD_MUXSEL_2) | ||
247 | #define MX23_PAD_SSP1_DETECT__USB_OTG_ID MXS_IOMUX_PAD_NAKED(2, 1, PAD_MUXSEL_2) | ||
248 | #define MX23_PAD_SSP1_DATA0__JTAG_TDI MXS_IOMUX_PAD_NAKED(2, 2, PAD_MUXSEL_2) | ||
249 | #define MX23_PAD_SSP1_DATA1__JTAG_TCLK MXS_IOMUX_PAD_NAKED(2, 3, PAD_MUXSEL_2) | ||
250 | #define MX23_PAD_SSP1_DATA2__JTAG_RTCK MXS_IOMUX_PAD_NAKED(2, 4, PAD_MUXSEL_2) | ||
251 | #define MX23_PAD_SSP1_DATA3__JTAG_TMS MXS_IOMUX_PAD_NAKED(2, 5, PAD_MUXSEL_2) | ||
252 | #define MX23_PAD_SSP1_SCK__JTAG_TRST MXS_IOMUX_PAD_NAKED(2, 6, PAD_MUXSEL_2) | ||
253 | #define MX23_PAD_ROTARYA__SPDIF MXS_IOMUX_PAD_NAKED(2, 7, PAD_MUXSEL_2) | ||
254 | #define MX23_PAD_ROTARYB__GPMI_CE3N MXS_IOMUX_PAD_NAKED(2, 8, PAD_MUXSEL_2) | ||
255 | |||
256 | /* MUXSEL_GPIO */ | ||
257 | #define MX23_PAD_GPMI_D00__GPIO_0_0 MXS_IOMUX_PAD_NAKED(0, 0, PAD_MUXSEL_GPIO) | ||
258 | #define MX23_PAD_GPMI_D01__GPIO_0_1 MXS_IOMUX_PAD_NAKED(0, 1, PAD_MUXSEL_GPIO) | ||
259 | #define MX23_PAD_GPMI_D02__GPIO_0_2 MXS_IOMUX_PAD_NAKED(0, 2, PAD_MUXSEL_GPIO) | ||
260 | #define MX23_PAD_GPMI_D03__GPIO_0_3 MXS_IOMUX_PAD_NAKED(0, 3, PAD_MUXSEL_GPIO) | ||
261 | #define MX23_PAD_GPMI_D04__GPIO_0_4 MXS_IOMUX_PAD_NAKED(0, 4, PAD_MUXSEL_GPIO) | ||
262 | #define MX23_PAD_GPMI_D05__GPIO_0_5 MXS_IOMUX_PAD_NAKED(0, 5, PAD_MUXSEL_GPIO) | ||
263 | #define MX23_PAD_GPMI_D06__GPIO_0_6 MXS_IOMUX_PAD_NAKED(0, 6, PAD_MUXSEL_GPIO) | ||
264 | #define MX23_PAD_GPMI_D07__GPIO_0_7 MXS_IOMUX_PAD_NAKED(0, 7, PAD_MUXSEL_GPIO) | ||
265 | #define MX23_PAD_GPMI_D08__GPIO_0_8 MXS_IOMUX_PAD_NAKED(0, 8, PAD_MUXSEL_GPIO) | ||
266 | #define MX23_PAD_GPMI_D09__GPIO_0_9 MXS_IOMUX_PAD_NAKED(0, 9, PAD_MUXSEL_GPIO) | ||
267 | #define MX23_PAD_GPMI_D10__GPIO_0_10 MXS_IOMUX_PAD_NAKED(0, 10, PAD_MUXSEL_GPIO) | ||
268 | #define MX23_PAD_GPMI_D11__GPIO_0_11 MXS_IOMUX_PAD_NAKED(0, 11, PAD_MUXSEL_GPIO) | ||
269 | #define MX23_PAD_GPMI_D12__GPIO_0_12 MXS_IOMUX_PAD_NAKED(0, 12, PAD_MUXSEL_GPIO) | ||
270 | #define MX23_PAD_GPMI_D13__GPIO_0_13 MXS_IOMUX_PAD_NAKED(0, 13, PAD_MUXSEL_GPIO) | ||
271 | #define MX23_PAD_GPMI_D14__GPIO_0_14 MXS_IOMUX_PAD_NAKED(0, 14, PAD_MUXSEL_GPIO) | ||
272 | #define MX23_PAD_GPMI_D15__GPIO_0_15 MXS_IOMUX_PAD_NAKED(0, 15, PAD_MUXSEL_GPIO) | ||
273 | #define MX23_PAD_GPMI_CLE__GPIO_0_16 MXS_IOMUX_PAD_NAKED(0, 16, PAD_MUXSEL_GPIO) | ||
274 | #define MX23_PAD_GPMI_ALE__GPIO_0_17 MXS_IOMUX_PAD_NAKED(0, 17, PAD_MUXSEL_GPIO) | ||
275 | #define MX23_PAD_GPMI_CE2N__GPIO_0_18 MXS_IOMUX_PAD_NAKED(0, 18, PAD_MUXSEL_GPIO) | ||
276 | #define MX23_PAD_GPMI_RDY0__GPIO_0_19 MXS_IOMUX_PAD_NAKED(0, 19, PAD_MUXSEL_GPIO) | ||
277 | #define MX23_PAD_GPMI_RDY1__GPIO_0_20 MXS_IOMUX_PAD_NAKED(0, 20, PAD_MUXSEL_GPIO) | ||
278 | #define MX23_PAD_GPMI_RDY2__GPIO_0_21 MXS_IOMUX_PAD_NAKED(0, 21, PAD_MUXSEL_GPIO) | ||
279 | #define MX23_PAD_GPMI_RDY3__GPIO_0_22 MXS_IOMUX_PAD_NAKED(0, 22, PAD_MUXSEL_GPIO) | ||
280 | #define MX23_PAD_GPMI_WPN__GPIO_0_23 MXS_IOMUX_PAD_NAKED(0, 23, PAD_MUXSEL_GPIO) | ||
281 | #define MX23_PAD_GPMI_WRN__GPIO_0_24 MXS_IOMUX_PAD_NAKED(0, 24, PAD_MUXSEL_GPIO) | ||
282 | #define MX23_PAD_GPMI_RDN__GPIO_0_25 MXS_IOMUX_PAD_NAKED(0, 25, PAD_MUXSEL_GPIO) | ||
283 | #define MX23_PAD_AUART1_CTS__GPIO_0_26 MXS_IOMUX_PAD_NAKED(0, 26, PAD_MUXSEL_GPIO) | ||
284 | #define MX23_PAD_AUART1_RTS__GPIO_0_27 MXS_IOMUX_PAD_NAKED(0, 27, PAD_MUXSEL_GPIO) | ||
285 | #define MX23_PAD_AUART1_RX__GPIO_0_28 MXS_IOMUX_PAD_NAKED(0, 28, PAD_MUXSEL_GPIO) | ||
286 | #define MX23_PAD_AUART1_TX__GPIO_0_29 MXS_IOMUX_PAD_NAKED(0, 29, PAD_MUXSEL_GPIO) | ||
287 | #define MX23_PAD_I2C_SCL__GPIO_0_30 MXS_IOMUX_PAD_NAKED(0, 30, PAD_MUXSEL_GPIO) | ||
288 | #define MX23_PAD_I2C_SDA__GPIO_0_31 MXS_IOMUX_PAD_NAKED(0, 31, PAD_MUXSEL_GPIO) | ||
289 | |||
290 | #define MX23_PAD_LCD_D00__GPIO_1_0 MXS_IOMUX_PAD_NAKED(1, 0, PAD_MUXSEL_GPIO) | ||
291 | #define MX23_PAD_LCD_D01__GPIO_1_1 MXS_IOMUX_PAD_NAKED(1, 1, PAD_MUXSEL_GPIO) | ||
292 | #define MX23_PAD_LCD_D02__GPIO_1_2 MXS_IOMUX_PAD_NAKED(1, 2, PAD_MUXSEL_GPIO) | ||
293 | #define MX23_PAD_LCD_D03__GPIO_1_3 MXS_IOMUX_PAD_NAKED(1, 3, PAD_MUXSEL_GPIO) | ||
294 | #define MX23_PAD_LCD_D04__GPIO_1_4 MXS_IOMUX_PAD_NAKED(1, 4, PAD_MUXSEL_GPIO) | ||
295 | #define MX23_PAD_LCD_D05__GPIO_1_5 MXS_IOMUX_PAD_NAKED(1, 5, PAD_MUXSEL_GPIO) | ||
296 | #define MX23_PAD_LCD_D06__GPIO_1_6 MXS_IOMUX_PAD_NAKED(1, 6, PAD_MUXSEL_GPIO) | ||
297 | #define MX23_PAD_LCD_D07__GPIO_1_7 MXS_IOMUX_PAD_NAKED(1, 7, PAD_MUXSEL_GPIO) | ||
298 | #define MX23_PAD_LCD_D08__GPIO_1_8 MXS_IOMUX_PAD_NAKED(1, 8, PAD_MUXSEL_GPIO) | ||
299 | #define MX23_PAD_LCD_D09__GPIO_1_9 MXS_IOMUX_PAD_NAKED(1, 9, PAD_MUXSEL_GPIO) | ||
300 | #define MX23_PAD_LCD_D10__GPIO_1_10 MXS_IOMUX_PAD_NAKED(1, 10, PAD_MUXSEL_GPIO) | ||
301 | #define MX23_PAD_LCD_D11__GPIO_1_11 MXS_IOMUX_PAD_NAKED(1, 11, PAD_MUXSEL_GPIO) | ||
302 | #define MX23_PAD_LCD_D12__GPIO_1_12 MXS_IOMUX_PAD_NAKED(1, 12, PAD_MUXSEL_GPIO) | ||
303 | #define MX23_PAD_LCD_D13__GPIO_1_13 MXS_IOMUX_PAD_NAKED(1, 13, PAD_MUXSEL_GPIO) | ||
304 | #define MX23_PAD_LCD_D14__GPIO_1_14 MXS_IOMUX_PAD_NAKED(1, 14, PAD_MUXSEL_GPIO) | ||
305 | #define MX23_PAD_LCD_D15__GPIO_1_15 MXS_IOMUX_PAD_NAKED(1, 15, PAD_MUXSEL_GPIO) | ||
306 | #define MX23_PAD_LCD_D16__GPIO_1_16 MXS_IOMUX_PAD_NAKED(1, 16, PAD_MUXSEL_GPIO) | ||
307 | #define MX23_PAD_LCD_D17__GPIO_1_17 MXS_IOMUX_PAD_NAKED(1, 17, PAD_MUXSEL_GPIO) | ||
308 | #define MX23_PAD_LCD_RESET__GPIO_1_18 MXS_IOMUX_PAD_NAKED(1, 18, PAD_MUXSEL_GPIO) | ||
309 | #define MX23_PAD_LCD_RS__GPIO_1_19 MXS_IOMUX_PAD_NAKED(1, 19, PAD_MUXSEL_GPIO) | ||
310 | #define MX23_PAD_LCD_WR__GPIO_1_20 MXS_IOMUX_PAD_NAKED(1, 20, PAD_MUXSEL_GPIO) | ||
311 | #define MX23_PAD_LCD_CS__GPIO_1_21 MXS_IOMUX_PAD_NAKED(1, 21, PAD_MUXSEL_GPIO) | ||
312 | #define MX23_PAD_LCD_DOTCK__GPIO_1_22 MXS_IOMUX_PAD_NAKED(1, 22, PAD_MUXSEL_GPIO) | ||
313 | #define MX23_PAD_LCD_ENABLE__GPIO_1_23 MXS_IOMUX_PAD_NAKED(1, 23, PAD_MUXSEL_GPIO) | ||
314 | #define MX23_PAD_LCD_HSYNC__GPIO_1_24 MXS_IOMUX_PAD_NAKED(1, 24, PAD_MUXSEL_GPIO) | ||
315 | #define MX23_PAD_LCD_VSYNC__GPIO_1_25 MXS_IOMUX_PAD_NAKED(1, 25, PAD_MUXSEL_GPIO) | ||
316 | #define MX23_PAD_PWM0__GPIO_1_26 MXS_IOMUX_PAD_NAKED(1, 26, PAD_MUXSEL_GPIO) | ||
317 | #define MX23_PAD_PWM1__GPIO_1_27 MXS_IOMUX_PAD_NAKED(1, 27, PAD_MUXSEL_GPIO) | ||
318 | #define MX23_PAD_PWM2__GPIO_1_28 MXS_IOMUX_PAD_NAKED(1, 28, PAD_MUXSEL_GPIO) | ||
319 | #define MX23_PAD_PWM3__GPIO_1_29 MXS_IOMUX_PAD_NAKED(1, 29, PAD_MUXSEL_GPIO) | ||
320 | #define MX23_PAD_PWM4__GPIO_1_30 MXS_IOMUX_PAD_NAKED(1, 30, PAD_MUXSEL_GPIO) | ||
321 | |||
322 | #define MX23_PAD_SSP1_CMD__GPIO_2_0 MXS_IOMUX_PAD_NAKED(2, 0, PAD_MUXSEL_GPIO) | ||
323 | #define MX23_PAD_SSP1_DETECT__GPIO_2_1 MXS_IOMUX_PAD_NAKED(2, 1, PAD_MUXSEL_GPIO) | ||
324 | #define MX23_PAD_SSP1_DATA0__GPIO_2_2 MXS_IOMUX_PAD_NAKED(2, 2, PAD_MUXSEL_GPIO) | ||
325 | #define MX23_PAD_SSP1_DATA1__GPIO_2_3 MXS_IOMUX_PAD_NAKED(2, 3, PAD_MUXSEL_GPIO) | ||
326 | #define MX23_PAD_SSP1_DATA2__GPIO_2_4 MXS_IOMUX_PAD_NAKED(2, 4, PAD_MUXSEL_GPIO) | ||
327 | #define MX23_PAD_SSP1_DATA3__GPIO_2_5 MXS_IOMUX_PAD_NAKED(2, 5, PAD_MUXSEL_GPIO) | ||
328 | #define MX23_PAD_SSP1_SCK__GPIO_2_6 MXS_IOMUX_PAD_NAKED(2, 6, PAD_MUXSEL_GPIO) | ||
329 | #define MX23_PAD_ROTARYA__GPIO_2_7 MXS_IOMUX_PAD_NAKED(2, 7, PAD_MUXSEL_GPIO) | ||
330 | #define MX23_PAD_ROTARYB__GPIO_2_8 MXS_IOMUX_PAD_NAKED(2, 8, PAD_MUXSEL_GPIO) | ||
331 | #define MX23_PAD_EMI_A00__GPIO_2_9 MXS_IOMUX_PAD_NAKED(2, 9, PAD_MUXSEL_GPIO) | ||
332 | #define MX23_PAD_EMI_A01__GPIO_2_10 MXS_IOMUX_PAD_NAKED(2, 10, PAD_MUXSEL_GPIO) | ||
333 | #define MX23_PAD_EMI_A02__GPIO_2_11 MXS_IOMUX_PAD_NAKED(2, 11, PAD_MUXSEL_GPIO) | ||
334 | #define MX23_PAD_EMI_A03__GPIO_2_12 MXS_IOMUX_PAD_NAKED(2, 12, PAD_MUXSEL_GPIO) | ||
335 | #define MX23_PAD_EMI_A04__GPIO_2_13 MXS_IOMUX_PAD_NAKED(2, 13, PAD_MUXSEL_GPIO) | ||
336 | #define MX23_PAD_EMI_A05__GPIO_2_14 MXS_IOMUX_PAD_NAKED(2, 14, PAD_MUXSEL_GPIO) | ||
337 | #define MX23_PAD_EMI_A06__GPIO_2_15 MXS_IOMUX_PAD_NAKED(2, 15, PAD_MUXSEL_GPIO) | ||
338 | #define MX23_PAD_EMI_A07__GPIO_2_16 MXS_IOMUX_PAD_NAKED(2, 16, PAD_MUXSEL_GPIO) | ||
339 | #define MX23_PAD_EMI_A08__GPIO_2_17 MXS_IOMUX_PAD_NAKED(2, 17, PAD_MUXSEL_GPIO) | ||
340 | #define MX23_PAD_EMI_A09__GPIO_2_18 MXS_IOMUX_PAD_NAKED(2, 18, PAD_MUXSEL_GPIO) | ||
341 | #define MX23_PAD_EMI_A10__GPIO_2_19 MXS_IOMUX_PAD_NAKED(2, 19, PAD_MUXSEL_GPIO) | ||
342 | #define MX23_PAD_EMI_A11__GPIO_2_20 MXS_IOMUX_PAD_NAKED(2, 20, PAD_MUXSEL_GPIO) | ||
343 | #define MX23_PAD_EMI_A12__GPIO_2_21 MXS_IOMUX_PAD_NAKED(2, 21, PAD_MUXSEL_GPIO) | ||
344 | #define MX23_PAD_EMI_BA0__GPIO_2_22 MXS_IOMUX_PAD_NAKED(2, 22, PAD_MUXSEL_GPIO) | ||
345 | #define MX23_PAD_EMI_BA1__GPIO_2_23 MXS_IOMUX_PAD_NAKED(2, 23, PAD_MUXSEL_GPIO) | ||
346 | #define MX23_PAD_EMI_CASN__GPIO_2_24 MXS_IOMUX_PAD_NAKED(2, 24, PAD_MUXSEL_GPIO) | ||
347 | #define MX23_PAD_EMI_CE0N__GPIO_2_25 MXS_IOMUX_PAD_NAKED(2, 25, PAD_MUXSEL_GPIO) | ||
348 | #define MX23_PAD_EMI_CE1N__GPIO_2_26 MXS_IOMUX_PAD_NAKED(2, 26, PAD_MUXSEL_GPIO) | ||
349 | #define MX23_PAD_GPMI_CE1N__GPIO_2_27 MXS_IOMUX_PAD_NAKED(2, 27, PAD_MUXSEL_GPIO) | ||
350 | #define MX23_PAD_GPMI_CE0N__GPIO_2_28 MXS_IOMUX_PAD_NAKED(2, 28, PAD_MUXSEL_GPIO) | ||
351 | #define MX23_PAD_EMI_CKE__GPIO_2_29 MXS_IOMUX_PAD_NAKED(2, 29, PAD_MUXSEL_GPIO) | ||
352 | #define MX23_PAD_EMI_RASN__GPIO_2_30 MXS_IOMUX_PAD_NAKED(2, 30, PAD_MUXSEL_GPIO) | ||
353 | #define MX23_PAD_EMI_WEN__GPIO_2_31 MXS_IOMUX_PAD_NAKED(2, 31, PAD_MUXSEL_GPIO) | ||
354 | |||
355 | #endif /* __MACH_IOMUX_MX23_H__ */ | ||
diff --git a/arch/arm/mach-mxs/include/mach/iomux-mx28.h b/arch/arm/mach-mxs/include/mach/iomux-mx28.h new file mode 100644 index 00000000000..f50fefd1052 --- /dev/null +++ b/arch/arm/mach-mxs/include/mach/iomux-mx28.h | |||
@@ -0,0 +1,537 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2009-2010 Amit Kucheria <amit.kucheria@canonical.com> | ||
3 | * Copyright (C) 2010 Freescale Semiconductor, Inc. | ||
4 | * | ||
5 | * The code contained herein is licensed under the GNU General Public | ||
6 | * License. You may obtain a copy of the GNU General Public License | ||
7 | * Version 2 or later at the following locations: | ||
8 | * | ||
9 | * http://www.opensource.org/licenses/gpl-license.html | ||
10 | * http://www.gnu.org/copyleft/gpl.html | ||
11 | */ | ||
12 | |||
13 | #ifndef __MACH_IOMUX_MX28_H__ | ||
14 | #define __MACH_IOMUX_MX28_H__ | ||
15 | |||
16 | #include <mach/iomux.h> | ||
17 | |||
18 | /* | ||
19 | * The naming convention for the pad modes is MX28_PAD_<padname>__<padmode> | ||
20 | * If <padname> or <padmode> refers to a GPIO, it is named GPIO_<unit>_<num> | ||
21 | * See also iomux.h | ||
22 | * | ||
23 | * BANK PIN MUX | ||
24 | */ | ||
25 | /* MUXSEL_0 */ | ||
26 | #define MX28_PAD_GPMI_D00__GPMI_D0 MXS_IOMUX_PAD_NAKED(0, 0, PAD_MUXSEL_0) | ||
27 | #define MX28_PAD_GPMI_D01__GPMI_D1 MXS_IOMUX_PAD_NAKED(0, 1, PAD_MUXSEL_0) | ||
28 | #define MX28_PAD_GPMI_D02__GPMI_D2 MXS_IOMUX_PAD_NAKED(0, 2, PAD_MUXSEL_0) | ||
29 | #define MX28_PAD_GPMI_D03__GPMI_D3 MXS_IOMUX_PAD_NAKED(0, 3, PAD_MUXSEL_0) | ||
30 | #define MX28_PAD_GPMI_D04__GPMI_D4 MXS_IOMUX_PAD_NAKED(0, 4, PAD_MUXSEL_0) | ||
31 | #define MX28_PAD_GPMI_D05__GPMI_D5 MXS_IOMUX_PAD_NAKED(0, 5, PAD_MUXSEL_0) | ||
32 | #define MX28_PAD_GPMI_D06__GPMI_D6 MXS_IOMUX_PAD_NAKED(0, 6, PAD_MUXSEL_0) | ||
33 | #define MX28_PAD_GPMI_D07__GPMI_D7 MXS_IOMUX_PAD_NAKED(0, 7, PAD_MUXSEL_0) | ||
34 | #define MX28_PAD_GPMI_CE0N__GPMI_CE0N MXS_IOMUX_PAD_NAKED(0, 16, PAD_MUXSEL_0) | ||
35 | #define MX28_PAD_GPMI_CE1N__GPMI_CE1N MXS_IOMUX_PAD_NAKED(0, 17, PAD_MUXSEL_0) | ||
36 | #define MX28_PAD_GPMI_CE2N__GPMI_CE2N MXS_IOMUX_PAD_NAKED(0, 18, PAD_MUXSEL_0) | ||
37 | #define MX28_PAD_GPMI_CE3N__GPMI_CE3N MXS_IOMUX_PAD_NAKED(0, 19, PAD_MUXSEL_0) | ||
38 | #define MX28_PAD_GPMI_RDY0__GPMI_READY0 MXS_IOMUX_PAD_NAKED(0, 20, PAD_MUXSEL_0) | ||
39 | #define MX28_PAD_GPMI_RDY1__GPMI_READY1 MXS_IOMUX_PAD_NAKED(0, 21, PAD_MUXSEL_0) | ||
40 | #define MX28_PAD_GPMI_RDY2__GPMI_READY2 MXS_IOMUX_PAD_NAKED(0, 22, PAD_MUXSEL_0) | ||
41 | #define MX28_PAD_GPMI_RDY3__GPMI_READY3 MXS_IOMUX_PAD_NAKED(0, 23, PAD_MUXSEL_0) | ||
42 | #define MX28_PAD_GPMI_RDN__GPMI_RDN MXS_IOMUX_PAD_NAKED(0, 24, PAD_MUXSEL_0) | ||
43 | #define MX28_PAD_GPMI_WRN__GPMI_WRN MXS_IOMUX_PAD_NAKED(0, 25, PAD_MUXSEL_0) | ||
44 | #define MX28_PAD_GPMI_ALE__GPMI_ALE MXS_IOMUX_PAD_NAKED(0, 26, PAD_MUXSEL_0) | ||
45 | #define MX28_PAD_GPMI_CLE__GPMI_CLE MXS_IOMUX_PAD_NAKED(0, 27, PAD_MUXSEL_0) | ||
46 | #define MX28_PAD_GPMI_RESETN__GPMI_RESETN MXS_IOMUX_PAD_NAKED(0, 28, PAD_MUXSEL_0) | ||
47 | |||
48 | #define MX28_PAD_LCD_D00__LCD_D0 MXS_IOMUX_PAD_NAKED(1, 0, PAD_MUXSEL_0) | ||
49 | #define MX28_PAD_LCD_D01__LCD_D1 MXS_IOMUX_PAD_NAKED(1, 1, PAD_MUXSEL_0) | ||
50 | #define MX28_PAD_LCD_D02__LCD_D2 MXS_IOMUX_PAD_NAKED(1, 2, PAD_MUXSEL_0) | ||
51 | #define MX28_PAD_LCD_D03__LCD_D3 MXS_IOMUX_PAD_NAKED(1, 3, PAD_MUXSEL_0) | ||
52 | #define MX28_PAD_LCD_D04__LCD_D4 MXS_IOMUX_PAD_NAKED(1, 4, PAD_MUXSEL_0) | ||
53 | #define MX28_PAD_LCD_D05__LCD_D5 MXS_IOMUX_PAD_NAKED(1, 5, PAD_MUXSEL_0) | ||
54 | #define MX28_PAD_LCD_D06__LCD_D6 MXS_IOMUX_PAD_NAKED(1, 6, PAD_MUXSEL_0) | ||
55 | #define MX28_PAD_LCD_D07__LCD_D7 MXS_IOMUX_PAD_NAKED(1, 7, PAD_MUXSEL_0) | ||
56 | #define MX28_PAD_LCD_D08__LCD_D8 MXS_IOMUX_PAD_NAKED(1, 8, PAD_MUXSEL_0) | ||
57 | #define MX28_PAD_LCD_D09__LCD_D9 MXS_IOMUX_PAD_NAKED(1, 9, PAD_MUXSEL_0) | ||
58 | #define MX28_PAD_LCD_D10__LCD_D10 MXS_IOMUX_PAD_NAKED(1, 10, PAD_MUXSEL_0) | ||
59 | #define MX28_PAD_LCD_D11__LCD_D11 MXS_IOMUX_PAD_NAKED(1, 11, PAD_MUXSEL_0) | ||
60 | #define MX28_PAD_LCD_D12__LCD_D12 MXS_IOMUX_PAD_NAKED(1, 12, PAD_MUXSEL_0) | ||
61 | #define MX28_PAD_LCD_D13__LCD_D13 MXS_IOMUX_PAD_NAKED(1, 13, PAD_MUXSEL_0) | ||
62 | #define MX28_PAD_LCD_D14__LCD_D14 MXS_IOMUX_PAD_NAKED(1, 14, PAD_MUXSEL_0) | ||
63 | #define MX28_PAD_LCD_D15__LCD_D15 MXS_IOMUX_PAD_NAKED(1, 15, PAD_MUXSEL_0) | ||
64 | #define MX28_PAD_LCD_D16__LCD_D16 MXS_IOMUX_PAD_NAKED(1, 16, PAD_MUXSEL_0) | ||
65 | #define MX28_PAD_LCD_D17__LCD_D17 MXS_IOMUX_PAD_NAKED(1, 17, PAD_MUXSEL_0) | ||
66 | #define MX28_PAD_LCD_D18__LCD_D18 MXS_IOMUX_PAD_NAKED(1, 18, PAD_MUXSEL_0) | ||
67 | #define MX28_PAD_LCD_D19__LCD_D19 MXS_IOMUX_PAD_NAKED(1, 19, PAD_MUXSEL_0) | ||
68 | #define MX28_PAD_LCD_D20__LCD_D20 MXS_IOMUX_PAD_NAKED(1, 20, PAD_MUXSEL_0) | ||
69 | #define MX28_PAD_LCD_D21__LCD_D21 MXS_IOMUX_PAD_NAKED(1, 21, PAD_MUXSEL_0) | ||
70 | #define MX28_PAD_LCD_D22__LCD_D22 MXS_IOMUX_PAD_NAKED(1, 22, PAD_MUXSEL_0) | ||
71 | #define MX28_PAD_LCD_D23__LCD_D23 MXS_IOMUX_PAD_NAKED(1, 23, PAD_MUXSEL_0) | ||
72 | #define MX28_PAD_LCD_RD_E__LCD_RD_E MXS_IOMUX_PAD_NAKED(1, 24, PAD_MUXSEL_0) | ||
73 | #define MX28_PAD_LCD_WR_RWN__LCD_WR_RWN MXS_IOMUX_PAD_NAKED(1, 25, PAD_MUXSEL_0) | ||
74 | #define MX28_PAD_LCD_RS__LCD_RS MXS_IOMUX_PAD_NAKED(1, 26, PAD_MUXSEL_0) | ||
75 | #define MX28_PAD_LCD_CS__LCD_CS MXS_IOMUX_PAD_NAKED(1, 27, PAD_MUXSEL_0) | ||
76 | #define MX28_PAD_LCD_VSYNC__LCD_VSYNC MXS_IOMUX_PAD_NAKED(1, 28, PAD_MUXSEL_0) | ||
77 | #define MX28_PAD_LCD_HSYNC__LCD_HSYNC MXS_IOMUX_PAD_NAKED(1, 29, PAD_MUXSEL_0) | ||
78 | #define MX28_PAD_LCD_DOTCLK__LCD_DOTCLK MXS_IOMUX_PAD_NAKED(1, 30, PAD_MUXSEL_0) | ||
79 | #define MX28_PAD_LCD_ENABLE__LCD_ENABLE MXS_IOMUX_PAD_NAKED(1, 31, PAD_MUXSEL_0) | ||
80 | |||
81 | #define MX28_PAD_SSP0_DATA0__SSP0_D0 MXS_IOMUX_PAD_NAKED(2, 0, PAD_MUXSEL_0) | ||
82 | #define MX28_PAD_SSP0_DATA1__SSP0_D1 MXS_IOMUX_PAD_NAKED(2, 1, PAD_MUXSEL_0) | ||
83 | #define MX28_PAD_SSP0_DATA2__SSP0_D2 MXS_IOMUX_PAD_NAKED(2, 2, PAD_MUXSEL_0) | ||
84 | #define MX28_PAD_SSP0_DATA3__SSP0_D3 MXS_IOMUX_PAD_NAKED(2, 3, PAD_MUXSEL_0) | ||
85 | #define MX28_PAD_SSP0_DATA4__SSP0_D4 MXS_IOMUX_PAD_NAKED(2, 4, PAD_MUXSEL_0) | ||
86 | #define MX28_PAD_SSP0_DATA5__SSP0_D5 MXS_IOMUX_PAD_NAKED(2, 5, PAD_MUXSEL_0) | ||
87 | #define MX28_PAD_SSP0_DATA6__SSP0_D6 MXS_IOMUX_PAD_NAKED(2, 6, PAD_MUXSEL_0) | ||
88 | #define MX28_PAD_SSP0_DATA7__SSP0_D7 MXS_IOMUX_PAD_NAKED(2, 7, PAD_MUXSEL_0) | ||
89 | #define MX28_PAD_SSP0_CMD__SSP0_CMD MXS_IOMUX_PAD_NAKED(2, 8, PAD_MUXSEL_0) | ||
90 | #define MX28_PAD_SSP0_DETECT__SSP0_CARD_DETECT MXS_IOMUX_PAD_NAKED(2, 9, PAD_MUXSEL_0) | ||
91 | #define MX28_PAD_SSP0_SCK__SSP0_SCK MXS_IOMUX_PAD_NAKED(2, 10, PAD_MUXSEL_0) | ||
92 | #define MX28_PAD_SSP1_SCK__SSP1_SCK MXS_IOMUX_PAD_NAKED(2, 12, PAD_MUXSEL_0) | ||
93 | #define MX28_PAD_SSP1_CMD__SSP1_CMD MXS_IOMUX_PAD_NAKED(2, 13, PAD_MUXSEL_0) | ||
94 | #define MX28_PAD_SSP1_DATA0__SSP1_D0 MXS_IOMUX_PAD_NAKED(2, 14, PAD_MUXSEL_0) | ||
95 | #define MX28_PAD_SSP1_DATA3__SSP1_D3 MXS_IOMUX_PAD_NAKED(2, 15, PAD_MUXSEL_0) | ||
96 | #define MX28_PAD_SSP2_SCK__SSP2_SCK MXS_IOMUX_PAD_NAKED(2, 16, PAD_MUXSEL_0) | ||
97 | #define MX28_PAD_SSP2_MOSI__SSP2_CMD MXS_IOMUX_PAD_NAKED(2, 17, PAD_MUXSEL_0) | ||
98 | #define MX28_PAD_SSP2_MISO__SSP2_D0 MXS_IOMUX_PAD_NAKED(2, 18, PAD_MUXSEL_0) | ||
99 | #define MX28_PAD_SSP2_SS0__SSP2_D3 MXS_IOMUX_PAD_NAKED(2, 19, PAD_MUXSEL_0) | ||
100 | #define MX28_PAD_SSP2_SS1__SSP2_D4 MXS_IOMUX_PAD_NAKED(2, 20, PAD_MUXSEL_0) | ||
101 | #define MX28_PAD_SSP2_SS2__SSP2_D5 MXS_IOMUX_PAD_NAKED(2, 21, PAD_MUXSEL_0) | ||
102 | #define MX28_PAD_SSP3_SCK__SSP3_SCK MXS_IOMUX_PAD_NAKED(2, 24, PAD_MUXSEL_0) | ||
103 | #define MX28_PAD_SSP3_MOSI__SSP3_CMD MXS_IOMUX_PAD_NAKED(2, 25, PAD_MUXSEL_0) | ||
104 | #define MX28_PAD_SSP3_MISO__SSP3_D0 MXS_IOMUX_PAD_NAKED(2, 26, PAD_MUXSEL_0) | ||
105 | #define MX28_PAD_SSP3_SS0__SSP3_D3 MXS_IOMUX_PAD_NAKED(2, 27, PAD_MUXSEL_0) | ||
106 | |||
107 | #define MX28_PAD_AUART0_RX__AUART0_RX MXS_IOMUX_PAD_NAKED(3, 0, PAD_MUXSEL_0) | ||
108 | #define MX28_PAD_AUART0_TX__AUART0_TX MXS_IOMUX_PAD_NAKED(3, 1, PAD_MUXSEL_0) | ||
109 | #define MX28_PAD_AUART0_CTS__AUART0_CTS MXS_IOMUX_PAD_NAKED(3, 2, PAD_MUXSEL_0) | ||
110 | #define MX28_PAD_AUART0_RTS__AUART0_RTS MXS_IOMUX_PAD_NAKED(3, 3, PAD_MUXSEL_0) | ||
111 | #define MX28_PAD_AUART1_RX__AUART1_RX MXS_IOMUX_PAD_NAKED(3, 4, PAD_MUXSEL_0) | ||
112 | #define MX28_PAD_AUART1_TX__AUART1_TX MXS_IOMUX_PAD_NAKED(3, 5, PAD_MUXSEL_0) | ||
113 | #define MX28_PAD_AUART1_CTS__AUART1_CTS MXS_IOMUX_PAD_NAKED(3, 6, PAD_MUXSEL_0) | ||
114 | #define MX28_PAD_AUART1_RTS__AUART1_RTS MXS_IOMUX_PAD_NAKED(3, 7, PAD_MUXSEL_0) | ||
115 | #define MX28_PAD_AUART2_RX__AUART2_RX MXS_IOMUX_PAD_NAKED(3, 8, PAD_MUXSEL_0) | ||
116 | #define MX28_PAD_AUART2_TX__AUART2_TX MXS_IOMUX_PAD_NAKED(3, 9, PAD_MUXSEL_0) | ||
117 | #define MX28_PAD_AUART2_CTS__AUART2_CTS MXS_IOMUX_PAD_NAKED(3, 10, PAD_MUXSEL_0) | ||
118 | #define MX28_PAD_AUART2_RTS__AUART2_RTS MXS_IOMUX_PAD_NAKED(3, 11, PAD_MUXSEL_0) | ||
119 | #define MX28_PAD_AUART3_RX__AUART3_RX MXS_IOMUX_PAD_NAKED(3, 12, PAD_MUXSEL_0) | ||
120 | #define MX28_PAD_AUART3_TX__AUART3_TX MXS_IOMUX_PAD_NAKED(3, 13, PAD_MUXSEL_0) | ||
121 | #define MX28_PAD_AUART3_CTS__AUART3_CTS MXS_IOMUX_PAD_NAKED(3, 14, PAD_MUXSEL_0) | ||
122 | #define MX28_PAD_AUART3_RTS__AUART3_RTS MXS_IOMUX_PAD_NAKED(3, 15, PAD_MUXSEL_0) | ||
123 | #define MX28_PAD_PWM0__PWM_0 MXS_IOMUX_PAD_NAKED(3, 16, PAD_MUXSEL_0) | ||
124 | #define MX28_PAD_PWM1__PWM_1 MXS_IOMUX_PAD_NAKED(3, 17, PAD_MUXSEL_0) | ||
125 | #define MX28_PAD_PWM2__PWM_2 MXS_IOMUX_PAD_NAKED(3, 18, PAD_MUXSEL_0) | ||
126 | #define MX28_PAD_SAIF0_MCLK__SAIF0_MCLK MXS_IOMUX_PAD_NAKED(3, 20, PAD_MUXSEL_0) | ||
127 | #define MX28_PAD_SAIF0_LRCLK__SAIF0_LRCLK MXS_IOMUX_PAD_NAKED(3, 21, PAD_MUXSEL_0) | ||
128 | #define MX28_PAD_SAIF0_BITCLK__SAIF0_BITCLK MXS_IOMUX_PAD_NAKED(3, 22, PAD_MUXSEL_0) | ||
129 | #define MX28_PAD_SAIF0_SDATA0__SAIF0_SDATA0 MXS_IOMUX_PAD_NAKED(3, 23, PAD_MUXSEL_0) | ||
130 | #define MX28_PAD_I2C0_SCL__I2C0_SCL MXS_IOMUX_PAD_NAKED(3, 24, PAD_MUXSEL_0) | ||
131 | #define MX28_PAD_I2C0_SDA__I2C0_SDA MXS_IOMUX_PAD_NAKED(3, 25, PAD_MUXSEL_0) | ||
132 | #define MX28_PAD_SAIF1_SDATA0__SAIF1_SDATA0 MXS_IOMUX_PAD_NAKED(3, 26, PAD_MUXSEL_0) | ||
133 | #define MX28_PAD_SPDIF__SPDIF_TX MXS_IOMUX_PAD_NAKED(3, 27, PAD_MUXSEL_0) | ||
134 | #define MX28_PAD_PWM3__PWM_3 MXS_IOMUX_PAD_NAKED(3, 28, PAD_MUXSEL_0) | ||
135 | #define MX28_PAD_PWM4__PWM_4 MXS_IOMUX_PAD_NAKED(3, 29, PAD_MUXSEL_0) | ||
136 | #define MX28_PAD_LCD_RESET__LCD_RESET MXS_IOMUX_PAD_NAKED(3, 30, PAD_MUXSEL_0) | ||
137 | |||
138 | #define MX28_PAD_ENET0_MDC__ENET0_MDC MXS_IOMUX_PAD_NAKED(4, 0, PAD_MUXSEL_0) | ||
139 | #define MX28_PAD_ENET0_MDIO__ENET0_MDIO MXS_IOMUX_PAD_NAKED(4, 1, PAD_MUXSEL_0) | ||
140 | #define MX28_PAD_ENET0_RX_EN__ENET0_RX_EN MXS_IOMUX_PAD_NAKED(4, 2, PAD_MUXSEL_0) | ||
141 | #define MX28_PAD_ENET0_RXD0__ENET0_RXD0 MXS_IOMUX_PAD_NAKED(4, 3, PAD_MUXSEL_0) | ||
142 | #define MX28_PAD_ENET0_RXD1__ENET0_RXD1 MXS_IOMUX_PAD_NAKED(4, 4, PAD_MUXSEL_0) | ||
143 | #define MX28_PAD_ENET0_TX_CLK__ENET0_TX_CLK MXS_IOMUX_PAD_NAKED(4, 5, PAD_MUXSEL_0) | ||
144 | #define MX28_PAD_ENET0_TX_EN__ENET0_TX_EN MXS_IOMUX_PAD_NAKED(4, 6, PAD_MUXSEL_0) | ||
145 | #define MX28_PAD_ENET0_TXD0__ENET0_TXD0 MXS_IOMUX_PAD_NAKED(4, 7, PAD_MUXSEL_0) | ||
146 | #define MX28_PAD_ENET0_TXD1__ENET0_TXD1 MXS_IOMUX_PAD_NAKED(4, 8, PAD_MUXSEL_0) | ||
147 | #define MX28_PAD_ENET0_RXD2__ENET0_RXD2 MXS_IOMUX_PAD_NAKED(4, 9, PAD_MUXSEL_0) | ||
148 | #define MX28_PAD_ENET0_RXD3__ENET0_RXD3 MXS_IOMUX_PAD_NAKED(4, 10, PAD_MUXSEL_0) | ||
149 | #define MX28_PAD_ENET0_TXD2__ENET0_TXD2 MXS_IOMUX_PAD_NAKED(4, 11, PAD_MUXSEL_0) | ||
150 | #define MX28_PAD_ENET0_TXD3__ENET0_TXD3 MXS_IOMUX_PAD_NAKED(4, 12, PAD_MUXSEL_0) | ||
151 | #define MX28_PAD_ENET0_RX_CLK__ENET0_RX_CLK MXS_IOMUX_PAD_NAKED(4, 13, PAD_MUXSEL_0) | ||
152 | #define MX28_PAD_ENET0_COL__ENET0_COL MXS_IOMUX_PAD_NAKED(4, 14, PAD_MUXSEL_0) | ||
153 | #define MX28_PAD_ENET0_CRS__ENET0_CRS MXS_IOMUX_PAD_NAKED(4, 15, PAD_MUXSEL_0) | ||
154 | #define MX28_PAD_ENET_CLK__CLKCTRL_ENET MXS_IOMUX_PAD_NAKED(4, 16, PAD_MUXSEL_0) | ||
155 | #define MX28_PAD_JTAG_RTCK__JTAG_RTCK MXS_IOMUX_PAD_NAKED(4, 20, PAD_MUXSEL_0) | ||
156 | |||
157 | #define MX28_PAD_EMI_D00__EMI_DATA0 MXS_IOMUX_PAD_NAKED(5, 0, PAD_MUXSEL_0) | ||
158 | #define MX28_PAD_EMI_D01__EMI_DATA1 MXS_IOMUX_PAD_NAKED(5, 1, PAD_MUXSEL_0) | ||
159 | #define MX28_PAD_EMI_D02__EMI_DATA2 MXS_IOMUX_PAD_NAKED(5, 2, PAD_MUXSEL_0) | ||
160 | #define MX28_PAD_EMI_D03__EMI_DATA3 MXS_IOMUX_PAD_NAKED(5, 3, PAD_MUXSEL_0) | ||
161 | #define MX28_PAD_EMI_D04__EMI_DATA4 MXS_IOMUX_PAD_NAKED(5, 4, PAD_MUXSEL_0) | ||
162 | #define MX28_PAD_EMI_D05__EMI_DATA5 MXS_IOMUX_PAD_NAKED(5, 5, PAD_MUXSEL_0) | ||
163 | #define MX28_PAD_EMI_D06__EMI_DATA6 MXS_IOMUX_PAD_NAKED(5, 6, PAD_MUXSEL_0) | ||
164 | #define MX28_PAD_EMI_D07__EMI_DATA7 MXS_IOMUX_PAD_NAKED(5, 7, PAD_MUXSEL_0) | ||
165 | #define MX28_PAD_EMI_D08__EMI_DATA8 MXS_IOMUX_PAD_NAKED(5, 8, PAD_MUXSEL_0) | ||
166 | #define MX28_PAD_EMI_D09__EMI_DATA9 MXS_IOMUX_PAD_NAKED(5, 9, PAD_MUXSEL_0) | ||
167 | #define MX28_PAD_EMI_D10__EMI_DATA10 MXS_IOMUX_PAD_NAKED(5, 10, PAD_MUXSEL_0) | ||
168 | #define MX28_PAD_EMI_D11__EMI_DATA11 MXS_IOMUX_PAD_NAKED(5, 11, PAD_MUXSEL_0) | ||
169 | #define MX28_PAD_EMI_D12__EMI_DATA12 MXS_IOMUX_PAD_NAKED(5, 12, PAD_MUXSEL_0) | ||
170 | #define MX28_PAD_EMI_D13__EMI_DATA13 MXS_IOMUX_PAD_NAKED(5, 13, PAD_MUXSEL_0) | ||
171 | #define MX28_PAD_EMI_D14__EMI_DATA14 MXS_IOMUX_PAD_NAKED(5, 14, PAD_MUXSEL_0) | ||
172 | #define MX28_PAD_EMI_D15__EMI_DATA15 MXS_IOMUX_PAD_NAKED(5, 15, PAD_MUXSEL_0) | ||
173 | #define MX28_PAD_EMI_ODT0__EMI_ODT0 MXS_IOMUX_PAD_NAKED(5, 16, PAD_MUXSEL_0) | ||
174 | #define MX28_PAD_EMI_DQM0__EMI_DQM0 MXS_IOMUX_PAD_NAKED(5, 17, PAD_MUXSEL_0) | ||
175 | #define MX28_PAD_EMI_ODT1__EMI_ODT1 MXS_IOMUX_PAD_NAKED(5, 18, PAD_MUXSEL_0) | ||
176 | #define MX28_PAD_EMI_DQM1__EMI_DQM1 MXS_IOMUX_PAD_NAKED(5, 19, PAD_MUXSEL_0) | ||
177 | #define MX28_PAD_EMI_DDR_OPEN_FB__EMI_DDR_OPEN_FEEDBACK MXS_IOMUX_PAD_NAKED(5, 20, PAD_MUXSEL_0) | ||
178 | #define MX28_PAD_EMI_CLK__EMI_CLK MXS_IOMUX_PAD_NAKED(5, 21, PAD_MUXSEL_0) | ||
179 | #define MX28_PAD_EMI_DQS0__EMI_DQS0 MXS_IOMUX_PAD_NAKED(5, 22, PAD_MUXSEL_0) | ||
180 | #define MX28_PAD_EMI_DQS1__EMI_DQS1 MXS_IOMUX_PAD_NAKED(5, 23, PAD_MUXSEL_0) | ||
181 | #define MX28_PAD_EMI_DDR_OPEN__EMI_DDR_OPEN MXS_IOMUX_PAD_NAKED(5, 26, PAD_MUXSEL_0) | ||
182 | |||
183 | #define MX28_PAD_EMI_A00__EMI_ADDR0 MXS_IOMUX_PAD_NAKED(6, 0, PAD_MUXSEL_0) | ||
184 | #define MX28_PAD_EMI_A01__EMI_ADDR1 MXS_IOMUX_PAD_NAKED(6, 1, PAD_MUXSEL_0) | ||
185 | #define MX28_PAD_EMI_A02__EMI_ADDR2 MXS_IOMUX_PAD_NAKED(6, 2, PAD_MUXSEL_0) | ||
186 | #define MX28_PAD_EMI_A03__EMI_ADDR3 MXS_IOMUX_PAD_NAKED(6, 3, PAD_MUXSEL_0) | ||
187 | #define MX28_PAD_EMI_A04__EMI_ADDR4 MXS_IOMUX_PAD_NAKED(6, 4, PAD_MUXSEL_0) | ||
188 | #define MX28_PAD_EMI_A05__EMI_ADDR5 MXS_IOMUX_PAD_NAKED(6, 5, PAD_MUXSEL_0) | ||
189 | #define MX28_PAD_EMI_A06__EMI_ADDR6 MXS_IOMUX_PAD_NAKED(6, 6, PAD_MUXSEL_0) | ||
190 | #define MX28_PAD_EMI_A07__EMI_ADDR7 MXS_IOMUX_PAD_NAKED(6, 7, PAD_MUXSEL_0) | ||
191 | #define MX28_PAD_EMI_A08__EMI_ADDR8 MXS_IOMUX_PAD_NAKED(6, 8, PAD_MUXSEL_0) | ||
192 | #define MX28_PAD_EMI_A09__EMI_ADDR9 MXS_IOMUX_PAD_NAKED(6, 9, PAD_MUXSEL_0) | ||
193 | #define MX28_PAD_EMI_A10__EMI_ADDR10 MXS_IOMUX_PAD_NAKED(6, 10, PAD_MUXSEL_0) | ||
194 | #define MX28_PAD_EMI_A11__EMI_ADDR11 MXS_IOMUX_PAD_NAKED(6, 11, PAD_MUXSEL_0) | ||
195 | #define MX28_PAD_EMI_A12__EMI_ADDR12 MXS_IOMUX_PAD_NAKED(6, 12, PAD_MUXSEL_0) | ||
196 | #define MX28_PAD_EMI_A13__EMI_ADDR13 MXS_IOMUX_PAD_NAKED(6, 13, PAD_MUXSEL_0) | ||
197 | #define MX28_PAD_EMI_A14__EMI_ADDR14 MXS_IOMUX_PAD_NAKED(6, 14, PAD_MUXSEL_0) | ||
198 | #define MX28_PAD_EMI_BA0__EMI_BA0 MXS_IOMUX_PAD_NAKED(6, 16, PAD_MUXSEL_0) | ||
199 | #define MX28_PAD_EMI_BA1__EMI_BA1 MXS_IOMUX_PAD_NAKED(6, 17, PAD_MUXSEL_0) | ||
200 | #define MX28_PAD_EMI_BA2__EMI_BA2 MXS_IOMUX_PAD_NAKED(6, 18, PAD_MUXSEL_0) | ||
201 | #define MX28_PAD_EMI_CASN__EMI_CASN MXS_IOMUX_PAD_NAKED(6, 19, PAD_MUXSEL_0) | ||
202 | #define MX28_PAD_EMI_RASN__EMI_RASN MXS_IOMUX_PAD_NAKED(6, 20, PAD_MUXSEL_0) | ||
203 | #define MX28_PAD_EMI_WEN__EMI_WEN MXS_IOMUX_PAD_NAKED(6, 21, PAD_MUXSEL_0) | ||
204 | #define MX28_PAD_EMI_CE0N__EMI_CE0N MXS_IOMUX_PAD_NAKED(6, 22, PAD_MUXSEL_0) | ||
205 | #define MX28_PAD_EMI_CE1N__EMI_CE1N MXS_IOMUX_PAD_NAKED(6, 23, PAD_MUXSEL_0) | ||
206 | #define MX28_PAD_EMI_CKE__EMI_CKE MXS_IOMUX_PAD_NAKED(6, 24, PAD_MUXSEL_0) | ||
207 | |||
208 | /* MUXSEL_1 */ | ||
209 | #define MX28_PAD_GPMI_D00__SSP1_D0 MXS_IOMUX_PAD_NAKED(0, 0, PAD_MUXSEL_1) | ||
210 | #define MX28_PAD_GPMI_D01__SSP1_D1 MXS_IOMUX_PAD_NAKED(0, 1, PAD_MUXSEL_1) | ||
211 | #define MX28_PAD_GPMI_D02__SSP1_D2 MXS_IOMUX_PAD_NAKED(0, 2, PAD_MUXSEL_1) | ||
212 | #define MX28_PAD_GPMI_D03__SSP1_D3 MXS_IOMUX_PAD_NAKED(0, 3, PAD_MUXSEL_1) | ||
213 | #define MX28_PAD_GPMI_D04__SSP1_D4 MXS_IOMUX_PAD_NAKED(0, 4, PAD_MUXSEL_1) | ||
214 | #define MX28_PAD_GPMI_D05__SSP1_D5 MXS_IOMUX_PAD_NAKED(0, 5, PAD_MUXSEL_1) | ||
215 | #define MX28_PAD_GPMI_D06__SSP1_D6 MXS_IOMUX_PAD_NAKED(0, 6, PAD_MUXSEL_1) | ||
216 | #define MX28_PAD_GPMI_D07__SSP1_D7 MXS_IOMUX_PAD_NAKED(0, 7, PAD_MUXSEL_1) | ||
217 | #define MX28_PAD_GPMI_CE0N__SSP3_D0 MXS_IOMUX_PAD_NAKED(0, 16, PAD_MUXSEL_1) | ||
218 | #define MX28_PAD_GPMI_CE1N__SSP3_D3 MXS_IOMUX_PAD_NAKED(0, 17, PAD_MUXSEL_1) | ||
219 | #define MX28_PAD_GPMI_CE2N__CAN1_TX MXS_IOMUX_PAD_NAKED(0, 18, PAD_MUXSEL_1) | ||
220 | #define MX28_PAD_GPMI_CE3N__CAN1_RX MXS_IOMUX_PAD_NAKED(0, 19, PAD_MUXSEL_1) | ||
221 | #define MX28_PAD_GPMI_RDY0__SSP1_CARD_DETECT MXS_IOMUX_PAD_NAKED(0, 20, PAD_MUXSEL_1) | ||
222 | #define MX28_PAD_GPMI_RDY1__SSP1_CMD MXS_IOMUX_PAD_NAKED(0, 21, PAD_MUXSEL_1) | ||
223 | #define MX28_PAD_GPMI_RDY2__CAN0_TX MXS_IOMUX_PAD_NAKED(0, 22, PAD_MUXSEL_1) | ||
224 | #define MX28_PAD_GPMI_RDY3__CAN0_RX MXS_IOMUX_PAD_NAKED(0, 23, PAD_MUXSEL_1) | ||
225 | #define MX28_PAD_GPMI_RDN__SSP3_SCK MXS_IOMUX_PAD_NAKED(0, 24, PAD_MUXSEL_1) | ||
226 | #define MX28_PAD_GPMI_WRN__SSP1_SCK MXS_IOMUX_PAD_NAKED(0, 25, PAD_MUXSEL_1) | ||
227 | #define MX28_PAD_GPMI_ALE__SSP3_D1 MXS_IOMUX_PAD_NAKED(0, 26, PAD_MUXSEL_1) | ||
228 | #define MX28_PAD_GPMI_CLE__SSP3_D2 MXS_IOMUX_PAD_NAKED(0, 27, PAD_MUXSEL_1) | ||
229 | #define MX28_PAD_GPMI_RESETN__SSP3_CMD MXS_IOMUX_PAD_NAKED(0, 28, PAD_MUXSEL_1) | ||
230 | |||
231 | #define MX28_PAD_LCD_D03__ETM_DA8 MXS_IOMUX_PAD_NAKED(1, 3, PAD_MUXSEL_1) | ||
232 | #define MX28_PAD_LCD_D04__ETM_DA9 MXS_IOMUX_PAD_NAKED(1, 4, PAD_MUXSEL_1) | ||
233 | #define MX28_PAD_LCD_D08__ETM_DA3 MXS_IOMUX_PAD_NAKED(1, 8, PAD_MUXSEL_1) | ||
234 | #define MX28_PAD_LCD_D09__ETM_DA4 MXS_IOMUX_PAD_NAKED(1, 9, PAD_MUXSEL_1) | ||
235 | #define MX28_PAD_LCD_D20__ENET1_1588_EVENT2_OUT MXS_IOMUX_PAD_NAKED(1, 20, PAD_MUXSEL_1) | ||
236 | #define MX28_PAD_LCD_D21__ENET1_1588_EVENT2_IN MXS_IOMUX_PAD_NAKED(1, 21, PAD_MUXSEL_1) | ||
237 | #define MX28_PAD_LCD_D22__ENET1_1588_EVENT3_OUT MXS_IOMUX_PAD_NAKED(1, 22, PAD_MUXSEL_1) | ||
238 | #define MX28_PAD_LCD_D23__ENET1_1588_EVENT3_IN MXS_IOMUX_PAD_NAKED(1, 23, PAD_MUXSEL_1) | ||
239 | #define MX28_PAD_LCD_RD_E__LCD_VSYNC MXS_IOMUX_PAD_NAKED(1, 24, PAD_MUXSEL_1) | ||
240 | #define MX28_PAD_LCD_WR_RWN__LCD_HSYNC MXS_IOMUX_PAD_NAKED(1, 25, PAD_MUXSEL_1) | ||
241 | #define MX28_PAD_LCD_RS__LCD_DOTCLK MXS_IOMUX_PAD_NAKED(1, 26, PAD_MUXSEL_1) | ||
242 | #define MX28_PAD_LCD_CS__LCD_ENABLE MXS_IOMUX_PAD_NAKED(1, 27, PAD_MUXSEL_1) | ||
243 | #define MX28_PAD_LCD_VSYNC__SAIF1_SDATA0 MXS_IOMUX_PAD_NAKED(1, 28, PAD_MUXSEL_1) | ||
244 | #define MX28_PAD_LCD_HSYNC__SAIF1_SDATA1 MXS_IOMUX_PAD_NAKED(1, 29, PAD_MUXSEL_1) | ||
245 | #define MX28_PAD_LCD_DOTCLK__SAIF1_MCLK MXS_IOMUX_PAD_NAKED(1, 30, PAD_MUXSEL_1) | ||
246 | |||
247 | #define MX28_PAD_SSP0_DATA4__SSP2_D0 MXS_IOMUX_PAD_NAKED(2, 4, PAD_MUXSEL_1) | ||
248 | #define MX28_PAD_SSP0_DATA5__SSP2_D3 MXS_IOMUX_PAD_NAKED(2, 5, PAD_MUXSEL_1) | ||
249 | #define MX28_PAD_SSP0_DATA6__SSP2_CMD MXS_IOMUX_PAD_NAKED(2, 6, PAD_MUXSEL_1) | ||
250 | #define MX28_PAD_SSP0_DATA7__SSP2_SCK MXS_IOMUX_PAD_NAKED(2, 7, PAD_MUXSEL_1) | ||
251 | #define MX28_PAD_SSP1_SCK__SSP2_D1 MXS_IOMUX_PAD_NAKED(2, 12, PAD_MUXSEL_1) | ||
252 | #define MX28_PAD_SSP1_CMD__SSP2_D2 MXS_IOMUX_PAD_NAKED(2, 13, PAD_MUXSEL_1) | ||
253 | #define MX28_PAD_SSP1_DATA0__SSP2_D6 MXS_IOMUX_PAD_NAKED(2, 14, PAD_MUXSEL_1) | ||
254 | #define MX28_PAD_SSP1_DATA3__SSP2_D7 MXS_IOMUX_PAD_NAKED(2, 15, PAD_MUXSEL_1) | ||
255 | #define MX28_PAD_SSP2_SCK__AUART2_RX MXS_IOMUX_PAD_NAKED(2, 16, PAD_MUXSEL_1) | ||
256 | #define MX28_PAD_SSP2_MOSI__AUART2_TX MXS_IOMUX_PAD_NAKED(2, 17, PAD_MUXSEL_1) | ||
257 | #define MX28_PAD_SSP2_MISO__AUART3_RX MXS_IOMUX_PAD_NAKED(2, 18, PAD_MUXSEL_1) | ||
258 | #define MX28_PAD_SSP2_SS0__AUART3_TX MXS_IOMUX_PAD_NAKED(2, 19, PAD_MUXSEL_1) | ||
259 | #define MX28_PAD_SSP2_SS1__SSP2_D1 MXS_IOMUX_PAD_NAKED(2, 20, PAD_MUXSEL_1) | ||
260 | #define MX28_PAD_SSP2_SS2__SSP2_D2 MXS_IOMUX_PAD_NAKED(2, 21, PAD_MUXSEL_1) | ||
261 | #define MX28_PAD_SSP3_SCK__AUART4_TX MXS_IOMUX_PAD_NAKED(2, 24, PAD_MUXSEL_1) | ||
262 | #define MX28_PAD_SSP3_MOSI__AUART4_RX MXS_IOMUX_PAD_NAKED(2, 25, PAD_MUXSEL_1) | ||
263 | #define MX28_PAD_SSP3_MISO__AUART4_RTS MXS_IOMUX_PAD_NAKED(2, 26, PAD_MUXSEL_1) | ||
264 | #define MX28_PAD_SSP3_SS0__AUART4_CTS MXS_IOMUX_PAD_NAKED(2, 27, PAD_MUXSEL_1) | ||
265 | |||
266 | #define MX28_PAD_AUART0_RX__I2C0_SCL MXS_IOMUX_PAD_NAKED(3, 0, PAD_MUXSEL_1) | ||
267 | #define MX28_PAD_AUART0_TX__I2C0_SDA MXS_IOMUX_PAD_NAKED(3, 1, PAD_MUXSEL_1) | ||
268 | #define MX28_PAD_AUART0_CTS__AUART4_RX MXS_IOMUX_PAD_NAKED(3, 2, PAD_MUXSEL_1) | ||
269 | #define MX28_PAD_AUART0_RTS__AUART4_TX MXS_IOMUX_PAD_NAKED(3, 3, PAD_MUXSEL_1) | ||
270 | #define MX28_PAD_AUART1_RX__SSP2_CARD_DETECT MXS_IOMUX_PAD_NAKED(3, 4, PAD_MUXSEL_1) | ||
271 | #define MX28_PAD_AUART1_TX__SSP3_CARD_DETECT MXS_IOMUX_PAD_NAKED(3, 5, PAD_MUXSEL_1) | ||
272 | #define MX28_PAD_AUART1_CTS__USB0_OVERCURRENT MXS_IOMUX_PAD_NAKED(3, 6, PAD_MUXSEL_1) | ||
273 | #define MX28_PAD_AUART1_RTS__USB0_ID MXS_IOMUX_PAD_NAKED(3, 7, PAD_MUXSEL_1) | ||
274 | #define MX28_PAD_AUART2_RX__SSP3_D1 MXS_IOMUX_PAD_NAKED(3, 8, PAD_MUXSEL_1) | ||
275 | #define MX28_PAD_AUART2_TX__SSP3_D2 MXS_IOMUX_PAD_NAKED(3, 9, PAD_MUXSEL_1) | ||
276 | #define MX28_PAD_AUART2_CTS__I2C1_SCL MXS_IOMUX_PAD_NAKED(3, 10, PAD_MUXSEL_1) | ||
277 | #define MX28_PAD_AUART2_RTS__I2C1_SDA MXS_IOMUX_PAD_NAKED(3, 11, PAD_MUXSEL_1) | ||
278 | #define MX28_PAD_AUART3_RX__CAN0_TX MXS_IOMUX_PAD_NAKED(3, 12, PAD_MUXSEL_1) | ||
279 | #define MX28_PAD_AUART3_TX__CAN0_RX MXS_IOMUX_PAD_NAKED(3, 13, PAD_MUXSEL_1) | ||
280 | #define MX28_PAD_AUART3_CTS__CAN1_TX MXS_IOMUX_PAD_NAKED(3, 14, PAD_MUXSEL_1) | ||
281 | #define MX28_PAD_AUART3_RTS__CAN1_RX MXS_IOMUX_PAD_NAKED(3, 15, PAD_MUXSEL_1) | ||
282 | #define MX28_PAD_PWM0__I2C1_SCL MXS_IOMUX_PAD_NAKED(3, 16, PAD_MUXSEL_1) | ||
283 | #define MX28_PAD_PWM1__I2C1_SDA MXS_IOMUX_PAD_NAKED(3, 17, PAD_MUXSEL_1) | ||
284 | #define MX28_PAD_PWM2__USB0_ID MXS_IOMUX_PAD_NAKED(3, 18, PAD_MUXSEL_1) | ||
285 | #define MX28_PAD_SAIF0_MCLK__PWM_3 MXS_IOMUX_PAD_NAKED(3, 20, PAD_MUXSEL_1) | ||
286 | #define MX28_PAD_SAIF0_LRCLK__PWM_4 MXS_IOMUX_PAD_NAKED(3, 21, PAD_MUXSEL_1) | ||
287 | #define MX28_PAD_SAIF0_BITCLK__PWM_5 MXS_IOMUX_PAD_NAKED(3, 22, PAD_MUXSEL_1) | ||
288 | #define MX28_PAD_SAIF0_SDATA0__PWM_6 MXS_IOMUX_PAD_NAKED(3, 23, PAD_MUXSEL_1) | ||
289 | #define MX28_PAD_I2C0_SCL__TIMROT_ROTARYA MXS_IOMUX_PAD_NAKED(3, 24, PAD_MUXSEL_1) | ||
290 | #define MX28_PAD_I2C0_SDA__TIMROT_ROTARYB MXS_IOMUX_PAD_NAKED(3, 25, PAD_MUXSEL_1) | ||
291 | #define MX28_PAD_SAIF1_SDATA0__PWM_7 MXS_IOMUX_PAD_NAKED(3, 26, PAD_MUXSEL_1) | ||
292 | #define MX28_PAD_LCD_RESET__LCD_VSYNC MXS_IOMUX_PAD_NAKED(3, 30, PAD_MUXSEL_1) | ||
293 | |||
294 | #define MX28_PAD_ENET0_MDC__GPMI_CE4N MXS_IOMUX_PAD_NAKED(4, 0, PAD_MUXSEL_1) | ||
295 | #define MX28_PAD_ENET0_MDIO__GPMI_CE5N MXS_IOMUX_PAD_NAKED(4, 1, PAD_MUXSEL_1) | ||
296 | #define MX28_PAD_ENET0_RX_EN__GPMI_CE6N MXS_IOMUX_PAD_NAKED(4, 2, PAD_MUXSEL_1) | ||
297 | #define MX28_PAD_ENET0_RXD0__GPMI_CE7N MXS_IOMUX_PAD_NAKED(4, 3, PAD_MUXSEL_1) | ||
298 | #define MX28_PAD_ENET0_RXD1__GPMI_READY4 MXS_IOMUX_PAD_NAKED(4, 4, PAD_MUXSEL_1) | ||
299 | #define MX28_PAD_ENET0_TX_CLK__HSADC_TRIGGER MXS_IOMUX_PAD_NAKED(4, 5, PAD_MUXSEL_1) | ||
300 | #define MX28_PAD_ENET0_TX_EN__GPMI_READY5 MXS_IOMUX_PAD_NAKED(4, 6, PAD_MUXSEL_1) | ||
301 | #define MX28_PAD_ENET0_TXD0__GPMI_READY6 MXS_IOMUX_PAD_NAKED(4, 7, PAD_MUXSEL_1) | ||
302 | #define MX28_PAD_ENET0_TXD1__GPMI_READY7 MXS_IOMUX_PAD_NAKED(4, 8, PAD_MUXSEL_1) | ||
303 | #define MX28_PAD_ENET0_RXD2__ENET1_RXD0 MXS_IOMUX_PAD_NAKED(4, 9, PAD_MUXSEL_1) | ||
304 | #define MX28_PAD_ENET0_RXD3__ENET1_RXD1 MXS_IOMUX_PAD_NAKED(4, 10, PAD_MUXSEL_1) | ||
305 | #define MX28_PAD_ENET0_TXD2__ENET1_TXD0 MXS_IOMUX_PAD_NAKED(4, 11, PAD_MUXSEL_1) | ||
306 | #define MX28_PAD_ENET0_TXD3__ENET1_TXD1 MXS_IOMUX_PAD_NAKED(4, 12, PAD_MUXSEL_1) | ||
307 | #define MX28_PAD_ENET0_RX_CLK__ENET0_RX_ER MXS_IOMUX_PAD_NAKED(4, 13, PAD_MUXSEL_1) | ||
308 | #define MX28_PAD_ENET0_COL__ENET1_TX_EN MXS_IOMUX_PAD_NAKED(4, 14, PAD_MUXSEL_1) | ||
309 | #define MX28_PAD_ENET0_CRS__ENET1_RX_EN MXS_IOMUX_PAD_NAKED(4, 15, PAD_MUXSEL_1) | ||
310 | |||
311 | /* MUXSEL_2 */ | ||
312 | #define MX28_PAD_GPMI_CE2N__ENET0_RX_ER MXS_IOMUX_PAD_NAKED(0, 18, PAD_MUXSEL_2) | ||
313 | #define MX28_PAD_GPMI_CE3N__SAIF1_MCLK MXS_IOMUX_PAD_NAKED(0, 19, PAD_MUXSEL_2) | ||
314 | #define MX28_PAD_GPMI_RDY0__USB0_ID MXS_IOMUX_PAD_NAKED(0, 20, PAD_MUXSEL_2) | ||
315 | #define MX28_PAD_GPMI_RDY2__ENET0_TX_ER MXS_IOMUX_PAD_NAKED(0, 22, PAD_MUXSEL_2) | ||
316 | #define MX28_PAD_GPMI_RDY3__HSADC_TRIGGER MXS_IOMUX_PAD_NAKED(0, 23, PAD_MUXSEL_2) | ||
317 | #define MX28_PAD_GPMI_ALE__SSP3_D4 MXS_IOMUX_PAD_NAKED(0, 26, PAD_MUXSEL_2) | ||
318 | #define MX28_PAD_GPMI_CLE__SSP3_D5 MXS_IOMUX_PAD_NAKED(0, 27, PAD_MUXSEL_2) | ||
319 | |||
320 | #define MX28_PAD_LCD_D00__ETM_DA0 MXS_IOMUX_PAD_NAKED(1, 0, PAD_MUXSEL_2) | ||
321 | #define MX28_PAD_LCD_D01__ETM_DA1 MXS_IOMUX_PAD_NAKED(1, 1, PAD_MUXSEL_2) | ||
322 | #define MX28_PAD_LCD_D02__ETM_DA2 MXS_IOMUX_PAD_NAKED(1, 2, PAD_MUXSEL_2) | ||
323 | #define MX28_PAD_LCD_D03__ETM_DA3 MXS_IOMUX_PAD_NAKED(1, 3, PAD_MUXSEL_2) | ||
324 | #define MX28_PAD_LCD_D04__ETM_DA4 MXS_IOMUX_PAD_NAKED(1, 4, PAD_MUXSEL_2) | ||
325 | #define MX28_PAD_LCD_D05__ETM_DA5 MXS_IOMUX_PAD_NAKED(1, 5, PAD_MUXSEL_2) | ||
326 | #define MX28_PAD_LCD_D06__ETM_DA6 MXS_IOMUX_PAD_NAKED(1, 6, PAD_MUXSEL_2) | ||
327 | #define MX28_PAD_LCD_D07__ETM_DA7 MXS_IOMUX_PAD_NAKED(1, 7, PAD_MUXSEL_2) | ||
328 | #define MX28_PAD_LCD_D08__ETM_DA8 MXS_IOMUX_PAD_NAKED(1, 8, PAD_MUXSEL_2) | ||
329 | #define MX28_PAD_LCD_D09__ETM_DA9 MXS_IOMUX_PAD_NAKED(1, 9, PAD_MUXSEL_2) | ||
330 | #define MX28_PAD_LCD_D10__ETM_DA10 MXS_IOMUX_PAD_NAKED(1, 10, PAD_MUXSEL_2) | ||
331 | #define MX28_PAD_LCD_D11__ETM_DA11 MXS_IOMUX_PAD_NAKED(1, 11, PAD_MUXSEL_2) | ||
332 | #define MX28_PAD_LCD_D12__ETM_DA12 MXS_IOMUX_PAD_NAKED(1, 12, PAD_MUXSEL_2) | ||
333 | #define MX28_PAD_LCD_D13__ETM_DA13 MXS_IOMUX_PAD_NAKED(1, 13, PAD_MUXSEL_2) | ||
334 | #define MX28_PAD_LCD_D14__ETM_DA14 MXS_IOMUX_PAD_NAKED(1, 14, PAD_MUXSEL_2) | ||
335 | #define MX28_PAD_LCD_D15__ETM_DA15 MXS_IOMUX_PAD_NAKED(1, 15, PAD_MUXSEL_2) | ||
336 | #define MX28_PAD_LCD_D16__ETM_DA7 MXS_IOMUX_PAD_NAKED(1, 16, PAD_MUXSEL_2) | ||
337 | #define MX28_PAD_LCD_D17__ETM_DA6 MXS_IOMUX_PAD_NAKED(1, 17, PAD_MUXSEL_2) | ||
338 | #define MX28_PAD_LCD_D18__ETM_DA5 MXS_IOMUX_PAD_NAKED(1, 18, PAD_MUXSEL_2) | ||
339 | #define MX28_PAD_LCD_D19__ETM_DA4 MXS_IOMUX_PAD_NAKED(1, 19, PAD_MUXSEL_2) | ||
340 | #define MX28_PAD_LCD_D20__ETM_DA3 MXS_IOMUX_PAD_NAKED(1, 20, PAD_MUXSEL_2) | ||
341 | #define MX28_PAD_LCD_D21__ETM_DA2 MXS_IOMUX_PAD_NAKED(1, 21, PAD_MUXSEL_2) | ||
342 | #define MX28_PAD_LCD_D22__ETM_DA1 MXS_IOMUX_PAD_NAKED(1, 22, PAD_MUXSEL_2) | ||
343 | #define MX28_PAD_LCD_D23__ETM_DA0 MXS_IOMUX_PAD_NAKED(1, 23, PAD_MUXSEL_2) | ||
344 | #define MX28_PAD_LCD_RD_E__ETM_TCTL MXS_IOMUX_PAD_NAKED(1, 24, PAD_MUXSEL_2) | ||
345 | #define MX28_PAD_LCD_WR_RWN__ETM_TCLK MXS_IOMUX_PAD_NAKED(1, 25, PAD_MUXSEL_2) | ||
346 | #define MX28_PAD_LCD_HSYNC__ETM_TCTL MXS_IOMUX_PAD_NAKED(1, 29, PAD_MUXSEL_2) | ||
347 | #define MX28_PAD_LCD_DOTCLK__ETM_TCLK MXS_IOMUX_PAD_NAKED(1, 30, PAD_MUXSEL_2) | ||
348 | |||
349 | #define MX28_PAD_SSP1_SCK__ENET0_1588_EVENT2_OUT MXS_IOMUX_PAD_NAKED(2, 12, PAD_MUXSEL_2) | ||
350 | #define MX28_PAD_SSP1_CMD__ENET0_1588_EVENT2_IN MXS_IOMUX_PAD_NAKED(2, 13, PAD_MUXSEL_2) | ||
351 | #define MX28_PAD_SSP1_DATA0__ENET0_1588_EVENT3_OUT MXS_IOMUX_PAD_NAKED(2, 14, PAD_MUXSEL_2) | ||
352 | #define MX28_PAD_SSP1_DATA3__ENET0_1588_EVENT3_IN MXS_IOMUX_PAD_NAKED(2, 15, PAD_MUXSEL_2) | ||
353 | #define MX28_PAD_SSP2_SCK__SAIF0_SDATA1 MXS_IOMUX_PAD_NAKED(2, 16, PAD_MUXSEL_2) | ||
354 | #define MX28_PAD_SSP2_MOSI__SAIF0_SDATA2 MXS_IOMUX_PAD_NAKED(2, 17, PAD_MUXSEL_2) | ||
355 | #define MX28_PAD_SSP2_MISO__SAIF1_SDATA1 MXS_IOMUX_PAD_NAKED(2, 18, PAD_MUXSEL_2) | ||
356 | #define MX28_PAD_SSP2_SS0__SAIF1_SDATA2 MXS_IOMUX_PAD_NAKED(2, 19, PAD_MUXSEL_2) | ||
357 | #define MX28_PAD_SSP2_SS1__USB1_OVERCURRENT MXS_IOMUX_PAD_NAKED(2, 20, PAD_MUXSEL_2) | ||
358 | #define MX28_PAD_SSP2_SS2__USB0_OVERCURRENT MXS_IOMUX_PAD_NAKED(2, 21, PAD_MUXSEL_2) | ||
359 | #define MX28_PAD_SSP3_SCK__ENET1_1588_EVENT0_OUT MXS_IOMUX_PAD_NAKED(2, 24, PAD_MUXSEL_2) | ||
360 | #define MX28_PAD_SSP3_MOSI__ENET1_1588_EVENT0_IN MXS_IOMUX_PAD_NAKED(2, 25, PAD_MUXSEL_2) | ||
361 | #define MX28_PAD_SSP3_MISO__ENET1_1588_EVENT1_OUT MXS_IOMUX_PAD_NAKED(2, 26, PAD_MUXSEL_2) | ||
362 | #define MX28_PAD_SSP3_SS0__ENET1_1588_EVENT1_IN MXS_IOMUX_PAD_NAKED(2, 27, PAD_MUXSEL_2) | ||
363 | |||
364 | #define MX28_PAD_AUART0_RX__DUART_CTS MXS_IOMUX_PAD_NAKED(3, 0, PAD_MUXSEL_2) | ||
365 | #define MX28_PAD_AUART0_TX__DUART_RTS MXS_IOMUX_PAD_NAKED(3, 1, PAD_MUXSEL_2) | ||
366 | #define MX28_PAD_AUART0_CTS__DUART_RX MXS_IOMUX_PAD_NAKED(3, 2, PAD_MUXSEL_2) | ||
367 | #define MX28_PAD_AUART0_RTS__DUART_TX MXS_IOMUX_PAD_NAKED(3, 3, PAD_MUXSEL_2) | ||
368 | #define MX28_PAD_AUART1_RX__PWM_0 MXS_IOMUX_PAD_NAKED(3, 4, PAD_MUXSEL_2) | ||
369 | #define MX28_PAD_AUART1_TX__PWM_1 MXS_IOMUX_PAD_NAKED(3, 5, PAD_MUXSEL_2) | ||
370 | #define MX28_PAD_AUART1_CTS__TIMROT_ROTARYA MXS_IOMUX_PAD_NAKED(3, 6, PAD_MUXSEL_2) | ||
371 | #define MX28_PAD_AUART1_RTS__TIMROT_ROTARYB MXS_IOMUX_PAD_NAKED(3, 7, PAD_MUXSEL_2) | ||
372 | #define MX28_PAD_AUART2_RX__SSP3_D4 MXS_IOMUX_PAD_NAKED(3, 8, PAD_MUXSEL_2) | ||
373 | #define MX28_PAD_AUART2_TX__SSP3_D5 MXS_IOMUX_PAD_NAKED(3, 9, PAD_MUXSEL_2) | ||
374 | #define MX28_PAD_AUART2_CTS__SAIF1_BITCLK MXS_IOMUX_PAD_NAKED(3, 10, PAD_MUXSEL_2) | ||
375 | #define MX28_PAD_AUART2_RTS__SAIF1_LRCLK MXS_IOMUX_PAD_NAKED(3, 11, PAD_MUXSEL_2) | ||
376 | #define MX28_PAD_AUART3_RX__ENET0_1588_EVENT0_OUT MXS_IOMUX_PAD_NAKED(3, 12, PAD_MUXSEL_2) | ||
377 | #define MX28_PAD_AUART3_TX__ENET0_1588_EVENT0_IN MXS_IOMUX_PAD_NAKED(3, 13, PAD_MUXSEL_2) | ||
378 | #define MX28_PAD_AUART3_CTS__ENET0_1588_EVENT1_OUT MXS_IOMUX_PAD_NAKED(3, 14, PAD_MUXSEL_2) | ||
379 | #define MX28_PAD_AUART3_RTS__ENET0_1588_EVENT1_IN MXS_IOMUX_PAD_NAKED(3, 15, PAD_MUXSEL_2) | ||
380 | #define MX28_PAD_PWM0__DUART_RX MXS_IOMUX_PAD_NAKED(3, 16, PAD_MUXSEL_2) | ||
381 | #define MX28_PAD_PWM1__DUART_TX MXS_IOMUX_PAD_NAKED(3, 17, PAD_MUXSEL_2) | ||
382 | #define MX28_PAD_PWM2__USB1_OVERCURRENT MXS_IOMUX_PAD_NAKED(3, 18, PAD_MUXSEL_2) | ||
383 | #define MX28_PAD_SAIF0_MCLK__AUART4_CTS MXS_IOMUX_PAD_NAKED(3, 20, PAD_MUXSEL_2) | ||
384 | #define MX28_PAD_SAIF0_LRCLK__AUART4_RTS MXS_IOMUX_PAD_NAKED(3, 21, PAD_MUXSEL_2) | ||
385 | #define MX28_PAD_SAIF0_BITCLK__AUART4_RX MXS_IOMUX_PAD_NAKED(3, 22, PAD_MUXSEL_2) | ||
386 | #define MX28_PAD_SAIF0_SDATA0__AUART4_TX MXS_IOMUX_PAD_NAKED(3, 23, PAD_MUXSEL_2) | ||
387 | #define MX28_PAD_I2C0_SCL__DUART_RX MXS_IOMUX_PAD_NAKED(3, 24, PAD_MUXSEL_2) | ||
388 | #define MX28_PAD_I2C0_SDA__DUART_TX MXS_IOMUX_PAD_NAKED(3, 25, PAD_MUXSEL_2) | ||
389 | #define MX28_PAD_SAIF1_SDATA0__SAIF0_SDATA1 MXS_IOMUX_PAD_NAKED(3, 26, PAD_MUXSEL_2) | ||
390 | #define MX28_PAD_SPDIF__ENET1_RX_ER MXS_IOMUX_PAD_NAKED(3, 27, PAD_MUXSEL_2) | ||
391 | |||
392 | #define MX28_PAD_ENET0_MDC__SAIF0_SDATA1 MXS_IOMUX_PAD_NAKED(4, 0, PAD_MUXSEL_2) | ||
393 | #define MX28_PAD_ENET0_MDIO__SAIF0_SDATA2 MXS_IOMUX_PAD_NAKED(4, 1, PAD_MUXSEL_2) | ||
394 | #define MX28_PAD_ENET0_RX_EN__SAIF1_SDATA1 MXS_IOMUX_PAD_NAKED(4, 2, PAD_MUXSEL_2) | ||
395 | #define MX28_PAD_ENET0_RXD0__SAIF1_SDATA2 MXS_IOMUX_PAD_NAKED(4, 3, PAD_MUXSEL_2) | ||
396 | #define MX28_PAD_ENET0_TX_CLK__ENET0_1588_EVENT2_OUT MXS_IOMUX_PAD_NAKED(4, 5, PAD_MUXSEL_2) | ||
397 | #define MX28_PAD_ENET0_RXD2__ENET0_1588_EVENT0_OUT MXS_IOMUX_PAD_NAKED(4, 9, PAD_MUXSEL_2) | ||
398 | #define MX28_PAD_ENET0_RXD3__ENET0_1588_EVENT0_IN MXS_IOMUX_PAD_NAKED(4, 10, PAD_MUXSEL_2) | ||
399 | #define MX28_PAD_ENET0_TXD2__ENET0_1588_EVENT1_OUT MXS_IOMUX_PAD_NAKED(4, 11, PAD_MUXSEL_2) | ||
400 | #define MX28_PAD_ENET0_TXD3__ENET0_1588_EVENT1_IN MXS_IOMUX_PAD_NAKED(4, 12, PAD_MUXSEL_2) | ||
401 | #define MX28_PAD_ENET0_RX_CLK__ENET0_1588_EVENT2_IN MXS_IOMUX_PAD_NAKED(4, 13, PAD_MUXSEL_2) | ||
402 | #define MX28_PAD_ENET0_COL__ENET0_1588_EVENT3_OUT MXS_IOMUX_PAD_NAKED(4, 14, PAD_MUXSEL_2) | ||
403 | #define MX28_PAD_ENET0_CRS__ENET0_1588_EVENT3_IN MXS_IOMUX_PAD_NAKED(4, 15, PAD_MUXSEL_2) | ||
404 | |||
405 | /* MUXSEL_GPIO */ | ||
406 | #define MX28_PAD_GPMI_D00__GPIO_0_0 MXS_IOMUX_PAD_NAKED(0, 0, PAD_MUXSEL_GPIO) | ||
407 | #define MX28_PAD_GPMI_D01__GPIO_0_1 MXS_IOMUX_PAD_NAKED(0, 1, PAD_MUXSEL_GPIO) | ||
408 | #define MX28_PAD_GPMI_D02__GPIO_0_2 MXS_IOMUX_PAD_NAKED(0, 2, PAD_MUXSEL_GPIO) | ||
409 | #define MX28_PAD_GPMI_D03__GPIO_0_3 MXS_IOMUX_PAD_NAKED(0, 3, PAD_MUXSEL_GPIO) | ||
410 | #define MX28_PAD_GPMI_D04__GPIO_0_4 MXS_IOMUX_PAD_NAKED(0, 4, PAD_MUXSEL_GPIO) | ||
411 | #define MX28_PAD_GPMI_D05__GPIO_0_5 MXS_IOMUX_PAD_NAKED(0, 5, PAD_MUXSEL_GPIO) | ||
412 | #define MX28_PAD_GPMI_D06__GPIO_0_6 MXS_IOMUX_PAD_NAKED(0, 6, PAD_MUXSEL_GPIO) | ||
413 | #define MX28_PAD_GPMI_D07__GPIO_0_7 MXS_IOMUX_PAD_NAKED(0, 7, PAD_MUXSEL_GPIO) | ||
414 | #define MX28_PAD_GPMI_CE0N__GPIO_0_16 MXS_IOMUX_PAD_NAKED(0, 16, PAD_MUXSEL_GPIO) | ||
415 | #define MX28_PAD_GPMI_CE1N__GPIO_0_17 MXS_IOMUX_PAD_NAKED(0, 17, PAD_MUXSEL_GPIO) | ||
416 | #define MX28_PAD_GPMI_CE2N__GPIO_0_18 MXS_IOMUX_PAD_NAKED(0, 18, PAD_MUXSEL_GPIO) | ||
417 | #define MX28_PAD_GPMI_CE3N__GPIO_0_19 MXS_IOMUX_PAD_NAKED(0, 19, PAD_MUXSEL_GPIO) | ||
418 | #define MX28_PAD_GPMI_RDY0__GPIO_0_20 MXS_IOMUX_PAD_NAKED(0, 20, PAD_MUXSEL_GPIO) | ||
419 | #define MX28_PAD_GPMI_RDY1__GPIO_0_21 MXS_IOMUX_PAD_NAKED(0, 21, PAD_MUXSEL_GPIO) | ||
420 | #define MX28_PAD_GPMI_RDY2__GPIO_0_22 MXS_IOMUX_PAD_NAKED(0, 22, PAD_MUXSEL_GPIO) | ||
421 | #define MX28_PAD_GPMI_RDY3__GPIO_0_23 MXS_IOMUX_PAD_NAKED(0, 23, PAD_MUXSEL_GPIO) | ||
422 | #define MX28_PAD_GPMI_RDN__GPIO_0_24 MXS_IOMUX_PAD_NAKED(0, 24, PAD_MUXSEL_GPIO) | ||
423 | #define MX28_PAD_GPMI_WRN__GPIO_0_25 MXS_IOMUX_PAD_NAKED(0, 25, PAD_MUXSEL_GPIO) | ||
424 | #define MX28_PAD_GPMI_ALE__GPIO_0_26 MXS_IOMUX_PAD_NAKED(0, 26, PAD_MUXSEL_GPIO) | ||
425 | #define MX28_PAD_GPMI_CLE__GPIO_0_27 MXS_IOMUX_PAD_NAKED(0, 27, PAD_MUXSEL_GPIO) | ||
426 | #define MX28_PAD_GPMI_RESETN__GPIO_0_28 MXS_IOMUX_PAD_NAKED(0, 28, PAD_MUXSEL_GPIO) | ||
427 | |||
428 | #define MX28_PAD_LCD_D00__GPIO_1_0 MXS_IOMUX_PAD_NAKED(1, 0, PAD_MUXSEL_GPIO) | ||
429 | #define MX28_PAD_LCD_D01__GPIO_1_1 MXS_IOMUX_PAD_NAKED(1, 1, PAD_MUXSEL_GPIO) | ||
430 | #define MX28_PAD_LCD_D02__GPIO_1_2 MXS_IOMUX_PAD_NAKED(1, 2, PAD_MUXSEL_GPIO) | ||
431 | #define MX28_PAD_LCD_D03__GPIO_1_3 MXS_IOMUX_PAD_NAKED(1, 3, PAD_MUXSEL_GPIO) | ||
432 | #define MX28_PAD_LCD_D04__GPIO_1_4 MXS_IOMUX_PAD_NAKED(1, 4, PAD_MUXSEL_GPIO) | ||
433 | #define MX28_PAD_LCD_D05__GPIO_1_5 MXS_IOMUX_PAD_NAKED(1, 5, PAD_MUXSEL_GPIO) | ||
434 | #define MX28_PAD_LCD_D06__GPIO_1_6 MXS_IOMUX_PAD_NAKED(1, 6, PAD_MUXSEL_GPIO) | ||
435 | #define MX28_PAD_LCD_D07__GPIO_1_7 MXS_IOMUX_PAD_NAKED(1, 7, PAD_MUXSEL_GPIO) | ||
436 | #define MX28_PAD_LCD_D08__GPIO_1_8 MXS_IOMUX_PAD_NAKED(1, 8, PAD_MUXSEL_GPIO) | ||
437 | #define MX28_PAD_LCD_D09__GPIO_1_9 MXS_IOMUX_PAD_NAKED(1, 9, PAD_MUXSEL_GPIO) | ||
438 | #define MX28_PAD_LCD_D10__GPIO_1_10 MXS_IOMUX_PAD_NAKED(1, 10, PAD_MUXSEL_GPIO) | ||
439 | #define MX28_PAD_LCD_D11__GPIO_1_11 MXS_IOMUX_PAD_NAKED(1, 11, PAD_MUXSEL_GPIO) | ||
440 | #define MX28_PAD_LCD_D12__GPIO_1_12 MXS_IOMUX_PAD_NAKED(1, 12, PAD_MUXSEL_GPIO) | ||
441 | #define MX28_PAD_LCD_D13__GPIO_1_13 MXS_IOMUX_PAD_NAKED(1, 13, PAD_MUXSEL_GPIO) | ||
442 | #define MX28_PAD_LCD_D14__GPIO_1_14 MXS_IOMUX_PAD_NAKED(1, 14, PAD_MUXSEL_GPIO) | ||
443 | #define MX28_PAD_LCD_D15__GPIO_1_15 MXS_IOMUX_PAD_NAKED(1, 15, PAD_MUXSEL_GPIO) | ||
444 | #define MX28_PAD_LCD_D16__GPIO_1_16 MXS_IOMUX_PAD_NAKED(1, 16, PAD_MUXSEL_GPIO) | ||
445 | #define MX28_PAD_LCD_D17__GPIO_1_17 MXS_IOMUX_PAD_NAKED(1, 17, PAD_MUXSEL_GPIO) | ||
446 | #define MX28_PAD_LCD_D18__GPIO_1_18 MXS_IOMUX_PAD_NAKED(1, 18, PAD_MUXSEL_GPIO) | ||
447 | #define MX28_PAD_LCD_D19__GPIO_1_19 MXS_IOMUX_PAD_NAKED(1, 19, PAD_MUXSEL_GPIO) | ||
448 | #define MX28_PAD_LCD_D20__GPIO_1_20 MXS_IOMUX_PAD_NAKED(1, 20, PAD_MUXSEL_GPIO) | ||
449 | #define MX28_PAD_LCD_D21__GPIO_1_21 MXS_IOMUX_PAD_NAKED(1, 21, PAD_MUXSEL_GPIO) | ||
450 | #define MX28_PAD_LCD_D22__GPIO_1_22 MXS_IOMUX_PAD_NAKED(1, 22, PAD_MUXSEL_GPIO) | ||
451 | #define MX28_PAD_LCD_D23__GPIO_1_23 MXS_IOMUX_PAD_NAKED(1, 23, PAD_MUXSEL_GPIO) | ||
452 | #define MX28_PAD_LCD_RD_E__GPIO_1_24 MXS_IOMUX_PAD_NAKED(1, 24, PAD_MUXSEL_GPIO) | ||
453 | #define MX28_PAD_LCD_WR_RWN__GPIO_1_25 MXS_IOMUX_PAD_NAKED(1, 25, PAD_MUXSEL_GPIO) | ||
454 | #define MX28_PAD_LCD_RS__GPIO_1_26 MXS_IOMUX_PAD_NAKED(1, 26, PAD_MUXSEL_GPIO) | ||
455 | #define MX28_PAD_LCD_CS__GPIO_1_27 MXS_IOMUX_PAD_NAKED(1, 27, PAD_MUXSEL_GPIO) | ||
456 | #define MX28_PAD_LCD_VSYNC__GPIO_1_28 MXS_IOMUX_PAD_NAKED(1, 28, PAD_MUXSEL_GPIO) | ||
457 | #define MX28_PAD_LCD_HSYNC__GPIO_1_29 MXS_IOMUX_PAD_NAKED(1, 29, PAD_MUXSEL_GPIO) | ||
458 | #define MX28_PAD_LCD_DOTCLK__GPIO_1_30 MXS_IOMUX_PAD_NAKED(1, 30, PAD_MUXSEL_GPIO) | ||
459 | #define MX28_PAD_LCD_ENABLE__GPIO_1_31 MXS_IOMUX_PAD_NAKED(1, 31, PAD_MUXSEL_GPIO) | ||
460 | |||
461 | #define MX28_PAD_SSP0_DATA0__GPIO_2_0 MXS_IOMUX_PAD_NAKED(2, 0, PAD_MUXSEL_GPIO) | ||
462 | #define MX28_PAD_SSP0_DATA1__GPIO_2_1 MXS_IOMUX_PAD_NAKED(2, 1, PAD_MUXSEL_GPIO) | ||
463 | #define MX28_PAD_SSP0_DATA2__GPIO_2_2 MXS_IOMUX_PAD_NAKED(2, 2, PAD_MUXSEL_GPIO) | ||
464 | #define MX28_PAD_SSP0_DATA3__GPIO_2_3 MXS_IOMUX_PAD_NAKED(2, 3, PAD_MUXSEL_GPIO) | ||
465 | #define MX28_PAD_SSP0_DATA4__GPIO_2_4 MXS_IOMUX_PAD_NAKED(2, 4, PAD_MUXSEL_GPIO) | ||
466 | #define MX28_PAD_SSP0_DATA5__GPIO_2_5 MXS_IOMUX_PAD_NAKED(2, 5, PAD_MUXSEL_GPIO) | ||
467 | #define MX28_PAD_SSP0_DATA6__GPIO_2_6 MXS_IOMUX_PAD_NAKED(2, 6, PAD_MUXSEL_GPIO) | ||
468 | #define MX28_PAD_SSP0_DATA7__GPIO_2_7 MXS_IOMUX_PAD_NAKED(2, 7, PAD_MUXSEL_GPIO) | ||
469 | #define MX28_PAD_SSP0_CMD__GPIO_2_8 MXS_IOMUX_PAD_NAKED(2, 8, PAD_MUXSEL_GPIO) | ||
470 | #define MX28_PAD_SSP0_DETECT__GPIO_2_9 MXS_IOMUX_PAD_NAKED(2, 9, PAD_MUXSEL_GPIO) | ||
471 | #define MX28_PAD_SSP0_SCK__GPIO_2_10 MXS_IOMUX_PAD_NAKED(2, 10, PAD_MUXSEL_GPIO) | ||
472 | #define MX28_PAD_SSP1_SCK__GPIO_2_12 MXS_IOMUX_PAD_NAKED(2, 12, PAD_MUXSEL_GPIO) | ||
473 | #define MX28_PAD_SSP1_CMD__GPIO_2_13 MXS_IOMUX_PAD_NAKED(2, 13, PAD_MUXSEL_GPIO) | ||
474 | #define MX28_PAD_SSP1_DATA0__GPIO_2_14 MXS_IOMUX_PAD_NAKED(2, 14, PAD_MUXSEL_GPIO) | ||
475 | #define MX28_PAD_SSP1_DATA3__GPIO_2_15 MXS_IOMUX_PAD_NAKED(2, 15, PAD_MUXSEL_GPIO) | ||
476 | #define MX28_PAD_SSP2_SCK__GPIO_2_16 MXS_IOMUX_PAD_NAKED(2, 16, PAD_MUXSEL_GPIO) | ||
477 | #define MX28_PAD_SSP2_MOSI__GPIO_2_17 MXS_IOMUX_PAD_NAKED(2, 17, PAD_MUXSEL_GPIO) | ||
478 | #define MX28_PAD_SSP2_MISO__GPIO_2_18 MXS_IOMUX_PAD_NAKED(2, 18, PAD_MUXSEL_GPIO) | ||
479 | #define MX28_PAD_SSP2_SS0__GPIO_2_19 MXS_IOMUX_PAD_NAKED(2, 19, PAD_MUXSEL_GPIO) | ||
480 | #define MX28_PAD_SSP2_SS1__GPIO_2_20 MXS_IOMUX_PAD_NAKED(2, 20, PAD_MUXSEL_GPIO) | ||
481 | #define MX28_PAD_SSP2_SS2__GPIO_2_21 MXS_IOMUX_PAD_NAKED(2, 21, PAD_MUXSEL_GPIO) | ||
482 | #define MX28_PAD_SSP3_SCK__GPIO_2_24 MXS_IOMUX_PAD_NAKED(2, 24, PAD_MUXSEL_GPIO) | ||
483 | #define MX28_PAD_SSP3_MOSI__GPIO_2_25 MXS_IOMUX_PAD_NAKED(2, 25, PAD_MUXSEL_GPIO) | ||
484 | #define MX28_PAD_SSP3_MISO__GPIO_2_26 MXS_IOMUX_PAD_NAKED(2, 26, PAD_MUXSEL_GPIO) | ||
485 | #define MX28_PAD_SSP3_SS0__GPIO_2_27 MXS_IOMUX_PAD_NAKED(2, 27, PAD_MUXSEL_GPIO) | ||
486 | |||
487 | #define MX28_PAD_AUART0_RX__GPIO_3_0 MXS_IOMUX_PAD_NAKED(3, 0, PAD_MUXSEL_GPIO) | ||
488 | #define MX28_PAD_AUART0_TX__GPIO_3_1 MXS_IOMUX_PAD_NAKED(3, 1, PAD_MUXSEL_GPIO) | ||
489 | #define MX28_PAD_AUART0_CTS__GPIO_3_2 MXS_IOMUX_PAD_NAKED(3, 2, PAD_MUXSEL_GPIO) | ||
490 | #define MX28_PAD_AUART0_RTS__GPIO_3_3 MXS_IOMUX_PAD_NAKED(3, 3, PAD_MUXSEL_GPIO) | ||
491 | #define MX28_PAD_AUART1_RX__GPIO_3_4 MXS_IOMUX_PAD_NAKED(3, 4, PAD_MUXSEL_GPIO) | ||
492 | #define MX28_PAD_AUART1_TX__GPIO_3_5 MXS_IOMUX_PAD_NAKED(3, 5, PAD_MUXSEL_GPIO) | ||
493 | #define MX28_PAD_AUART1_CTS__GPIO_3_6 MXS_IOMUX_PAD_NAKED(3, 6, PAD_MUXSEL_GPIO) | ||
494 | #define MX28_PAD_AUART1_RTS__GPIO_3_7 MXS_IOMUX_PAD_NAKED(3, 7, PAD_MUXSEL_GPIO) | ||
495 | #define MX28_PAD_AUART2_RX__GPIO_3_8 MXS_IOMUX_PAD_NAKED(3, 8, PAD_MUXSEL_GPIO) | ||
496 | #define MX28_PAD_AUART2_TX__GPIO_3_9 MXS_IOMUX_PAD_NAKED(3, 9, PAD_MUXSEL_GPIO) | ||
497 | #define MX28_PAD_AUART2_CTS__GPIO_3_10 MXS_IOMUX_PAD_NAKED(3, 10, PAD_MUXSEL_GPIO) | ||
498 | #define MX28_PAD_AUART2_RTS__GPIO_3_11 MXS_IOMUX_PAD_NAKED(3, 11, PAD_MUXSEL_GPIO) | ||
499 | #define MX28_PAD_AUART3_RX__GPIO_3_12 MXS_IOMUX_PAD_NAKED(3, 12, PAD_MUXSEL_GPIO) | ||
500 | #define MX28_PAD_AUART3_TX__GPIO_3_13 MXS_IOMUX_PAD_NAKED(3, 13, PAD_MUXSEL_GPIO) | ||
501 | #define MX28_PAD_AUART3_CTS__GPIO_3_14 MXS_IOMUX_PAD_NAKED(3, 14, PAD_MUXSEL_GPIO) | ||
502 | #define MX28_PAD_AUART3_RTS__GPIO_3_15 MXS_IOMUX_PAD_NAKED(3, 15, PAD_MUXSEL_GPIO) | ||
503 | #define MX28_PAD_PWM0__GPIO_3_16 MXS_IOMUX_PAD_NAKED(3, 16, PAD_MUXSEL_GPIO) | ||
504 | #define MX28_PAD_PWM1__GPIO_3_17 MXS_IOMUX_PAD_NAKED(3, 17, PAD_MUXSEL_GPIO) | ||
505 | #define MX28_PAD_PWM2__GPIO_3_18 MXS_IOMUX_PAD_NAKED(3, 18, PAD_MUXSEL_GPIO) | ||
506 | #define MX28_PAD_SAIF0_MCLK__GPIO_3_20 MXS_IOMUX_PAD_NAKED(3, 20, PAD_MUXSEL_GPIO) | ||
507 | #define MX28_PAD_SAIF0_LRCLK__GPIO_3_21 MXS_IOMUX_PAD_NAKED(3, 21, PAD_MUXSEL_GPIO) | ||
508 | #define MX28_PAD_SAIF0_BITCLK__GPIO_3_22 MXS_IOMUX_PAD_NAKED(3, 22, PAD_MUXSEL_GPIO) | ||
509 | #define MX28_PAD_SAIF0_SDATA0__GPIO_3_23 MXS_IOMUX_PAD_NAKED(3, 23, PAD_MUXSEL_GPIO) | ||
510 | #define MX28_PAD_I2C0_SCL__GPIO_3_24 MXS_IOMUX_PAD_NAKED(3, 24, PAD_MUXSEL_GPIO) | ||
511 | #define MX28_PAD_I2C0_SDA__GPIO_3_25 MXS_IOMUX_PAD_NAKED(3, 25, PAD_MUXSEL_GPIO) | ||
512 | #define MX28_PAD_SAIF1_SDATA0__GPIO_3_26 MXS_IOMUX_PAD_NAKED(3, 26, PAD_MUXSEL_GPIO) | ||
513 | #define MX28_PAD_SPDIF__GPIO_3_27 MXS_IOMUX_PAD_NAKED(3, 27, PAD_MUXSEL_GPIO) | ||
514 | #define MX28_PAD_PWM3__GPIO_3_28 MXS_IOMUX_PAD_NAKED(3, 28, PAD_MUXSEL_GPIO) | ||
515 | #define MX28_PAD_PWM4__GPIO_3_29 MXS_IOMUX_PAD_NAKED(3, 29, PAD_MUXSEL_GPIO) | ||
516 | #define MX28_PAD_LCD_RESET__GPIO_3_30 MXS_IOMUX_PAD_NAKED(3, 30, PAD_MUXSEL_GPIO) | ||
517 | |||
518 | #define MX28_PAD_ENET0_MDC__GPIO_4_0 MXS_IOMUX_PAD_NAKED(4, 0, PAD_MUXSEL_GPIO) | ||
519 | #define MX28_PAD_ENET0_MDIO__GPIO_4_1 MXS_IOMUX_PAD_NAKED(4, 1, PAD_MUXSEL_GPIO) | ||
520 | #define MX28_PAD_ENET0_RX_EN__GPIO_4_2 MXS_IOMUX_PAD_NAKED(4, 2, PAD_MUXSEL_GPIO) | ||
521 | #define MX28_PAD_ENET0_RXD0__GPIO_4_3 MXS_IOMUX_PAD_NAKED(4, 3, PAD_MUXSEL_GPIO) | ||
522 | #define MX28_PAD_ENET0_RXD1__GPIO_4_4 MXS_IOMUX_PAD_NAKED(4, 4, PAD_MUXSEL_GPIO) | ||
523 | #define MX28_PAD_ENET0_TX_CLK__GPIO_4_5 MXS_IOMUX_PAD_NAKED(4, 5, PAD_MUXSEL_GPIO) | ||
524 | #define MX28_PAD_ENET0_TX_EN__GPIO_4_6 MXS_IOMUX_PAD_NAKED(4, 6, PAD_MUXSEL_GPIO) | ||
525 | #define MX28_PAD_ENET0_TXD0__GPIO_4_7 MXS_IOMUX_PAD_NAKED(4, 7, PAD_MUXSEL_GPIO) | ||
526 | #define MX28_PAD_ENET0_TXD1__GPIO_4_8 MXS_IOMUX_PAD_NAKED(4, 8, PAD_MUXSEL_GPIO) | ||
527 | #define MX28_PAD_ENET0_RXD2__GPIO_4_9 MXS_IOMUX_PAD_NAKED(4, 9, PAD_MUXSEL_GPIO) | ||
528 | #define MX28_PAD_ENET0_RXD3__GPIO_4_10 MXS_IOMUX_PAD_NAKED(4, 10, PAD_MUXSEL_GPIO) | ||
529 | #define MX28_PAD_ENET0_TXD2__GPIO_4_11 MXS_IOMUX_PAD_NAKED(4, 11, PAD_MUXSEL_GPIO) | ||
530 | #define MX28_PAD_ENET0_TXD3__GPIO_4_12 MXS_IOMUX_PAD_NAKED(4, 12, PAD_MUXSEL_GPIO) | ||
531 | #define MX28_PAD_ENET0_RX_CLK__GPIO_4_13 MXS_IOMUX_PAD_NAKED(4, 13, PAD_MUXSEL_GPIO) | ||
532 | #define MX28_PAD_ENET0_COL__GPIO_4_14 MXS_IOMUX_PAD_NAKED(4, 14, PAD_MUXSEL_GPIO) | ||
533 | #define MX28_PAD_ENET0_CRS__GPIO_4_15 MXS_IOMUX_PAD_NAKED(4, 15, PAD_MUXSEL_GPIO) | ||
534 | #define MX28_PAD_ENET_CLK__GPIO_4_16 MXS_IOMUX_PAD_NAKED(4, 16, PAD_MUXSEL_GPIO) | ||
535 | #define MX28_PAD_JTAG_RTCK__GPIO_4_20 MXS_IOMUX_PAD_NAKED(4, 20, PAD_MUXSEL_GPIO) | ||
536 | |||
537 | #endif /* __MACH_IOMUX_MX28_H__ */ | ||
diff --git a/arch/arm/mach-mxs/include/mach/iomux.h b/arch/arm/mach-mxs/include/mach/iomux.h new file mode 100644 index 00000000000..7abdf58b8bb --- /dev/null +++ b/arch/arm/mach-mxs/include/mach/iomux.h | |||
@@ -0,0 +1,168 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2009 by Jan Weitzel Phytec Messtechnik GmbH, | ||
3 | * <armlinux@phytec.de> | ||
4 | * Copyright (C) 2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or | ||
7 | * modify it under the terms of the GNU General Public License | ||
8 | * as published by the Free Software Foundation; either version 2 | ||
9 | * of the License, or (at your option) any later version. | ||
10 | * This program is distributed in the hope that it will be useful, | ||
11 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
12 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
13 | * GNU General Public License for more details. | ||
14 | * | ||
15 | * You should have received a copy of the GNU General Public License | ||
16 | * along with this program; if not, write to the Free Software | ||
17 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, | ||
18 | * MA 02110-1301, USA. | ||
19 | */ | ||
20 | |||
21 | #ifndef __MACH_MXS_IOMUX_H__ | ||
22 | #define __MACH_MXS_IOMUX_H__ | ||
23 | |||
24 | /* | ||
25 | * IOMUX/PAD Bit field definitions | ||
26 | * | ||
27 | * PAD_BANK: 0..2 (3) | ||
28 | * PAD_PIN: 3..7 (5) | ||
29 | * PAD_MUXSEL: 8..9 (2) | ||
30 | * PAD_MA: 10..11 (2) | ||
31 | * PAD_MA_VALID: 12 (1) | ||
32 | * PAD_VOL: 13 (1) | ||
33 | * PAD_VOL_VALID: 14 (1) | ||
34 | * PAD_PULL: 15 (1) | ||
35 | * PAD_PULL_VALID: 16 (1) | ||
36 | * RESERVED: 17..31 (15) | ||
37 | */ | ||
38 | typedef u32 iomux_cfg_t; | ||
39 | |||
40 | #define MXS_PAD_BANK_SHIFT 0 | ||
41 | #define MXS_PAD_BANK_MASK ((iomux_cfg_t)0x7 << MXS_PAD_BANK_SHIFT) | ||
42 | #define MXS_PAD_PIN_SHIFT 3 | ||
43 | #define MXS_PAD_PIN_MASK ((iomux_cfg_t)0x1f << MXS_PAD_PIN_SHIFT) | ||
44 | #define MXS_PAD_MUXSEL_SHIFT 8 | ||
45 | #define MXS_PAD_MUXSEL_MASK ((iomux_cfg_t)0x3 << MXS_PAD_MUXSEL_SHIFT) | ||
46 | #define MXS_PAD_MA_SHIFT 10 | ||
47 | #define MXS_PAD_MA_MASK ((iomux_cfg_t)0x3 << MXS_PAD_MA_SHIFT) | ||
48 | #define MXS_PAD_MA_VALID_SHIFT 12 | ||
49 | #define MXS_PAD_MA_VALID_MASK ((iomux_cfg_t)0x1 << MXS_PAD_MA_VALID_SHIFT) | ||
50 | #define MXS_PAD_VOL_SHIFT 13 | ||
51 | #define MXS_PAD_VOL_MASK ((iomux_cfg_t)0x1 << MXS_PAD_VOL_SHIFT) | ||
52 | #define MXS_PAD_VOL_VALID_SHIFT 14 | ||
53 | #define MXS_PAD_VOL_VALID_MASK ((iomux_cfg_t)0x1 << MXS_PAD_VOL_VALID_SHIFT) | ||
54 | #define MXS_PAD_PULL_SHIFT 15 | ||
55 | #define MXS_PAD_PULL_MASK ((iomux_cfg_t)0x1 << MXS_PAD_PULL_SHIFT) | ||
56 | #define MXS_PAD_PULL_VALID_SHIFT 16 | ||
57 | #define MXS_PAD_PULL_VALID_MASK ((iomux_cfg_t)0x1 << MXS_PAD_PULL_VALID_SHIFT) | ||
58 | |||
59 | #define PAD_MUXSEL_0 0 | ||
60 | #define PAD_MUXSEL_1 1 | ||
61 | #define PAD_MUXSEL_2 2 | ||
62 | #define PAD_MUXSEL_GPIO 3 | ||
63 | |||
64 | #define PAD_4MA 0 | ||
65 | #define PAD_8MA 1 | ||
66 | #define PAD_12MA 2 | ||
67 | #define PAD_16MA 3 | ||
68 | |||
69 | #define PAD_1V8 0 | ||
70 | #define PAD_3V3 1 | ||
71 | |||
72 | #define PAD_NOPULL 0 | ||
73 | #define PAD_PULLUP 1 | ||
74 | |||
75 | #define MXS_PAD_4MA ((PAD_4MA << MXS_PAD_MA_SHIFT) | \ | ||
76 | MXS_PAD_MA_VALID_MASK) | ||
77 | #define MXS_PAD_8MA ((PAD_8MA << MXS_PAD_MA_SHIFT) | \ | ||
78 | MXS_PAD_MA_VALID_MASK) | ||
79 | #define MXS_PAD_12MA ((PAD_12MA << MXS_PAD_MA_SHIFT) | \ | ||
80 | MXS_PAD_MA_VALID_MASK) | ||
81 | #define MXS_PAD_16MA ((PAD_16MA << MXS_PAD_MA_SHIFT) | \ | ||
82 | MXS_PAD_MA_VALID_MASK) | ||
83 | |||
84 | #define MXS_PAD_1V8 ((PAD_1V8 << MXS_PAD_VOL_SHIFT) | \ | ||
85 | MXS_PAD_VOL_VALID_MASK) | ||
86 | #define MXS_PAD_3V3 ((PAD_3V3 << MXS_PAD_VOL_SHIFT) | \ | ||
87 | MXS_PAD_VOL_VALID_MASK) | ||
88 | |||
89 | #define MXS_PAD_NOPULL ((PAD_NOPULL << MXS_PAD_PULL_SHIFT) | \ | ||
90 | MXS_PAD_PULL_VALID_MASK) | ||
91 | #define MXS_PAD_PULLUP ((PAD_PULLUP << MXS_PAD_PULL_SHIFT) | \ | ||
92 | MXS_PAD_PULL_VALID_MASK) | ||
93 | |||
94 | /* generic pad control used in most cases */ | ||
95 | #define MXS_PAD_CTRL (MXS_PAD_4MA | MXS_PAD_3V3 | MXS_PAD_NOPULL) | ||
96 | |||
97 | #define MXS_IOMUX_PAD(_bank, _pin, _muxsel, _ma, _vol, _pull) \ | ||
98 | (((iomux_cfg_t)(_bank) << MXS_PAD_BANK_SHIFT) | \ | ||
99 | ((iomux_cfg_t)(_pin) << MXS_PAD_PIN_SHIFT) | \ | ||
100 | ((iomux_cfg_t)(_muxsel) << MXS_PAD_MUXSEL_SHIFT) | \ | ||
101 | ((iomux_cfg_t)(_ma) << MXS_PAD_MA_SHIFT) | \ | ||
102 | ((iomux_cfg_t)(_vol) << MXS_PAD_VOL_SHIFT) | \ | ||
103 | ((iomux_cfg_t)(_pull) << MXS_PAD_PULL_SHIFT)) | ||
104 | |||
105 | /* | ||
106 | * A pad becomes naked, when none of mA, vol or pull | ||
107 | * validity bits is set. | ||
108 | */ | ||
109 | #define MXS_IOMUX_PAD_NAKED(_bank, _pin, _muxsel) \ | ||
110 | MXS_IOMUX_PAD(_bank, _pin, _muxsel, 0, 0, 0) | ||
111 | |||
112 | static inline unsigned int PAD_BANK(iomux_cfg_t pad) | ||
113 | { | ||
114 | return (pad & MXS_PAD_BANK_MASK) >> MXS_PAD_BANK_SHIFT; | ||
115 | } | ||
116 | |||
117 | static inline unsigned int PAD_PIN(iomux_cfg_t pad) | ||
118 | { | ||
119 | return (pad & MXS_PAD_PIN_MASK) >> MXS_PAD_PIN_SHIFT; | ||
120 | } | ||
121 | |||
122 | static inline unsigned int PAD_MUXSEL(iomux_cfg_t pad) | ||
123 | { | ||
124 | return (pad & MXS_PAD_MUXSEL_MASK) >> MXS_PAD_MUXSEL_SHIFT; | ||
125 | } | ||
126 | |||
127 | static inline unsigned int PAD_MA(iomux_cfg_t pad) | ||
128 | { | ||
129 | return (pad & MXS_PAD_MA_MASK) >> MXS_PAD_MA_SHIFT; | ||
130 | } | ||
131 | |||
132 | static inline unsigned int PAD_MA_VALID(iomux_cfg_t pad) | ||
133 | { | ||
134 | return (pad & MXS_PAD_MA_VALID_MASK) >> MXS_PAD_MA_VALID_SHIFT; | ||
135 | } | ||
136 | |||
137 | static inline unsigned int PAD_VOL(iomux_cfg_t pad) | ||
138 | { | ||
139 | return (pad & MXS_PAD_VOL_MASK) >> MXS_PAD_VOL_SHIFT; | ||
140 | } | ||
141 | |||
142 | static inline unsigned int PAD_VOL_VALID(iomux_cfg_t pad) | ||
143 | { | ||
144 | return (pad & MXS_PAD_VOL_VALID_MASK) >> MXS_PAD_VOL_VALID_SHIFT; | ||
145 | } | ||
146 | |||
147 | static inline unsigned int PAD_PULL(iomux_cfg_t pad) | ||
148 | { | ||
149 | return (pad & MXS_PAD_PULL_MASK) >> MXS_PAD_PULL_SHIFT; | ||
150 | } | ||
151 | |||
152 | static inline unsigned int PAD_PULL_VALID(iomux_cfg_t pad) | ||
153 | { | ||
154 | return (pad & MXS_PAD_PULL_VALID_MASK) >> MXS_PAD_PULL_VALID_SHIFT; | ||
155 | } | ||
156 | |||
157 | /* | ||
158 | * configures a single pad in the iomuxer | ||
159 | */ | ||
160 | int mxs_iomux_setup_pad(iomux_cfg_t pad); | ||
161 | |||
162 | /* | ||
163 | * configures multiple pads | ||
164 | * convenient way to call the above function with tables | ||
165 | */ | ||
166 | int mxs_iomux_setup_multiple_pads(const iomux_cfg_t *pad_list, unsigned count); | ||
167 | |||
168 | #endif /* __MACH_MXS_IOMUX_H__*/ | ||
diff --git a/arch/arm/mach-mxs/include/mach/irqs.h b/arch/arm/mach-mxs/include/mach/irqs.h new file mode 100644 index 00000000000..f771039b814 --- /dev/null +++ b/arch/arm/mach-mxs/include/mach/irqs.h | |||
@@ -0,0 +1,32 @@ | |||
1 | /* | ||
2 | * Copyright 2004-2007 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | */ | ||
4 | |||
5 | /* | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #ifndef __MACH_MXS_IRQS_H__ | ||
12 | #define __MACH_MXS_IRQS_H__ | ||
13 | |||
14 | #define MXS_INTERNAL_IRQS 128 | ||
15 | |||
16 | #define MXS_GPIO_IRQ_START MXS_INTERNAL_IRQS | ||
17 | |||
18 | /* the maximum for MXS-based */ | ||
19 | #define MXS_GPIO_IRQS (32 * 5) | ||
20 | |||
21 | /* | ||
22 | * The next 16 interrupts are for board specific purposes. Since | ||
23 | * the kernel can only run on one machine at a time, we can re-use | ||
24 | * these. If you need more, increase MXS_BOARD_IRQS, but keep it | ||
25 | * within sensible limits. | ||
26 | */ | ||
27 | #define MXS_BOARD_IRQ_START (MXS_GPIO_IRQ_START + MXS_GPIO_IRQS) | ||
28 | #define MXS_BOARD_IRQS 16 | ||
29 | |||
30 | #define NR_IRQS (MXS_BOARD_IRQ_START + MXS_BOARD_IRQS) | ||
31 | |||
32 | #endif /* __MACH_MXS_IRQS_H__ */ | ||
diff --git a/arch/arm/mach-mxs/include/mach/memory.h b/arch/arm/mach-mxs/include/mach/memory.h new file mode 100644 index 00000000000..b5420a5c2d4 --- /dev/null +++ b/arch/arm/mach-mxs/include/mach/memory.h | |||
@@ -0,0 +1,24 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2009-2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or modify | ||
5 | * it under the terms of the GNU General Public License as published by | ||
6 | * the Free Software Foundation; either version 2 of the License, or | ||
7 | * (at your option) any later version. | ||
8 | * | ||
9 | * This program is distributed in the hope that it will be useful, | ||
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
12 | * GNU General Public License for more details. | ||
13 | * | ||
14 | * You should have received a copy of the GNU General Public License along | ||
15 | * with this program; if not, write to the Free Software Foundation, Inc., | ||
16 | * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | ||
17 | */ | ||
18 | |||
19 | #ifndef __MACH_MXS_MEMORY_H__ | ||
20 | #define __MACH_MXS_MEMORY_H__ | ||
21 | |||
22 | #define PHYS_OFFSET UL(0x40000000) | ||
23 | |||
24 | #endif /* __MACH_MXS_MEMORY_H__ */ | ||
diff --git a/arch/arm/mach-mxs/include/mach/mmc.h b/arch/arm/mach-mxs/include/mach/mmc.h new file mode 100644 index 00000000000..211547a0556 --- /dev/null +++ b/arch/arm/mach-mxs/include/mach/mmc.h | |||
@@ -0,0 +1,18 @@ | |||
1 | /* | ||
2 | * Copyright 2011 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or modify | ||
5 | * it under the terms of the GNU General Public License version 2 as | ||
6 | * published by the Free Software Foundation. | ||
7 | */ | ||
8 | |||
9 | #ifndef __MACH_MXS_MMC_H__ | ||
10 | #define __MACH_MXS_MMC_H__ | ||
11 | |||
12 | struct mxs_mmc_platform_data { | ||
13 | int wp_gpio; /* write protect pin */ | ||
14 | unsigned int flags; | ||
15 | #define SLOTF_4_BIT_CAPABLE (1 << 0) | ||
16 | #define SLOTF_8_BIT_CAPABLE (1 << 1) | ||
17 | }; | ||
18 | #endif /* __MACH_MXS_MMC_H__ */ | ||
diff --git a/arch/arm/mach-mxs/include/mach/mxsfb.h b/arch/arm/mach-mxs/include/mach/mxsfb.h new file mode 100644 index 00000000000..e4d79791515 --- /dev/null +++ b/arch/arm/mach-mxs/include/mach/mxsfb.h | |||
@@ -0,0 +1,49 @@ | |||
1 | /* | ||
2 | * This program is free software; you can redistribute it and/or | ||
3 | * modify it under the terms of the GNU General Public License | ||
4 | * as published by the Free Software Foundation; either version 2 | ||
5 | * of the License, or (at your option) any later version. | ||
6 | * This program is distributed in the hope that it will be useful, | ||
7 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
8 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
9 | * GNU General Public License for more details. | ||
10 | * | ||
11 | * You should have received a copy of the GNU General Public License | ||
12 | * along with this program; if not, write to the Free Software | ||
13 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, | ||
14 | * MA 02110-1301, USA. | ||
15 | */ | ||
16 | |||
17 | #ifndef __MACH_FB_H | ||
18 | #define __MACH_FB_H | ||
19 | |||
20 | #include <linux/fb.h> | ||
21 | |||
22 | #define STMLCDIF_8BIT 1 /** pixel data bus to the display is of 8 bit width */ | ||
23 | #define STMLCDIF_16BIT 0 /** pixel data bus to the display is of 16 bit width */ | ||
24 | #define STMLCDIF_18BIT 2 /** pixel data bus to the display is of 18 bit width */ | ||
25 | #define STMLCDIF_24BIT 3 /** pixel data bus to the display is of 24 bit width */ | ||
26 | |||
27 | #define FB_SYNC_DATA_ENABLE_HIGH_ACT (1 << 6) | ||
28 | #define FB_SYNC_DOTCLK_FAILING_ACT (1 << 7) /* failing/negtive edge sampling */ | ||
29 | |||
30 | struct mxsfb_platform_data { | ||
31 | struct fb_videomode *mode_list; | ||
32 | unsigned mode_count; | ||
33 | |||
34 | unsigned default_bpp; | ||
35 | |||
36 | unsigned dotclk_delay; /* refer manual HW_LCDIF_VDCTRL4 register */ | ||
37 | unsigned ld_intf_width; /* refer STMLCDIF_* macros */ | ||
38 | |||
39 | unsigned fb_size; /* Size of the video memory. If zero a | ||
40 | * default will be used | ||
41 | */ | ||
42 | unsigned long fb_phys; /* physical address for the video memory. If | ||
43 | * zero the framebuffer memory will be dynamically | ||
44 | * allocated. If specified,fb_size must also be specified. | ||
45 | * fb_phys must be unused by Linux. | ||
46 | */ | ||
47 | }; | ||
48 | |||
49 | #endif /* __MACH_FB_H */ | ||
diff --git a/arch/arm/mach-mxs/include/mach/system.h b/arch/arm/mach-mxs/include/mach/system.h new file mode 100644 index 00000000000..0e428239b43 --- /dev/null +++ b/arch/arm/mach-mxs/include/mach/system.h | |||
@@ -0,0 +1,27 @@ | |||
1 | /* | ||
2 | * Copyright (C) 1999 ARM Limited | ||
3 | * Copyright (C) 2000 Deep Blue Solutions Ltd | ||
4 | * Copyright 2004-2008 Freescale Semiconductor, Inc. All Rights Reserved. | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License as published by | ||
8 | * the Free Software Foundation; either version 2 of the License, or | ||
9 | * (at your option) any later version. | ||
10 | * | ||
11 | * This program is distributed in the hope that it will be useful, | ||
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
14 | * GNU General Public License for more details. | ||
15 | */ | ||
16 | |||
17 | #ifndef __MACH_MXS_SYSTEM_H__ | ||
18 | #define __MACH_MXS_SYSTEM_H__ | ||
19 | |||
20 | static inline void arch_idle(void) | ||
21 | { | ||
22 | cpu_do_idle(); | ||
23 | } | ||
24 | |||
25 | void arch_reset(char mode, const char *cmd); | ||
26 | |||
27 | #endif /* __MACH_MXS_SYSTEM_H__ */ | ||
diff --git a/arch/arm/mach-mxs/include/mach/vmalloc.h b/arch/arm/mach-mxs/include/mach/vmalloc.h new file mode 100644 index 00000000000..103b0165ed0 --- /dev/null +++ b/arch/arm/mach-mxs/include/mach/vmalloc.h | |||
@@ -0,0 +1,22 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2000 Russell King. | ||
3 | * Copyright 2004-2007 Freescale Semiconductor, Inc. All Rights Reserved. | ||
4 | * | ||
5 | * This program is free software; you can redistribute it and/or modify | ||
6 | * it under the terms of the GNU General Public License as published by | ||
7 | * the Free Software Foundation; either version 2 of the License, or | ||
8 | * (at your option) any later version. | ||
9 | * | ||
10 | * This program is distributed in the hope that it will be useful, | ||
11 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
12 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
13 | * GNU General Public License for more details. | ||
14 | */ | ||
15 | |||
16 | #ifndef __MACH_MXS_VMALLOC_H__ | ||
17 | #define __MACH_MXS_VMALLOC_H__ | ||
18 | |||
19 | /* vmalloc ending address */ | ||
20 | #define VMALLOC_END 0xf4000000UL | ||
21 | |||
22 | #endif /* __MACH_MXS_VMALLOC_H__ */ | ||
diff --git a/arch/arm/mach-mxs/iomux.c b/arch/arm/mach-mxs/iomux.c new file mode 100644 index 00000000000..0e804e2f11f --- /dev/null +++ b/arch/arm/mach-mxs/iomux.c | |||
@@ -0,0 +1,101 @@ | |||
1 | /* | ||
2 | * Copyright 2004-2006,2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | * Copyright (C) 2008 by Sascha Hauer <kernel@pengutronix.de> | ||
4 | * Copyright (C) 2009 by Jan Weitzel Phytec Messtechnik GmbH, | ||
5 | * <armlinux@phytec.de> | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or | ||
8 | * modify it under the terms of the GNU General Public License | ||
9 | * as published by the Free Software Foundation; either version 2 | ||
10 | * of the License, or (at your option) any later version. | ||
11 | * This program is distributed in the hope that it will be useful, | ||
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
14 | * GNU General Public License for more details. | ||
15 | * | ||
16 | * You should have received a copy of the GNU General Public License | ||
17 | * along with this program; if not, write to the Free Software | ||
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, | ||
19 | * MA 02110-1301, USA. | ||
20 | */ | ||
21 | |||
22 | #include <linux/errno.h> | ||
23 | #include <linux/init.h> | ||
24 | #include <linux/kernel.h> | ||
25 | #include <linux/module.h> | ||
26 | #include <linux/string.h> | ||
27 | #include <linux/gpio.h> | ||
28 | |||
29 | #include <asm/mach/map.h> | ||
30 | |||
31 | #include <mach/mxs.h> | ||
32 | #include <mach/iomux.h> | ||
33 | |||
34 | /* | ||
35 | * configures a single pad in the iomuxer | ||
36 | */ | ||
37 | int mxs_iomux_setup_pad(iomux_cfg_t pad) | ||
38 | { | ||
39 | u32 reg, ofs, bp, bm; | ||
40 | void __iomem *iomux_base = MXS_IO_ADDRESS(MXS_PINCTRL_BASE_ADDR); | ||
41 | |||
42 | /* muxsel */ | ||
43 | ofs = 0x100; | ||
44 | ofs += PAD_BANK(pad) * 0x20 + PAD_PIN(pad) / 16 * 0x10; | ||
45 | bp = PAD_PIN(pad) % 16 * 2; | ||
46 | bm = 0x3 << bp; | ||
47 | reg = __raw_readl(iomux_base + ofs); | ||
48 | reg &= ~bm; | ||
49 | reg |= PAD_MUXSEL(pad) << bp; | ||
50 | __raw_writel(reg, iomux_base + ofs); | ||
51 | |||
52 | /* drive */ | ||
53 | ofs = cpu_is_mx23() ? 0x200 : 0x300; | ||
54 | ofs += PAD_BANK(pad) * 0x40 + PAD_PIN(pad) / 8 * 0x10; | ||
55 | /* mA */ | ||
56 | if (PAD_MA_VALID(pad)) { | ||
57 | bp = PAD_PIN(pad) % 8 * 4; | ||
58 | bm = 0x3 << bp; | ||
59 | reg = __raw_readl(iomux_base + ofs); | ||
60 | reg &= ~bm; | ||
61 | reg |= PAD_MA(pad) << bp; | ||
62 | __raw_writel(reg, iomux_base + ofs); | ||
63 | } | ||
64 | /* vol */ | ||
65 | if (PAD_VOL_VALID(pad)) { | ||
66 | bp = PAD_PIN(pad) % 8 * 4 + 2; | ||
67 | if (PAD_VOL(pad)) | ||
68 | __mxs_setl(1 << bp, iomux_base + ofs); | ||
69 | else | ||
70 | __mxs_clrl(1 << bp, iomux_base + ofs); | ||
71 | } | ||
72 | |||
73 | /* pull */ | ||
74 | if (PAD_PULL_VALID(pad)) { | ||
75 | ofs = cpu_is_mx23() ? 0x400 : 0x600; | ||
76 | ofs += PAD_BANK(pad) * 0x10; | ||
77 | bp = PAD_PIN(pad); | ||
78 | if (PAD_PULL(pad)) | ||
79 | __mxs_setl(1 << bp, iomux_base + ofs); | ||
80 | else | ||
81 | __mxs_clrl(1 << bp, iomux_base + ofs); | ||
82 | } | ||
83 | |||
84 | return 0; | ||
85 | } | ||
86 | |||
87 | int mxs_iomux_setup_multiple_pads(const iomux_cfg_t *pad_list, unsigned count) | ||
88 | { | ||
89 | const iomux_cfg_t *p = pad_list; | ||
90 | int i; | ||
91 | int ret; | ||
92 | |||
93 | for (i = 0; i < count; i++) { | ||
94 | ret = mxs_iomux_setup_pad(*p); | ||
95 | if (ret) | ||
96 | return ret; | ||
97 | p++; | ||
98 | } | ||
99 | |||
100 | return 0; | ||
101 | } | ||
diff --git a/arch/arm/mach-mxs/mach-mx23evk.c b/arch/arm/mach-mxs/mach-mx23evk.c new file mode 100644 index 00000000000..3c2de33803a --- /dev/null +++ b/arch/arm/mach-mxs/mach-mx23evk.c | |||
@@ -0,0 +1,187 @@ | |||
1 | /* | ||
2 | * Copyright 2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or modify | ||
5 | * it under the terms of the GNU General Public License as published by | ||
6 | * the Free Software Foundation; either version 2 of the License, or | ||
7 | * (at your option) any later version. | ||
8 | * | ||
9 | * This program is distributed in the hope that it will be useful, | ||
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
12 | * GNU General Public License for more details. | ||
13 | */ | ||
14 | |||
15 | #include <linux/delay.h> | ||
16 | #include <linux/platform_device.h> | ||
17 | #include <linux/gpio.h> | ||
18 | #include <linux/irq.h> | ||
19 | |||
20 | #include <asm/mach-types.h> | ||
21 | #include <asm/mach/arch.h> | ||
22 | #include <asm/mach/time.h> | ||
23 | |||
24 | #include <mach/common.h> | ||
25 | #include <mach/iomux-mx23.h> | ||
26 | |||
27 | #include "devices-mx23.h" | ||
28 | |||
29 | #define MX23EVK_LCD_ENABLE MXS_GPIO_NR(1, 18) | ||
30 | #define MX23EVK_BL_ENABLE MXS_GPIO_NR(1, 28) | ||
31 | #define MX23EVK_MMC0_WRITE_PROTECT MXS_GPIO_NR(1, 30) | ||
32 | #define MX23EVK_MMC0_SLOT_POWER MXS_GPIO_NR(1, 29) | ||
33 | |||
34 | static const iomux_cfg_t mx23evk_pads[] __initconst = { | ||
35 | /* duart */ | ||
36 | MX23_PAD_PWM0__DUART_RX | MXS_PAD_CTRL, | ||
37 | MX23_PAD_PWM1__DUART_TX | MXS_PAD_CTRL, | ||
38 | |||
39 | /* auart */ | ||
40 | MX23_PAD_AUART1_RX__AUART1_RX | MXS_PAD_CTRL, | ||
41 | MX23_PAD_AUART1_TX__AUART1_TX | MXS_PAD_CTRL, | ||
42 | MX23_PAD_AUART1_CTS__AUART1_CTS | MXS_PAD_CTRL, | ||
43 | MX23_PAD_AUART1_RTS__AUART1_RTS | MXS_PAD_CTRL, | ||
44 | |||
45 | /* mxsfb (lcdif) */ | ||
46 | MX23_PAD_LCD_D00__LCD_D00 | MXS_PAD_CTRL, | ||
47 | MX23_PAD_LCD_D01__LCD_D01 | MXS_PAD_CTRL, | ||
48 | MX23_PAD_LCD_D02__LCD_D02 | MXS_PAD_CTRL, | ||
49 | MX23_PAD_LCD_D03__LCD_D03 | MXS_PAD_CTRL, | ||
50 | MX23_PAD_LCD_D04__LCD_D04 | MXS_PAD_CTRL, | ||
51 | MX23_PAD_LCD_D05__LCD_D05 | MXS_PAD_CTRL, | ||
52 | MX23_PAD_LCD_D06__LCD_D06 | MXS_PAD_CTRL, | ||
53 | MX23_PAD_LCD_D07__LCD_D07 | MXS_PAD_CTRL, | ||
54 | MX23_PAD_LCD_D08__LCD_D08 | MXS_PAD_CTRL, | ||
55 | MX23_PAD_LCD_D09__LCD_D09 | MXS_PAD_CTRL, | ||
56 | MX23_PAD_LCD_D10__LCD_D10 | MXS_PAD_CTRL, | ||
57 | MX23_PAD_LCD_D11__LCD_D11 | MXS_PAD_CTRL, | ||
58 | MX23_PAD_LCD_D12__LCD_D12 | MXS_PAD_CTRL, | ||
59 | MX23_PAD_LCD_D13__LCD_D13 | MXS_PAD_CTRL, | ||
60 | MX23_PAD_LCD_D14__LCD_D14 | MXS_PAD_CTRL, | ||
61 | MX23_PAD_LCD_D15__LCD_D15 | MXS_PAD_CTRL, | ||
62 | MX23_PAD_LCD_D16__LCD_D16 | MXS_PAD_CTRL, | ||
63 | MX23_PAD_LCD_D17__LCD_D17 | MXS_PAD_CTRL, | ||
64 | MX23_PAD_GPMI_D08__LCD_D18 | MXS_PAD_CTRL, | ||
65 | MX23_PAD_GPMI_D09__LCD_D19 | MXS_PAD_CTRL, | ||
66 | MX23_PAD_GPMI_D10__LCD_D20 | MXS_PAD_CTRL, | ||
67 | MX23_PAD_GPMI_D11__LCD_D21 | MXS_PAD_CTRL, | ||
68 | MX23_PAD_GPMI_D12__LCD_D22 | MXS_PAD_CTRL, | ||
69 | MX23_PAD_GPMI_D13__LCD_D23 | MXS_PAD_CTRL, | ||
70 | MX23_PAD_LCD_VSYNC__LCD_VSYNC | MXS_PAD_CTRL, | ||
71 | MX23_PAD_LCD_HSYNC__LCD_HSYNC | MXS_PAD_CTRL, | ||
72 | MX23_PAD_LCD_DOTCK__LCD_DOTCK | MXS_PAD_CTRL, | ||
73 | MX23_PAD_LCD_ENABLE__LCD_ENABLE | MXS_PAD_CTRL, | ||
74 | /* LCD panel enable */ | ||
75 | MX23_PAD_LCD_RESET__GPIO_1_18 | MXS_PAD_CTRL, | ||
76 | /* backlight control */ | ||
77 | MX23_PAD_PWM2__GPIO_1_28 | MXS_PAD_CTRL, | ||
78 | |||
79 | /* mmc */ | ||
80 | MX23_PAD_SSP1_DATA0__SSP1_DATA0 | | ||
81 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
82 | MX23_PAD_SSP1_DATA1__SSP1_DATA1 | | ||
83 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
84 | MX23_PAD_SSP1_DATA2__SSP1_DATA2 | | ||
85 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
86 | MX23_PAD_SSP1_DATA3__SSP1_DATA3 | | ||
87 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
88 | MX23_PAD_GPMI_D08__SSP1_DATA4 | | ||
89 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
90 | MX23_PAD_GPMI_D09__SSP1_DATA5 | | ||
91 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
92 | MX23_PAD_GPMI_D10__SSP1_DATA6 | | ||
93 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
94 | MX23_PAD_GPMI_D11__SSP1_DATA7 | | ||
95 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
96 | MX23_PAD_SSP1_CMD__SSP1_CMD | | ||
97 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
98 | MX23_PAD_SSP1_DETECT__SSP1_DETECT | | ||
99 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_NOPULL), | ||
100 | MX23_PAD_SSP1_SCK__SSP1_SCK | | ||
101 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_NOPULL), | ||
102 | /* write protect */ | ||
103 | MX23_PAD_PWM4__GPIO_1_30 | | ||
104 | (MXS_PAD_4MA | MXS_PAD_3V3 | MXS_PAD_NOPULL), | ||
105 | /* slot power enable */ | ||
106 | MX23_PAD_PWM3__GPIO_1_29 | | ||
107 | (MXS_PAD_4MA | MXS_PAD_3V3 | MXS_PAD_NOPULL), | ||
108 | }; | ||
109 | |||
110 | /* mxsfb (lcdif) */ | ||
111 | static struct fb_videomode mx23evk_video_modes[] = { | ||
112 | { | ||
113 | .name = "Samsung-LMS430HF02", | ||
114 | .refresh = 60, | ||
115 | .xres = 480, | ||
116 | .yres = 272, | ||
117 | .pixclock = 108096, /* picosecond (9.2 MHz) */ | ||
118 | .left_margin = 15, | ||
119 | .right_margin = 8, | ||
120 | .upper_margin = 12, | ||
121 | .lower_margin = 4, | ||
122 | .hsync_len = 1, | ||
123 | .vsync_len = 1, | ||
124 | .sync = FB_SYNC_DATA_ENABLE_HIGH_ACT | | ||
125 | FB_SYNC_DOTCLK_FAILING_ACT, | ||
126 | }, | ||
127 | }; | ||
128 | |||
129 | static const struct mxsfb_platform_data mx23evk_mxsfb_pdata __initconst = { | ||
130 | .mode_list = mx23evk_video_modes, | ||
131 | .mode_count = ARRAY_SIZE(mx23evk_video_modes), | ||
132 | .default_bpp = 32, | ||
133 | .ld_intf_width = STMLCDIF_24BIT, | ||
134 | }; | ||
135 | |||
136 | static struct mxs_mmc_platform_data mx23evk_mmc_pdata __initdata = { | ||
137 | .wp_gpio = MX23EVK_MMC0_WRITE_PROTECT, | ||
138 | .flags = SLOTF_8_BIT_CAPABLE, | ||
139 | }; | ||
140 | |||
141 | static void __init mx23evk_init(void) | ||
142 | { | ||
143 | int ret; | ||
144 | |||
145 | mxs_iomux_setup_multiple_pads(mx23evk_pads, ARRAY_SIZE(mx23evk_pads)); | ||
146 | |||
147 | mx23_add_duart(); | ||
148 | mx23_add_auart0(); | ||
149 | |||
150 | /* power on mmc slot by writing 0 to the gpio */ | ||
151 | ret = gpio_request_one(MX23EVK_MMC0_SLOT_POWER, GPIOF_OUT_INIT_LOW, | ||
152 | "mmc0-slot-power"); | ||
153 | if (ret) | ||
154 | pr_warn("failed to request gpio mmc0-slot-power: %d\n", ret); | ||
155 | mx23_add_mxs_mmc(0, &mx23evk_mmc_pdata); | ||
156 | |||
157 | ret = gpio_request_one(MX23EVK_LCD_ENABLE, GPIOF_DIR_OUT, "lcd-enable"); | ||
158 | if (ret) | ||
159 | pr_warn("failed to request gpio lcd-enable: %d\n", ret); | ||
160 | else | ||
161 | gpio_set_value(MX23EVK_LCD_ENABLE, 1); | ||
162 | |||
163 | ret = gpio_request_one(MX23EVK_BL_ENABLE, GPIOF_DIR_OUT, "bl-enable"); | ||
164 | if (ret) | ||
165 | pr_warn("failed to request gpio bl-enable: %d\n", ret); | ||
166 | else | ||
167 | gpio_set_value(MX23EVK_BL_ENABLE, 1); | ||
168 | |||
169 | mx23_add_mxsfb(&mx23evk_mxsfb_pdata); | ||
170 | } | ||
171 | |||
172 | static void __init mx23evk_timer_init(void) | ||
173 | { | ||
174 | mx23_clocks_init(); | ||
175 | } | ||
176 | |||
177 | static struct sys_timer mx23evk_timer = { | ||
178 | .init = mx23evk_timer_init, | ||
179 | }; | ||
180 | |||
181 | MACHINE_START(MX23EVK, "Freescale MX23 EVK") | ||
182 | /* Maintainer: Freescale Semiconductor, Inc. */ | ||
183 | .map_io = mx23_map_io, | ||
184 | .init_irq = mx23_init_irq, | ||
185 | .init_machine = mx23evk_init, | ||
186 | .timer = &mx23evk_timer, | ||
187 | MACHINE_END | ||
diff --git a/arch/arm/mach-mxs/mach-mx28evk.c b/arch/arm/mach-mxs/mach-mx28evk.c new file mode 100644 index 00000000000..eaaf6ff2899 --- /dev/null +++ b/arch/arm/mach-mxs/mach-mx28evk.c | |||
@@ -0,0 +1,426 @@ | |||
1 | /* | ||
2 | * Copyright 2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or modify | ||
5 | * it under the terms of the GNU General Public License as published by | ||
6 | * the Free Software Foundation; either version 2 of the License, or | ||
7 | * (at your option) any later version. | ||
8 | * | ||
9 | * This program is distributed in the hope that it will be useful, | ||
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
12 | * GNU General Public License for more details. | ||
13 | */ | ||
14 | |||
15 | #include <linux/delay.h> | ||
16 | #include <linux/platform_device.h> | ||
17 | #include <linux/gpio.h> | ||
18 | #include <linux/leds.h> | ||
19 | #include <linux/irq.h> | ||
20 | #include <linux/clk.h> | ||
21 | |||
22 | #include <asm/mach-types.h> | ||
23 | #include <asm/mach/arch.h> | ||
24 | #include <asm/mach/time.h> | ||
25 | |||
26 | #include <mach/common.h> | ||
27 | #include <mach/iomux-mx28.h> | ||
28 | |||
29 | #include "devices-mx28.h" | ||
30 | |||
31 | #define MX28EVK_FLEXCAN_SWITCH MXS_GPIO_NR(2, 13) | ||
32 | #define MX28EVK_FEC_PHY_POWER MXS_GPIO_NR(2, 15) | ||
33 | #define MX28EVK_GPIO_LED MXS_GPIO_NR(3, 5) | ||
34 | #define MX28EVK_BL_ENABLE MXS_GPIO_NR(3, 18) | ||
35 | #define MX28EVK_LCD_ENABLE MXS_GPIO_NR(3, 30) | ||
36 | #define MX28EVK_FEC_PHY_RESET MXS_GPIO_NR(4, 13) | ||
37 | |||
38 | #define MX28EVK_MMC0_WRITE_PROTECT MXS_GPIO_NR(2, 12) | ||
39 | #define MX28EVK_MMC1_WRITE_PROTECT MXS_GPIO_NR(0, 28) | ||
40 | #define MX28EVK_MMC0_SLOT_POWER MXS_GPIO_NR(3, 28) | ||
41 | #define MX28EVK_MMC1_SLOT_POWER MXS_GPIO_NR(3, 29) | ||
42 | |||
43 | static const iomux_cfg_t mx28evk_pads[] __initconst = { | ||
44 | /* duart */ | ||
45 | MX28_PAD_PWM0__DUART_RX | MXS_PAD_CTRL, | ||
46 | MX28_PAD_PWM1__DUART_TX | MXS_PAD_CTRL, | ||
47 | |||
48 | /* auart0 */ | ||
49 | MX28_PAD_AUART0_RX__AUART0_RX | MXS_PAD_CTRL, | ||
50 | MX28_PAD_AUART0_TX__AUART0_TX | MXS_PAD_CTRL, | ||
51 | MX28_PAD_AUART0_CTS__AUART0_CTS | MXS_PAD_CTRL, | ||
52 | MX28_PAD_AUART0_RTS__AUART0_RTS | MXS_PAD_CTRL, | ||
53 | /* auart3 */ | ||
54 | MX28_PAD_AUART3_RX__AUART3_RX | MXS_PAD_CTRL, | ||
55 | MX28_PAD_AUART3_TX__AUART3_TX | MXS_PAD_CTRL, | ||
56 | MX28_PAD_AUART3_CTS__AUART3_CTS | MXS_PAD_CTRL, | ||
57 | MX28_PAD_AUART3_RTS__AUART3_RTS | MXS_PAD_CTRL, | ||
58 | |||
59 | #define MXS_PAD_FEC (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP) | ||
60 | /* fec0 */ | ||
61 | MX28_PAD_ENET0_MDC__ENET0_MDC | MXS_PAD_FEC, | ||
62 | MX28_PAD_ENET0_MDIO__ENET0_MDIO | MXS_PAD_FEC, | ||
63 | MX28_PAD_ENET0_RX_EN__ENET0_RX_EN | MXS_PAD_FEC, | ||
64 | MX28_PAD_ENET0_RXD0__ENET0_RXD0 | MXS_PAD_FEC, | ||
65 | MX28_PAD_ENET0_RXD1__ENET0_RXD1 | MXS_PAD_FEC, | ||
66 | MX28_PAD_ENET0_TX_EN__ENET0_TX_EN | MXS_PAD_FEC, | ||
67 | MX28_PAD_ENET0_TXD0__ENET0_TXD0 | MXS_PAD_FEC, | ||
68 | MX28_PAD_ENET0_TXD1__ENET0_TXD1 | MXS_PAD_FEC, | ||
69 | MX28_PAD_ENET_CLK__CLKCTRL_ENET | MXS_PAD_FEC, | ||
70 | /* fec1 */ | ||
71 | MX28_PAD_ENET0_CRS__ENET1_RX_EN | MXS_PAD_FEC, | ||
72 | MX28_PAD_ENET0_RXD2__ENET1_RXD0 | MXS_PAD_FEC, | ||
73 | MX28_PAD_ENET0_RXD3__ENET1_RXD1 | MXS_PAD_FEC, | ||
74 | MX28_PAD_ENET0_COL__ENET1_TX_EN | MXS_PAD_FEC, | ||
75 | MX28_PAD_ENET0_TXD2__ENET1_TXD0 | MXS_PAD_FEC, | ||
76 | MX28_PAD_ENET0_TXD3__ENET1_TXD1 | MXS_PAD_FEC, | ||
77 | /* phy power line */ | ||
78 | MX28_PAD_SSP1_DATA3__GPIO_2_15 | MXS_PAD_CTRL, | ||
79 | /* phy reset line */ | ||
80 | MX28_PAD_ENET0_RX_CLK__GPIO_4_13 | MXS_PAD_CTRL, | ||
81 | |||
82 | /* flexcan0 */ | ||
83 | MX28_PAD_GPMI_RDY2__CAN0_TX, | ||
84 | MX28_PAD_GPMI_RDY3__CAN0_RX, | ||
85 | /* flexcan1 */ | ||
86 | MX28_PAD_GPMI_CE2N__CAN1_TX, | ||
87 | MX28_PAD_GPMI_CE3N__CAN1_RX, | ||
88 | /* transceiver power control */ | ||
89 | MX28_PAD_SSP1_CMD__GPIO_2_13, | ||
90 | |||
91 | /* mxsfb (lcdif) */ | ||
92 | MX28_PAD_LCD_D00__LCD_D0 | MXS_PAD_CTRL, | ||
93 | MX28_PAD_LCD_D01__LCD_D1 | MXS_PAD_CTRL, | ||
94 | MX28_PAD_LCD_D02__LCD_D2 | MXS_PAD_CTRL, | ||
95 | MX28_PAD_LCD_D03__LCD_D3 | MXS_PAD_CTRL, | ||
96 | MX28_PAD_LCD_D04__LCD_D4 | MXS_PAD_CTRL, | ||
97 | MX28_PAD_LCD_D05__LCD_D5 | MXS_PAD_CTRL, | ||
98 | MX28_PAD_LCD_D06__LCD_D6 | MXS_PAD_CTRL, | ||
99 | MX28_PAD_LCD_D07__LCD_D7 | MXS_PAD_CTRL, | ||
100 | MX28_PAD_LCD_D08__LCD_D8 | MXS_PAD_CTRL, | ||
101 | MX28_PAD_LCD_D09__LCD_D9 | MXS_PAD_CTRL, | ||
102 | MX28_PAD_LCD_D10__LCD_D10 | MXS_PAD_CTRL, | ||
103 | MX28_PAD_LCD_D11__LCD_D11 | MXS_PAD_CTRL, | ||
104 | MX28_PAD_LCD_D12__LCD_D12 | MXS_PAD_CTRL, | ||
105 | MX28_PAD_LCD_D13__LCD_D13 | MXS_PAD_CTRL, | ||
106 | MX28_PAD_LCD_D14__LCD_D14 | MXS_PAD_CTRL, | ||
107 | MX28_PAD_LCD_D15__LCD_D15 | MXS_PAD_CTRL, | ||
108 | MX28_PAD_LCD_D16__LCD_D16 | MXS_PAD_CTRL, | ||
109 | MX28_PAD_LCD_D17__LCD_D17 | MXS_PAD_CTRL, | ||
110 | MX28_PAD_LCD_D18__LCD_D18 | MXS_PAD_CTRL, | ||
111 | MX28_PAD_LCD_D19__LCD_D19 | MXS_PAD_CTRL, | ||
112 | MX28_PAD_LCD_D20__LCD_D20 | MXS_PAD_CTRL, | ||
113 | MX28_PAD_LCD_D21__LCD_D21 | MXS_PAD_CTRL, | ||
114 | MX28_PAD_LCD_D22__LCD_D22 | MXS_PAD_CTRL, | ||
115 | MX28_PAD_LCD_D23__LCD_D23 | MXS_PAD_CTRL, | ||
116 | MX28_PAD_LCD_RD_E__LCD_VSYNC | MXS_PAD_CTRL, | ||
117 | MX28_PAD_LCD_WR_RWN__LCD_HSYNC | MXS_PAD_CTRL, | ||
118 | MX28_PAD_LCD_RS__LCD_DOTCLK | MXS_PAD_CTRL, | ||
119 | MX28_PAD_LCD_CS__LCD_ENABLE | MXS_PAD_CTRL, | ||
120 | /* LCD panel enable */ | ||
121 | MX28_PAD_LCD_RESET__GPIO_3_30 | MXS_PAD_CTRL, | ||
122 | /* backlight control */ | ||
123 | MX28_PAD_PWM2__GPIO_3_18 | MXS_PAD_CTRL, | ||
124 | /* mmc0 */ | ||
125 | MX28_PAD_SSP0_DATA0__SSP0_D0 | | ||
126 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
127 | MX28_PAD_SSP0_DATA1__SSP0_D1 | | ||
128 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
129 | MX28_PAD_SSP0_DATA2__SSP0_D2 | | ||
130 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
131 | MX28_PAD_SSP0_DATA3__SSP0_D3 | | ||
132 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
133 | MX28_PAD_SSP0_DATA4__SSP0_D4 | | ||
134 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
135 | MX28_PAD_SSP0_DATA5__SSP0_D5 | | ||
136 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
137 | MX28_PAD_SSP0_DATA6__SSP0_D6 | | ||
138 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
139 | MX28_PAD_SSP0_DATA7__SSP0_D7 | | ||
140 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
141 | MX28_PAD_SSP0_CMD__SSP0_CMD | | ||
142 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
143 | MX28_PAD_SSP0_DETECT__SSP0_CARD_DETECT | | ||
144 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_NOPULL), | ||
145 | MX28_PAD_SSP0_SCK__SSP0_SCK | | ||
146 | (MXS_PAD_12MA | MXS_PAD_3V3 | MXS_PAD_NOPULL), | ||
147 | /* write protect */ | ||
148 | MX28_PAD_SSP1_SCK__GPIO_2_12 | | ||
149 | (MXS_PAD_4MA | MXS_PAD_3V3 | MXS_PAD_NOPULL), | ||
150 | /* slot power enable */ | ||
151 | MX28_PAD_PWM3__GPIO_3_28 | | ||
152 | (MXS_PAD_4MA | MXS_PAD_3V3 | MXS_PAD_NOPULL), | ||
153 | |||
154 | /* mmc1 */ | ||
155 | MX28_PAD_GPMI_D00__SSP1_D0 | | ||
156 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
157 | MX28_PAD_GPMI_D01__SSP1_D1 | | ||
158 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
159 | MX28_PAD_GPMI_D02__SSP1_D2 | | ||
160 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
161 | MX28_PAD_GPMI_D03__SSP1_D3 | | ||
162 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
163 | MX28_PAD_GPMI_D04__SSP1_D4 | | ||
164 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
165 | MX28_PAD_GPMI_D05__SSP1_D5 | | ||
166 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
167 | MX28_PAD_GPMI_D06__SSP1_D6 | | ||
168 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
169 | MX28_PAD_GPMI_D07__SSP1_D7 | | ||
170 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
171 | MX28_PAD_GPMI_RDY1__SSP1_CMD | | ||
172 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
173 | MX28_PAD_GPMI_RDY0__SSP1_CARD_DETECT | | ||
174 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_NOPULL), | ||
175 | MX28_PAD_GPMI_WRN__SSP1_SCK | | ||
176 | (MXS_PAD_12MA | MXS_PAD_3V3 | MXS_PAD_NOPULL), | ||
177 | /* write protect */ | ||
178 | MX28_PAD_GPMI_RESETN__GPIO_0_28 | | ||
179 | (MXS_PAD_4MA | MXS_PAD_3V3 | MXS_PAD_NOPULL), | ||
180 | /* slot power enable */ | ||
181 | MX28_PAD_PWM4__GPIO_3_29 | | ||
182 | (MXS_PAD_4MA | MXS_PAD_3V3 | MXS_PAD_NOPULL), | ||
183 | |||
184 | /* led */ | ||
185 | MX28_PAD_AUART1_TX__GPIO_3_5 | MXS_PAD_CTRL, | ||
186 | }; | ||
187 | |||
188 | /* led */ | ||
189 | static const struct gpio_led mx28evk_leds[] __initconst = { | ||
190 | { | ||
191 | .name = "GPIO-LED", | ||
192 | .default_trigger = "heartbeat", | ||
193 | .gpio = MX28EVK_GPIO_LED, | ||
194 | }, | ||
195 | }; | ||
196 | |||
197 | static const struct gpio_led_platform_data mx28evk_led_data __initconst = { | ||
198 | .leds = mx28evk_leds, | ||
199 | .num_leds = ARRAY_SIZE(mx28evk_leds), | ||
200 | }; | ||
201 | |||
202 | /* fec */ | ||
203 | static void __init mx28evk_fec_reset(void) | ||
204 | { | ||
205 | int ret; | ||
206 | struct clk *clk; | ||
207 | |||
208 | /* Enable fec phy clock */ | ||
209 | clk = clk_get_sys("pll2", NULL); | ||
210 | if (!IS_ERR(clk)) | ||
211 | clk_enable(clk); | ||
212 | |||
213 | /* Power up fec phy */ | ||
214 | ret = gpio_request(MX28EVK_FEC_PHY_POWER, "fec-phy-power"); | ||
215 | if (ret) { | ||
216 | pr_err("Failed to request gpio fec-phy-%s: %d\n", "power", ret); | ||
217 | return; | ||
218 | } | ||
219 | |||
220 | ret = gpio_direction_output(MX28EVK_FEC_PHY_POWER, 0); | ||
221 | if (ret) { | ||
222 | pr_err("Failed to drive gpio fec-phy-%s: %d\n", "power", ret); | ||
223 | return; | ||
224 | } | ||
225 | |||
226 | /* Reset fec phy */ | ||
227 | ret = gpio_request(MX28EVK_FEC_PHY_RESET, "fec-phy-reset"); | ||
228 | if (ret) { | ||
229 | pr_err("Failed to request gpio fec-phy-%s: %d\n", "reset", ret); | ||
230 | return; | ||
231 | } | ||
232 | |||
233 | gpio_direction_output(MX28EVK_FEC_PHY_RESET, 0); | ||
234 | if (ret) { | ||
235 | pr_err("Failed to drive gpio fec-phy-%s: %d\n", "reset", ret); | ||
236 | return; | ||
237 | } | ||
238 | |||
239 | mdelay(1); | ||
240 | gpio_set_value(MX28EVK_FEC_PHY_RESET, 1); | ||
241 | } | ||
242 | |||
243 | static struct fec_platform_data mx28_fec_pdata[] __initdata = { | ||
244 | { | ||
245 | /* fec0 */ | ||
246 | .phy = PHY_INTERFACE_MODE_RMII, | ||
247 | }, { | ||
248 | /* fec1 */ | ||
249 | .phy = PHY_INTERFACE_MODE_RMII, | ||
250 | }, | ||
251 | }; | ||
252 | |||
253 | static int __init mx28evk_fec_get_mac(void) | ||
254 | { | ||
255 | int i; | ||
256 | u32 val; | ||
257 | const u32 *ocotp = mxs_get_ocotp(); | ||
258 | |||
259 | if (!ocotp) | ||
260 | goto error; | ||
261 | |||
262 | /* | ||
263 | * OCOTP only stores the last 4 octets for each mac address, | ||
264 | * so hard-code Freescale OUI (00:04:9f) here. | ||
265 | */ | ||
266 | for (i = 0; i < 2; i++) { | ||
267 | val = ocotp[i * 4]; | ||
268 | mx28_fec_pdata[i].mac[0] = 0x00; | ||
269 | mx28_fec_pdata[i].mac[1] = 0x04; | ||
270 | mx28_fec_pdata[i].mac[2] = 0x9f; | ||
271 | mx28_fec_pdata[i].mac[3] = (val >> 16) & 0xff; | ||
272 | mx28_fec_pdata[i].mac[4] = (val >> 8) & 0xff; | ||
273 | mx28_fec_pdata[i].mac[5] = (val >> 0) & 0xff; | ||
274 | } | ||
275 | |||
276 | return 0; | ||
277 | |||
278 | error: | ||
279 | pr_err("%s: timeout when reading fec mac from OCOTP\n", __func__); | ||
280 | return -ETIMEDOUT; | ||
281 | } | ||
282 | |||
283 | /* | ||
284 | * MX28EVK_FLEXCAN_SWITCH is shared between both flexcan controllers | ||
285 | */ | ||
286 | static int flexcan0_en, flexcan1_en; | ||
287 | |||
288 | static void mx28evk_flexcan_switch(void) | ||
289 | { | ||
290 | if (flexcan0_en || flexcan1_en) | ||
291 | gpio_set_value(MX28EVK_FLEXCAN_SWITCH, 1); | ||
292 | else | ||
293 | gpio_set_value(MX28EVK_FLEXCAN_SWITCH, 0); | ||
294 | } | ||
295 | |||
296 | static void mx28evk_flexcan0_switch(int enable) | ||
297 | { | ||
298 | flexcan0_en = enable; | ||
299 | mx28evk_flexcan_switch(); | ||
300 | } | ||
301 | |||
302 | static void mx28evk_flexcan1_switch(int enable) | ||
303 | { | ||
304 | flexcan1_en = enable; | ||
305 | mx28evk_flexcan_switch(); | ||
306 | } | ||
307 | |||
308 | static const struct flexcan_platform_data | ||
309 | mx28evk_flexcan_pdata[] __initconst = { | ||
310 | { | ||
311 | .transceiver_switch = mx28evk_flexcan0_switch, | ||
312 | }, { | ||
313 | .transceiver_switch = mx28evk_flexcan1_switch, | ||
314 | } | ||
315 | }; | ||
316 | |||
317 | /* mxsfb (lcdif) */ | ||
318 | static struct fb_videomode mx28evk_video_modes[] = { | ||
319 | { | ||
320 | .name = "Seiko-43WVF1G", | ||
321 | .refresh = 60, | ||
322 | .xres = 800, | ||
323 | .yres = 480, | ||
324 | .pixclock = 29851, /* picosecond (33.5 MHz) */ | ||
325 | .left_margin = 89, | ||
326 | .right_margin = 164, | ||
327 | .upper_margin = 23, | ||
328 | .lower_margin = 10, | ||
329 | .hsync_len = 10, | ||
330 | .vsync_len = 10, | ||
331 | .sync = FB_SYNC_DATA_ENABLE_HIGH_ACT | | ||
332 | FB_SYNC_DOTCLK_FAILING_ACT, | ||
333 | }, | ||
334 | }; | ||
335 | |||
336 | static const struct mxsfb_platform_data mx28evk_mxsfb_pdata __initconst = { | ||
337 | .mode_list = mx28evk_video_modes, | ||
338 | .mode_count = ARRAY_SIZE(mx28evk_video_modes), | ||
339 | .default_bpp = 32, | ||
340 | .ld_intf_width = STMLCDIF_24BIT, | ||
341 | }; | ||
342 | |||
343 | static struct mxs_mmc_platform_data mx28evk_mmc_pdata[] __initdata = { | ||
344 | { | ||
345 | /* mmc0 */ | ||
346 | .wp_gpio = MX28EVK_MMC0_WRITE_PROTECT, | ||
347 | .flags = SLOTF_8_BIT_CAPABLE, | ||
348 | }, { | ||
349 | /* mmc1 */ | ||
350 | .wp_gpio = MX28EVK_MMC1_WRITE_PROTECT, | ||
351 | .flags = SLOTF_8_BIT_CAPABLE, | ||
352 | }, | ||
353 | }; | ||
354 | |||
355 | static void __init mx28evk_init(void) | ||
356 | { | ||
357 | int ret; | ||
358 | |||
359 | mxs_iomux_setup_multiple_pads(mx28evk_pads, ARRAY_SIZE(mx28evk_pads)); | ||
360 | |||
361 | mx28_add_duart(); | ||
362 | mx28_add_auart0(); | ||
363 | mx28_add_auart3(); | ||
364 | |||
365 | if (mx28evk_fec_get_mac()) | ||
366 | pr_warn("%s: failed on fec mac setup\n", __func__); | ||
367 | |||
368 | mx28evk_fec_reset(); | ||
369 | mx28_add_fec(0, &mx28_fec_pdata[0]); | ||
370 | mx28_add_fec(1, &mx28_fec_pdata[1]); | ||
371 | |||
372 | ret = gpio_request_one(MX28EVK_FLEXCAN_SWITCH, GPIOF_DIR_OUT, | ||
373 | "flexcan-switch"); | ||
374 | if (ret) { | ||
375 | pr_err("failed to request gpio flexcan-switch: %d\n", ret); | ||
376 | } else { | ||
377 | mx28_add_flexcan(0, &mx28evk_flexcan_pdata[0]); | ||
378 | mx28_add_flexcan(1, &mx28evk_flexcan_pdata[1]); | ||
379 | } | ||
380 | |||
381 | ret = gpio_request_one(MX28EVK_LCD_ENABLE, GPIOF_DIR_OUT, "lcd-enable"); | ||
382 | if (ret) | ||
383 | pr_warn("failed to request gpio lcd-enable: %d\n", ret); | ||
384 | else | ||
385 | gpio_set_value(MX28EVK_LCD_ENABLE, 1); | ||
386 | |||
387 | ret = gpio_request_one(MX28EVK_BL_ENABLE, GPIOF_DIR_OUT, "bl-enable"); | ||
388 | if (ret) | ||
389 | pr_warn("failed to request gpio bl-enable: %d\n", ret); | ||
390 | else | ||
391 | gpio_set_value(MX28EVK_BL_ENABLE, 1); | ||
392 | |||
393 | mx28_add_mxsfb(&mx28evk_mxsfb_pdata); | ||
394 | |||
395 | /* power on mmc slot by writing 0 to the gpio */ | ||
396 | ret = gpio_request_one(MX28EVK_MMC0_SLOT_POWER, GPIOF_OUT_INIT_LOW, | ||
397 | "mmc0-slot-power"); | ||
398 | if (ret) | ||
399 | pr_warn("failed to request gpio mmc0-slot-power: %d\n", ret); | ||
400 | mx28_add_mxs_mmc(0, &mx28evk_mmc_pdata[0]); | ||
401 | |||
402 | ret = gpio_request_one(MX28EVK_MMC1_SLOT_POWER, GPIOF_OUT_INIT_LOW, | ||
403 | "mmc1-slot-power"); | ||
404 | if (ret) | ||
405 | pr_warn("failed to request gpio mmc1-slot-power: %d\n", ret); | ||
406 | mx28_add_mxs_mmc(1, &mx28evk_mmc_pdata[1]); | ||
407 | |||
408 | gpio_led_register_device(0, &mx28evk_led_data); | ||
409 | } | ||
410 | |||
411 | static void __init mx28evk_timer_init(void) | ||
412 | { | ||
413 | mx28_clocks_init(); | ||
414 | } | ||
415 | |||
416 | static struct sys_timer mx28evk_timer = { | ||
417 | .init = mx28evk_timer_init, | ||
418 | }; | ||
419 | |||
420 | MACHINE_START(MX28EVK, "Freescale MX28 EVK") | ||
421 | /* Maintainer: Freescale Semiconductor, Inc. */ | ||
422 | .map_io = mx28_map_io, | ||
423 | .init_irq = mx28_init_irq, | ||
424 | .init_machine = mx28evk_init, | ||
425 | .timer = &mx28evk_timer, | ||
426 | MACHINE_END | ||
diff --git a/arch/arm/mach-mxs/mach-stmp378x_devb.c b/arch/arm/mach-mxs/mach-stmp378x_devb.c new file mode 100644 index 00000000000..7f38d82b69a --- /dev/null +++ b/arch/arm/mach-mxs/mach-stmp378x_devb.c | |||
@@ -0,0 +1,120 @@ | |||
1 | /* | ||
2 | * board setup for STMP378x-Development-Board | ||
3 | * | ||
4 | * based on mx23evk board setup and information gained form the original | ||
5 | * plat-stmp based board setup, now converted to mach-mxs. | ||
6 | * | ||
7 | * Copyright 2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
8 | * Copyright (C) 2011 Wolfram Sang, Pengutronix e.K. | ||
9 | * | ||
10 | * This program is free software; you can redistribute it and/or modify | ||
11 | * it under the terms of the GNU General Public License as published by | ||
12 | * the Free Software Foundation; version 2 of the License. | ||
13 | * | ||
14 | * This program is distributed in the hope that it will be useful, | ||
15 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
16 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
17 | * GNU General Public License for more details. | ||
18 | */ | ||
19 | |||
20 | #include <linux/platform_device.h> | ||
21 | #include <linux/gpio.h> | ||
22 | #include <linux/irq.h> | ||
23 | #include <linux/spi/spi.h> | ||
24 | |||
25 | #include <asm/mach-types.h> | ||
26 | #include <asm/mach/arch.h> | ||
27 | #include <asm/mach/time.h> | ||
28 | |||
29 | #include <mach/common.h> | ||
30 | #include <mach/iomux-mx23.h> | ||
31 | |||
32 | #include "devices-mx23.h" | ||
33 | |||
34 | #define STMP378X_DEVB_MMC0_WRITE_PROTECT MXS_GPIO_NR(1, 30) | ||
35 | #define STMP378X_DEVB_MMC0_SLOT_POWER MXS_GPIO_NR(1, 29) | ||
36 | |||
37 | #define STMP378X_DEVB_PAD_AUART (MXS_PAD_4MA | MXS_PAD_1V8 | MXS_PAD_NOPULL) | ||
38 | |||
39 | static const iomux_cfg_t stmp378x_dvb_pads[] __initconst = { | ||
40 | /* duart (extended setup missing in old boardcode, too */ | ||
41 | MX23_PAD_PWM0__DUART_RX, | ||
42 | MX23_PAD_PWM1__DUART_TX, | ||
43 | |||
44 | /* auart */ | ||
45 | MX23_PAD_AUART1_RX__AUART1_RX | STMP378X_DEVB_PAD_AUART, | ||
46 | MX23_PAD_AUART1_TX__AUART1_TX | STMP378X_DEVB_PAD_AUART, | ||
47 | MX23_PAD_AUART1_CTS__AUART1_CTS | STMP378X_DEVB_PAD_AUART, | ||
48 | MX23_PAD_AUART1_RTS__AUART1_RTS | STMP378X_DEVB_PAD_AUART, | ||
49 | |||
50 | /* mmc */ | ||
51 | MX23_PAD_SSP1_DATA0__SSP1_DATA0 | | ||
52 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
53 | MX23_PAD_SSP1_DATA1__SSP1_DATA1 | | ||
54 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
55 | MX23_PAD_SSP1_DATA2__SSP1_DATA2 | | ||
56 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
57 | MX23_PAD_SSP1_DATA3__SSP1_DATA3 | | ||
58 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
59 | MX23_PAD_SSP1_CMD__SSP1_CMD | | ||
60 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
61 | MX23_PAD_SSP1_DETECT__SSP1_DETECT | | ||
62 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_NOPULL), | ||
63 | MX23_PAD_SSP1_SCK__SSP1_SCK | | ||
64 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_NOPULL), | ||
65 | MX23_PAD_PWM4__GPIO_1_30 | MXS_PAD_CTRL, /* write protect */ | ||
66 | MX23_PAD_PWM3__GPIO_1_29 | MXS_PAD_CTRL, /* power enable */ | ||
67 | }; | ||
68 | |||
69 | static struct mxs_mmc_platform_data stmp378x_dvb_mmc_pdata __initdata = { | ||
70 | .wp_gpio = STMP378X_DEVB_MMC0_WRITE_PROTECT, | ||
71 | }; | ||
72 | |||
73 | static struct spi_board_info spi_board_info[] __initdata = { | ||
74 | #if defined(CONFIG_ENC28J60) || defined(CONFIG_ENC28J60_MODULE) | ||
75 | { | ||
76 | .modalias = "enc28j60", | ||
77 | .max_speed_hz = 6 * 1000 * 1000, | ||
78 | .bus_num = 1, | ||
79 | .chip_select = 0, | ||
80 | .platform_data = NULL, | ||
81 | }, | ||
82 | #endif | ||
83 | }; | ||
84 | |||
85 | static void __init stmp378x_dvb_init(void) | ||
86 | { | ||
87 | int ret; | ||
88 | |||
89 | mxs_iomux_setup_multiple_pads(stmp378x_dvb_pads, | ||
90 | ARRAY_SIZE(stmp378x_dvb_pads)); | ||
91 | |||
92 | mx23_add_duart(); | ||
93 | mx23_add_auart0(); | ||
94 | |||
95 | /* power on mmc slot */ | ||
96 | ret = gpio_request_one(STMP378X_DEVB_MMC0_SLOT_POWER, | ||
97 | GPIOF_OUT_INIT_LOW, "mmc0-slot-power"); | ||
98 | if (ret) | ||
99 | pr_warn("could not power mmc (%d)\n", ret); | ||
100 | |||
101 | mx23_add_mxs_mmc(0, &stmp378x_dvb_mmc_pdata); | ||
102 | |||
103 | spi_register_board_info(spi_board_info, ARRAY_SIZE(spi_board_info)); | ||
104 | } | ||
105 | |||
106 | static void __init stmp378x_dvb_timer_init(void) | ||
107 | { | ||
108 | mx23_clocks_init(); | ||
109 | } | ||
110 | |||
111 | static struct sys_timer stmp378x_dvb_timer = { | ||
112 | .init = stmp378x_dvb_timer_init, | ||
113 | }; | ||
114 | |||
115 | MACHINE_START(STMP378X, "STMP378X") | ||
116 | .map_io = mx23_map_io, | ||
117 | .init_irq = mx23_init_irq, | ||
118 | .init_machine = stmp378x_dvb_init, | ||
119 | .timer = &stmp378x_dvb_timer, | ||
120 | MACHINE_END | ||
diff --git a/arch/arm/mach-mxs/mach-tx28.c b/arch/arm/mach-mxs/mach-tx28.c new file mode 100644 index 00000000000..515a423f82c --- /dev/null +++ b/arch/arm/mach-mxs/mach-tx28.c | |||
@@ -0,0 +1,180 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2010 <LW@KARO-electronics.de> | ||
3 | * | ||
4 | * based on: mach-mx28_evk.c | ||
5 | * Copyright 2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or | ||
8 | * modify it under the terms of the GNU General Public License | ||
9 | * version 2 as published by the Free Software Foundation | ||
10 | */ | ||
11 | #include <linux/kernel.h> | ||
12 | #include <linux/gpio.h> | ||
13 | #include <linux/leds.h> | ||
14 | #include <linux/platform_device.h> | ||
15 | #include <linux/spi/spi.h> | ||
16 | #include <linux/spi/spi_gpio.h> | ||
17 | #include <linux/i2c.h> | ||
18 | |||
19 | #include <asm/mach/arch.h> | ||
20 | #include <asm/mach/time.h> | ||
21 | |||
22 | #include <mach/common.h> | ||
23 | #include <mach/iomux-mx28.h> | ||
24 | |||
25 | #include "devices-mx28.h" | ||
26 | #include "module-tx28.h" | ||
27 | |||
28 | #define TX28_STK5_GPIO_LED MXS_GPIO_NR(4, 10) | ||
29 | |||
30 | static const iomux_cfg_t tx28_stk5v3_pads[] __initconst = { | ||
31 | /* LED */ | ||
32 | MX28_PAD_ENET0_RXD3__GPIO_4_10 | | ||
33 | MXS_PAD_3V3 | MXS_PAD_4MA | MXS_PAD_NOPULL, | ||
34 | |||
35 | /* framebuffer */ | ||
36 | #define LCD_MODE (MXS_PAD_3V3 | MXS_PAD_4MA) | ||
37 | MX28_PAD_LCD_D00__LCD_D0 | LCD_MODE, | ||
38 | MX28_PAD_LCD_D01__LCD_D1 | LCD_MODE, | ||
39 | MX28_PAD_LCD_D02__LCD_D2 | LCD_MODE, | ||
40 | MX28_PAD_LCD_D03__LCD_D3 | LCD_MODE, | ||
41 | MX28_PAD_LCD_D04__LCD_D4 | LCD_MODE, | ||
42 | MX28_PAD_LCD_D05__LCD_D5 | LCD_MODE, | ||
43 | MX28_PAD_LCD_D06__LCD_D6 | LCD_MODE, | ||
44 | MX28_PAD_LCD_D07__LCD_D7 | LCD_MODE, | ||
45 | MX28_PAD_LCD_D08__LCD_D8 | LCD_MODE, | ||
46 | MX28_PAD_LCD_D09__LCD_D9 | LCD_MODE, | ||
47 | MX28_PAD_LCD_D10__LCD_D10 | LCD_MODE, | ||
48 | MX28_PAD_LCD_D11__LCD_D11 | LCD_MODE, | ||
49 | MX28_PAD_LCD_D12__LCD_D12 | LCD_MODE, | ||
50 | MX28_PAD_LCD_D13__LCD_D13 | LCD_MODE, | ||
51 | MX28_PAD_LCD_D14__LCD_D14 | LCD_MODE, | ||
52 | MX28_PAD_LCD_D15__LCD_D15 | LCD_MODE, | ||
53 | MX28_PAD_LCD_D16__LCD_D16 | LCD_MODE, | ||
54 | MX28_PAD_LCD_D17__LCD_D17 | LCD_MODE, | ||
55 | MX28_PAD_LCD_D18__LCD_D18 | LCD_MODE, | ||
56 | MX28_PAD_LCD_D19__LCD_D19 | LCD_MODE, | ||
57 | MX28_PAD_LCD_D20__LCD_D20 | LCD_MODE, | ||
58 | MX28_PAD_LCD_D21__LCD_D21 | LCD_MODE, | ||
59 | MX28_PAD_LCD_D22__LCD_D22 | LCD_MODE, | ||
60 | MX28_PAD_LCD_D23__LCD_D23 | LCD_MODE, | ||
61 | MX28_PAD_LCD_RD_E__LCD_VSYNC | LCD_MODE, | ||
62 | MX28_PAD_LCD_WR_RWN__LCD_HSYNC | LCD_MODE, | ||
63 | MX28_PAD_LCD_RS__LCD_DOTCLK | LCD_MODE, | ||
64 | MX28_PAD_LCD_CS__LCD_CS | LCD_MODE, | ||
65 | MX28_PAD_LCD_VSYNC__LCD_VSYNC | LCD_MODE, | ||
66 | MX28_PAD_LCD_HSYNC__LCD_HSYNC | LCD_MODE, | ||
67 | MX28_PAD_LCD_DOTCLK__LCD_DOTCLK | LCD_MODE, | ||
68 | MX28_PAD_LCD_ENABLE__GPIO_1_31 | LCD_MODE, | ||
69 | MX28_PAD_LCD_RESET__GPIO_3_30 | LCD_MODE, | ||
70 | MX28_PAD_PWM0__PWM_0 | LCD_MODE, | ||
71 | |||
72 | /* UART1 */ | ||
73 | MX28_PAD_AUART0_CTS__DUART_RX, | ||
74 | MX28_PAD_AUART0_RTS__DUART_TX, | ||
75 | MX28_PAD_AUART0_TX__DUART_RTS, | ||
76 | MX28_PAD_AUART0_RX__DUART_CTS, | ||
77 | |||
78 | /* UART2 */ | ||
79 | MX28_PAD_AUART1_RX__AUART1_RX, | ||
80 | MX28_PAD_AUART1_TX__AUART1_TX, | ||
81 | MX28_PAD_AUART1_RTS__AUART1_RTS, | ||
82 | MX28_PAD_AUART1_CTS__AUART1_CTS, | ||
83 | |||
84 | /* CAN */ | ||
85 | MX28_PAD_GPMI_RDY2__CAN0_TX, | ||
86 | MX28_PAD_GPMI_RDY3__CAN0_RX, | ||
87 | |||
88 | /* I2C */ | ||
89 | MX28_PAD_I2C0_SCL__I2C0_SCL, | ||
90 | MX28_PAD_I2C0_SDA__I2C0_SDA, | ||
91 | |||
92 | /* TSC2007 */ | ||
93 | MX28_PAD_SAIF0_MCLK__GPIO_3_20 | MXS_PAD_3V3 | MXS_PAD_4MA | MXS_PAD_PULLUP, | ||
94 | |||
95 | /* MMC0 */ | ||
96 | MX28_PAD_SSP0_DATA0__SSP0_D0 | | ||
97 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
98 | MX28_PAD_SSP0_DATA1__SSP0_D1 | | ||
99 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
100 | MX28_PAD_SSP0_DATA2__SSP0_D2 | | ||
101 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
102 | MX28_PAD_SSP0_DATA3__SSP0_D3 | | ||
103 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
104 | MX28_PAD_SSP0_CMD__SSP0_CMD | | ||
105 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_PULLUP), | ||
106 | MX28_PAD_SSP0_DETECT__SSP0_CARD_DETECT | | ||
107 | (MXS_PAD_8MA | MXS_PAD_3V3 | MXS_PAD_NOPULL), | ||
108 | MX28_PAD_SSP0_SCK__SSP0_SCK | | ||
109 | (MXS_PAD_12MA | MXS_PAD_3V3 | MXS_PAD_NOPULL), | ||
110 | }; | ||
111 | |||
112 | static const struct gpio_led tx28_stk5v3_leds[] __initconst = { | ||
113 | { | ||
114 | .name = "GPIO-LED", | ||
115 | .default_trigger = "heartbeat", | ||
116 | .gpio = TX28_STK5_GPIO_LED, | ||
117 | }, | ||
118 | }; | ||
119 | |||
120 | static const struct gpio_led_platform_data tx28_stk5v3_led_data __initconst = { | ||
121 | .leds = tx28_stk5v3_leds, | ||
122 | .num_leds = ARRAY_SIZE(tx28_stk5v3_leds), | ||
123 | }; | ||
124 | |||
125 | static struct spi_board_info tx28_spi_board_info[] = { | ||
126 | { | ||
127 | .modalias = "spidev", | ||
128 | .max_speed_hz = 20000000, | ||
129 | .bus_num = 0, | ||
130 | .chip_select = 1, | ||
131 | .controller_data = (void *)SPI_GPIO_NO_CHIPSELECT, | ||
132 | .mode = SPI_MODE_0, | ||
133 | }, | ||
134 | }; | ||
135 | |||
136 | static struct i2c_board_info tx28_stk5v3_i2c_boardinfo[] __initdata = { | ||
137 | { | ||
138 | I2C_BOARD_INFO("ds1339", 0x68), | ||
139 | }, | ||
140 | }; | ||
141 | |||
142 | static struct mxs_mmc_platform_data tx28_mmc0_pdata __initdata = { | ||
143 | .wp_gpio = -EINVAL, | ||
144 | .flags = SLOTF_4_BIT_CAPABLE, | ||
145 | }; | ||
146 | |||
147 | static void __init tx28_stk5v3_init(void) | ||
148 | { | ||
149 | mxs_iomux_setup_multiple_pads(tx28_stk5v3_pads, | ||
150 | ARRAY_SIZE(tx28_stk5v3_pads)); | ||
151 | |||
152 | mx28_add_duart(); /* UART1 */ | ||
153 | mx28_add_auart(1); /* UART2 */ | ||
154 | |||
155 | tx28_add_fec0(); | ||
156 | /* spi via ssp will be added when available */ | ||
157 | spi_register_board_info(tx28_spi_board_info, | ||
158 | ARRAY_SIZE(tx28_spi_board_info)); | ||
159 | gpio_led_register_device(0, &tx28_stk5v3_led_data); | ||
160 | mx28_add_mxs_i2c(0); | ||
161 | i2c_register_board_info(0, tx28_stk5v3_i2c_boardinfo, | ||
162 | ARRAY_SIZE(tx28_stk5v3_i2c_boardinfo)); | ||
163 | mx28_add_mxs_mmc(0, &tx28_mmc0_pdata); | ||
164 | } | ||
165 | |||
166 | static void __init tx28_timer_init(void) | ||
167 | { | ||
168 | mx28_clocks_init(); | ||
169 | } | ||
170 | |||
171 | static struct sys_timer tx28_timer = { | ||
172 | .init = tx28_timer_init, | ||
173 | }; | ||
174 | |||
175 | MACHINE_START(TX28, "Ka-Ro electronics TX28 module") | ||
176 | .map_io = mx28_map_io, | ||
177 | .init_irq = mx28_init_irq, | ||
178 | .init_machine = tx28_stk5v3_init, | ||
179 | .timer = &tx28_timer, | ||
180 | MACHINE_END | ||
diff --git a/arch/arm/mach-mxs/mm-mx23.c b/arch/arm/mach-mxs/mm-mx23.c new file mode 100644 index 00000000000..1b2345ac1a8 --- /dev/null +++ b/arch/arm/mach-mxs/mm-mx23.c | |||
@@ -0,0 +1,44 @@ | |||
1 | /* | ||
2 | * Copyright 2008-2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | * | ||
4 | * The code contained herein is licensed under the GNU General Public | ||
5 | * License. You may obtain a copy of the GNU General Public License | ||
6 | * Version 2 or later at the following locations: | ||
7 | * | ||
8 | * http://www.opensource.org/licenses/gpl-license.html | ||
9 | * http://www.gnu.org/copyleft/gpl.html | ||
10 | * | ||
11 | * Create static mapping between physical to virtual memory. | ||
12 | */ | ||
13 | |||
14 | #include <linux/mm.h> | ||
15 | #include <linux/init.h> | ||
16 | |||
17 | #include <asm/mach/map.h> | ||
18 | |||
19 | #include <mach/mx23.h> | ||
20 | #include <mach/common.h> | ||
21 | #include <mach/iomux.h> | ||
22 | |||
23 | /* | ||
24 | * Define the MX23 memory map. | ||
25 | */ | ||
26 | static struct map_desc mx23_io_desc[] __initdata = { | ||
27 | mxs_map_entry(MX23, OCRAM, MT_DEVICE), | ||
28 | mxs_map_entry(MX23, IO, MT_DEVICE), | ||
29 | }; | ||
30 | |||
31 | /* | ||
32 | * This function initializes the memory map. It is called during the | ||
33 | * system startup to create static physical to virtual memory mappings | ||
34 | * for the IO modules. | ||
35 | */ | ||
36 | void __init mx23_map_io(void) | ||
37 | { | ||
38 | iotable_init(mx23_io_desc, ARRAY_SIZE(mx23_io_desc)); | ||
39 | } | ||
40 | |||
41 | void __init mx23_init_irq(void) | ||
42 | { | ||
43 | icoll_init_irq(); | ||
44 | } | ||
diff --git a/arch/arm/mach-mxs/mm-mx28.c b/arch/arm/mach-mxs/mm-mx28.c new file mode 100644 index 00000000000..b6e18ddb92c --- /dev/null +++ b/arch/arm/mach-mxs/mm-mx28.c | |||
@@ -0,0 +1,44 @@ | |||
1 | /* | ||
2 | * Copyright 2008-2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | * | ||
4 | * The code contained herein is licensed under the GNU General Public | ||
5 | * License. You may obtain a copy of the GNU General Public License | ||
6 | * Version 2 or later at the following locations: | ||
7 | * | ||
8 | * http://www.opensource.org/licenses/gpl-license.html | ||
9 | * http://www.gnu.org/copyleft/gpl.html | ||
10 | * | ||
11 | * Create static mapping between physical to virtual memory. | ||
12 | */ | ||
13 | |||
14 | #include <linux/mm.h> | ||
15 | #include <linux/init.h> | ||
16 | |||
17 | #include <asm/mach/map.h> | ||
18 | |||
19 | #include <mach/mx28.h> | ||
20 | #include <mach/common.h> | ||
21 | #include <mach/iomux.h> | ||
22 | |||
23 | /* | ||
24 | * Define the MX28 memory map. | ||
25 | */ | ||
26 | static struct map_desc mx28_io_desc[] __initdata = { | ||
27 | mxs_map_entry(MX28, OCRAM, MT_DEVICE), | ||
28 | mxs_map_entry(MX28, IO, MT_DEVICE), | ||
29 | }; | ||
30 | |||
31 | /* | ||
32 | * This function initializes the memory map. It is called during the | ||
33 | * system startup to create static physical to virtual memory mappings | ||
34 | * for the IO modules. | ||
35 | */ | ||
36 | void __init mx28_map_io(void) | ||
37 | { | ||
38 | iotable_init(mx28_io_desc, ARRAY_SIZE(mx28_io_desc)); | ||
39 | } | ||
40 | |||
41 | void __init mx28_init_irq(void) | ||
42 | { | ||
43 | icoll_init_irq(); | ||
44 | } | ||
diff --git a/arch/arm/mach-mxs/module-tx28.c b/arch/arm/mach-mxs/module-tx28.c new file mode 100644 index 00000000000..0fcff47009c --- /dev/null +++ b/arch/arm/mach-mxs/module-tx28.c | |||
@@ -0,0 +1,160 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2010 <LW@KARO-electronics.de> | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or modify it under | ||
5 | * the terms of the GNU General Public License version 2 as published by the | ||
6 | * Free Software Foundation. | ||
7 | */ | ||
8 | |||
9 | #include <linux/delay.h> | ||
10 | #include <linux/fec.h> | ||
11 | #include <linux/gpio.h> | ||
12 | |||
13 | #include <mach/iomux-mx28.h> | ||
14 | #include "../devices-mx28.h" | ||
15 | |||
16 | #include "module-tx28.h" | ||
17 | |||
18 | #define TX28_FEC_PHY_POWER MXS_GPIO_NR(3, 29) | ||
19 | #define TX28_FEC_PHY_RESET MXS_GPIO_NR(4, 13) | ||
20 | |||
21 | static const iomux_cfg_t tx28_fec_gpio_pads[] __initconst = { | ||
22 | /* PHY POWER */ | ||
23 | MX28_PAD_PWM4__GPIO_3_29 | | ||
24 | MXS_PAD_4MA | MXS_PAD_NOPULL | MXS_PAD_3V3, | ||
25 | /* PHY RESET */ | ||
26 | MX28_PAD_ENET0_RX_CLK__GPIO_4_13 | | ||
27 | MXS_PAD_4MA | MXS_PAD_NOPULL | MXS_PAD_3V3, | ||
28 | /* Mode strap pins 0-2 */ | ||
29 | MX28_PAD_ENET0_RXD0__GPIO_4_3 | | ||
30 | MXS_PAD_8MA | MXS_PAD_PULLUP | MXS_PAD_3V3, | ||
31 | MX28_PAD_ENET0_RXD1__GPIO_4_4 | | ||
32 | MXS_PAD_8MA | MXS_PAD_PULLUP | MXS_PAD_3V3, | ||
33 | MX28_PAD_ENET0_RX_EN__GPIO_4_2 | | ||
34 | MXS_PAD_8MA | MXS_PAD_PULLUP | MXS_PAD_3V3, | ||
35 | /* nINT */ | ||
36 | MX28_PAD_ENET0_TX_CLK__GPIO_4_5 | | ||
37 | MXS_PAD_4MA | MXS_PAD_NOPULL | MXS_PAD_3V3, | ||
38 | |||
39 | MX28_PAD_ENET0_MDC__GPIO_4_0, | ||
40 | MX28_PAD_ENET0_MDIO__GPIO_4_1, | ||
41 | MX28_PAD_ENET0_TX_EN__GPIO_4_6, | ||
42 | MX28_PAD_ENET0_TXD0__GPIO_4_7, | ||
43 | MX28_PAD_ENET0_TXD1__GPIO_4_8, | ||
44 | MX28_PAD_ENET_CLK__GPIO_4_16, | ||
45 | }; | ||
46 | |||
47 | #define FEC_MODE (MXS_PAD_8MA | MXS_PAD_PULLUP | MXS_PAD_3V3) | ||
48 | static const iomux_cfg_t tx28_fec0_pads[] __initconst = { | ||
49 | MX28_PAD_ENET0_MDC__ENET0_MDC | FEC_MODE, | ||
50 | MX28_PAD_ENET0_MDIO__ENET0_MDIO | FEC_MODE, | ||
51 | MX28_PAD_ENET0_RX_EN__ENET0_RX_EN | FEC_MODE, | ||
52 | MX28_PAD_ENET0_RXD0__ENET0_RXD0 | FEC_MODE, | ||
53 | MX28_PAD_ENET0_RXD1__ENET0_RXD1 | FEC_MODE, | ||
54 | MX28_PAD_ENET0_TX_EN__ENET0_TX_EN | FEC_MODE, | ||
55 | MX28_PAD_ENET0_TXD0__ENET0_TXD0 | FEC_MODE, | ||
56 | MX28_PAD_ENET0_TXD1__ENET0_TXD1 | FEC_MODE, | ||
57 | MX28_PAD_ENET_CLK__CLKCTRL_ENET | FEC_MODE, | ||
58 | }; | ||
59 | |||
60 | static const iomux_cfg_t tx28_fec1_pads[] __initconst = { | ||
61 | MX28_PAD_ENET0_RXD2__ENET1_RXD0, | ||
62 | MX28_PAD_ENET0_RXD3__ENET1_RXD1, | ||
63 | MX28_PAD_ENET0_TXD2__ENET1_TXD0, | ||
64 | MX28_PAD_ENET0_TXD3__ENET1_TXD1, | ||
65 | MX28_PAD_ENET0_COL__ENET1_TX_EN, | ||
66 | MX28_PAD_ENET0_CRS__ENET1_RX_EN, | ||
67 | }; | ||
68 | |||
69 | static struct fec_platform_data tx28_fec0_data = { | ||
70 | .phy = PHY_INTERFACE_MODE_RMII, | ||
71 | }; | ||
72 | |||
73 | static struct fec_platform_data tx28_fec1_data = { | ||
74 | .phy = PHY_INTERFACE_MODE_RMII, | ||
75 | }; | ||
76 | |||
77 | int __init tx28_add_fec0(void) | ||
78 | { | ||
79 | int i, ret; | ||
80 | |||
81 | pr_debug("%s: Switching FEC PHY power off\n", __func__); | ||
82 | ret = mxs_iomux_setup_multiple_pads(tx28_fec_gpio_pads, | ||
83 | ARRAY_SIZE(tx28_fec_gpio_pads)); | ||
84 | for (i = 0; i < ARRAY_SIZE(tx28_fec_gpio_pads); i++) { | ||
85 | unsigned int gpio = MXS_GPIO_NR(PAD_BANK(tx28_fec_gpio_pads[i]), | ||
86 | PAD_PIN(tx28_fec_gpio_pads[i])); | ||
87 | |||
88 | ret = gpio_request(gpio, "FEC"); | ||
89 | if (ret) { | ||
90 | pr_err("Failed to request GPIO_%d_%d: %d\n", | ||
91 | PAD_BANK(tx28_fec_gpio_pads[i]), | ||
92 | PAD_PIN(tx28_fec_gpio_pads[i]), ret); | ||
93 | goto free_gpios; | ||
94 | } | ||
95 | ret = gpio_direction_output(gpio, 0); | ||
96 | if (ret) { | ||
97 | pr_err("Failed to set direction of GPIO_%d_%d to output: %d\n", | ||
98 | gpio / 32 + 1, gpio % 32, ret); | ||
99 | goto free_gpios; | ||
100 | } | ||
101 | } | ||
102 | |||
103 | /* Power up fec phy */ | ||
104 | pr_debug("%s: Switching FEC PHY power on\n", __func__); | ||
105 | ret = gpio_direction_output(TX28_FEC_PHY_POWER, 1); | ||
106 | if (ret) { | ||
107 | pr_err("Failed to power on PHY: %d\n", ret); | ||
108 | goto free_gpios; | ||
109 | } | ||
110 | mdelay(26); /* 25ms according to data sheet */ | ||
111 | |||
112 | /* nINT */ | ||
113 | gpio_direction_input(MXS_GPIO_NR(4, 5)); | ||
114 | /* Mode strap pins */ | ||
115 | gpio_direction_output(MXS_GPIO_NR(4, 2), 1); | ||
116 | gpio_direction_output(MXS_GPIO_NR(4, 3), 1); | ||
117 | gpio_direction_output(MXS_GPIO_NR(4, 4), 1); | ||
118 | |||
119 | udelay(100); /* minimum assertion time for nRST */ | ||
120 | |||
121 | pr_debug("%s: Deasserting FEC PHY RESET\n", __func__); | ||
122 | gpio_set_value(TX28_FEC_PHY_RESET, 1); | ||
123 | |||
124 | ret = mxs_iomux_setup_multiple_pads(tx28_fec0_pads, | ||
125 | ARRAY_SIZE(tx28_fec0_pads)); | ||
126 | if (ret) { | ||
127 | pr_debug("%s: mxs_iomux_setup_multiple_pads() failed with rc: %d\n", | ||
128 | __func__, ret); | ||
129 | goto free_gpios; | ||
130 | } | ||
131 | pr_debug("%s: Registering FEC0 device\n", __func__); | ||
132 | mx28_add_fec(0, &tx28_fec0_data); | ||
133 | return 0; | ||
134 | |||
135 | free_gpios: | ||
136 | while (--i >= 0) { | ||
137 | unsigned int gpio = MXS_GPIO_NR(PAD_BANK(tx28_fec_gpio_pads[i]), | ||
138 | PAD_PIN(tx28_fec_gpio_pads[i])); | ||
139 | |||
140 | gpio_free(gpio); | ||
141 | } | ||
142 | |||
143 | return ret; | ||
144 | } | ||
145 | |||
146 | int __init tx28_add_fec1(void) | ||
147 | { | ||
148 | int ret; | ||
149 | |||
150 | ret = mxs_iomux_setup_multiple_pads(tx28_fec1_pads, | ||
151 | ARRAY_SIZE(tx28_fec1_pads)); | ||
152 | if (ret) { | ||
153 | pr_debug("%s: mxs_iomux_setup_multiple_pads() failed with rc: %d\n", | ||
154 | __func__, ret); | ||
155 | return ret; | ||
156 | } | ||
157 | pr_debug("%s: Registering FEC1 device\n", __func__); | ||
158 | mx28_add_fec(1, &tx28_fec1_data); | ||
159 | return 0; | ||
160 | } | ||
diff --git a/arch/arm/mach-mxs/module-tx28.h b/arch/arm/mach-mxs/module-tx28.h new file mode 100644 index 00000000000..8ed425457d3 --- /dev/null +++ b/arch/arm/mach-mxs/module-tx28.h | |||
@@ -0,0 +1,10 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2010 Pengutronix | ||
3 | * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de> | ||
4 | * | ||
5 | * This program is free software; you can redistribute it and/or modify it under | ||
6 | * the terms of the GNU General Public License version 2 as published by the | ||
7 | * Free Software Foundation. | ||
8 | */ | ||
9 | int __init tx28_add_fec0(void); | ||
10 | int __init tx28_add_fec1(void); | ||
diff --git a/arch/arm/mach-mxs/regs-clkctrl-mx23.h b/arch/arm/mach-mxs/regs-clkctrl-mx23.h new file mode 100644 index 00000000000..0ea5c9d0e2b --- /dev/null +++ b/arch/arm/mach-mxs/regs-clkctrl-mx23.h | |||
@@ -0,0 +1,331 @@ | |||
1 | /* | ||
2 | * Freescale CLKCTRL Register Definitions | ||
3 | * | ||
4 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
5 | * Copyright 2008-2010 Freescale Semiconductor, Inc. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | * | ||
21 | * This file is created by xml file. Don't Edit it. | ||
22 | * | ||
23 | * Xml Revision: 1.48 | ||
24 | * Template revision: 26195 | ||
25 | */ | ||
26 | |||
27 | #ifndef __REGS_CLKCTRL_MX23_H__ | ||
28 | #define __REGS_CLKCTRL_MX23_H__ | ||
29 | |||
30 | |||
31 | #define HW_CLKCTRL_PLLCTRL0 (0x00000000) | ||
32 | #define HW_CLKCTRL_PLLCTRL0_SET (0x00000004) | ||
33 | #define HW_CLKCTRL_PLLCTRL0_CLR (0x00000008) | ||
34 | #define HW_CLKCTRL_PLLCTRL0_TOG (0x0000000c) | ||
35 | |||
36 | #define BP_CLKCTRL_PLLCTRL0_LFR_SEL 28 | ||
37 | #define BM_CLKCTRL_PLLCTRL0_LFR_SEL 0x30000000 | ||
38 | #define BF_CLKCTRL_PLLCTRL0_LFR_SEL(v) \ | ||
39 | (((v) << 28) & BM_CLKCTRL_PLLCTRL0_LFR_SEL) | ||
40 | #define BV_CLKCTRL_PLLCTRL0_LFR_SEL__DEFAULT 0x0 | ||
41 | #define BV_CLKCTRL_PLLCTRL0_LFR_SEL__TIMES_2 0x1 | ||
42 | #define BV_CLKCTRL_PLLCTRL0_LFR_SEL__TIMES_05 0x2 | ||
43 | #define BV_CLKCTRL_PLLCTRL0_LFR_SEL__UNDEFINED 0x3 | ||
44 | #define BP_CLKCTRL_PLLCTRL0_CP_SEL 24 | ||
45 | #define BM_CLKCTRL_PLLCTRL0_CP_SEL 0x03000000 | ||
46 | #define BF_CLKCTRL_PLLCTRL0_CP_SEL(v) \ | ||
47 | (((v) << 24) & BM_CLKCTRL_PLLCTRL0_CP_SEL) | ||
48 | #define BV_CLKCTRL_PLLCTRL0_CP_SEL__DEFAULT 0x0 | ||
49 | #define BV_CLKCTRL_PLLCTRL0_CP_SEL__TIMES_2 0x1 | ||
50 | #define BV_CLKCTRL_PLLCTRL0_CP_SEL__TIMES_05 0x2 | ||
51 | #define BV_CLKCTRL_PLLCTRL0_CP_SEL__UNDEFINED 0x3 | ||
52 | #define BP_CLKCTRL_PLLCTRL0_DIV_SEL 20 | ||
53 | #define BM_CLKCTRL_PLLCTRL0_DIV_SEL 0x00300000 | ||
54 | #define BF_CLKCTRL_PLLCTRL0_DIV_SEL(v) \ | ||
55 | (((v) << 20) & BM_CLKCTRL_PLLCTRL0_DIV_SEL) | ||
56 | #define BV_CLKCTRL_PLLCTRL0_DIV_SEL__DEFAULT 0x0 | ||
57 | #define BV_CLKCTRL_PLLCTRL0_DIV_SEL__LOWER 0x1 | ||
58 | #define BV_CLKCTRL_PLLCTRL0_DIV_SEL__LOWEST 0x2 | ||
59 | #define BV_CLKCTRL_PLLCTRL0_DIV_SEL__UNDEFINED 0x3 | ||
60 | #define BM_CLKCTRL_PLLCTRL0_EN_USB_CLKS 0x00040000 | ||
61 | #define BM_CLKCTRL_PLLCTRL0_POWER 0x00010000 | ||
62 | |||
63 | #define HW_CLKCTRL_PLLCTRL1 (0x00000010) | ||
64 | |||
65 | #define BM_CLKCTRL_PLLCTRL1_LOCK 0x80000000 | ||
66 | #define BM_CLKCTRL_PLLCTRL1_FORCE_LOCK 0x40000000 | ||
67 | #define BP_CLKCTRL_PLLCTRL1_LOCK_COUNT 0 | ||
68 | #define BM_CLKCTRL_PLLCTRL1_LOCK_COUNT 0x0000FFFF | ||
69 | #define BF_CLKCTRL_PLLCTRL1_LOCK_COUNT(v) \ | ||
70 | (((v) << 0) & BM_CLKCTRL_PLLCTRL1_LOCK_COUNT) | ||
71 | |||
72 | #define HW_CLKCTRL_CPU (0x00000020) | ||
73 | #define HW_CLKCTRL_CPU_SET (0x00000024) | ||
74 | #define HW_CLKCTRL_CPU_CLR (0x00000028) | ||
75 | #define HW_CLKCTRL_CPU_TOG (0x0000002c) | ||
76 | |||
77 | #define BM_CLKCTRL_CPU_BUSY_REF_XTAL 0x20000000 | ||
78 | #define BM_CLKCTRL_CPU_BUSY_REF_CPU 0x10000000 | ||
79 | #define BM_CLKCTRL_CPU_DIV_XTAL_FRAC_EN 0x04000000 | ||
80 | #define BP_CLKCTRL_CPU_DIV_XTAL 16 | ||
81 | #define BM_CLKCTRL_CPU_DIV_XTAL 0x03FF0000 | ||
82 | #define BF_CLKCTRL_CPU_DIV_XTAL(v) \ | ||
83 | (((v) << 16) & BM_CLKCTRL_CPU_DIV_XTAL) | ||
84 | #define BM_CLKCTRL_CPU_INTERRUPT_WAIT 0x00001000 | ||
85 | #define BM_CLKCTRL_CPU_DIV_CPU_FRAC_EN 0x00000400 | ||
86 | #define BP_CLKCTRL_CPU_DIV_CPU 0 | ||
87 | #define BM_CLKCTRL_CPU_DIV_CPU 0x0000003F | ||
88 | #define BF_CLKCTRL_CPU_DIV_CPU(v) \ | ||
89 | (((v) << 0) & BM_CLKCTRL_CPU_DIV_CPU) | ||
90 | |||
91 | #define HW_CLKCTRL_HBUS (0x00000030) | ||
92 | #define HW_CLKCTRL_HBUS_SET (0x00000034) | ||
93 | #define HW_CLKCTRL_HBUS_CLR (0x00000038) | ||
94 | #define HW_CLKCTRL_HBUS_TOG (0x0000003c) | ||
95 | |||
96 | #define BM_CLKCTRL_HBUS_BUSY 0x20000000 | ||
97 | #define BM_CLKCTRL_HBUS_DCP_AS_ENABLE 0x10000000 | ||
98 | #define BM_CLKCTRL_HBUS_PXP_AS_ENABLE 0x08000000 | ||
99 | #define BM_CLKCTRL_HBUS_APBHDMA_AS_ENABLE 0x04000000 | ||
100 | #define BM_CLKCTRL_HBUS_APBXDMA_AS_ENABLE 0x02000000 | ||
101 | #define BM_CLKCTRL_HBUS_TRAFFIC_JAM_AS_ENABLE 0x01000000 | ||
102 | #define BM_CLKCTRL_HBUS_TRAFFIC_AS_ENABLE 0x00800000 | ||
103 | #define BM_CLKCTRL_HBUS_CPU_DATA_AS_ENABLE 0x00400000 | ||
104 | #define BM_CLKCTRL_HBUS_CPU_INSTR_AS_ENABLE 0x00200000 | ||
105 | #define BM_CLKCTRL_HBUS_AUTO_SLOW_MODE 0x00100000 | ||
106 | #define BP_CLKCTRL_HBUS_SLOW_DIV 16 | ||
107 | #define BM_CLKCTRL_HBUS_SLOW_DIV 0x00070000 | ||
108 | #define BF_CLKCTRL_HBUS_SLOW_DIV(v) \ | ||
109 | (((v) << 16) & BM_CLKCTRL_HBUS_SLOW_DIV) | ||
110 | #define BV_CLKCTRL_HBUS_SLOW_DIV__BY1 0x0 | ||
111 | #define BV_CLKCTRL_HBUS_SLOW_DIV__BY2 0x1 | ||
112 | #define BV_CLKCTRL_HBUS_SLOW_DIV__BY4 0x2 | ||
113 | #define BV_CLKCTRL_HBUS_SLOW_DIV__BY8 0x3 | ||
114 | #define BV_CLKCTRL_HBUS_SLOW_DIV__BY16 0x4 | ||
115 | #define BV_CLKCTRL_HBUS_SLOW_DIV__BY32 0x5 | ||
116 | #define BM_CLKCTRL_HBUS_DIV_FRAC_EN 0x00000020 | ||
117 | #define BP_CLKCTRL_HBUS_DIV 0 | ||
118 | #define BM_CLKCTRL_HBUS_DIV 0x0000001F | ||
119 | #define BF_CLKCTRL_HBUS_DIV(v) \ | ||
120 | (((v) << 0) & BM_CLKCTRL_HBUS_DIV) | ||
121 | |||
122 | #define HW_CLKCTRL_XBUS (0x00000040) | ||
123 | |||
124 | #define BM_CLKCTRL_XBUS_BUSY 0x80000000 | ||
125 | #define BM_CLKCTRL_XBUS_DIV_FRAC_EN 0x00000400 | ||
126 | #define BP_CLKCTRL_XBUS_DIV 0 | ||
127 | #define BM_CLKCTRL_XBUS_DIV 0x000003FF | ||
128 | #define BF_CLKCTRL_XBUS_DIV(v) \ | ||
129 | (((v) << 0) & BM_CLKCTRL_XBUS_DIV) | ||
130 | |||
131 | #define HW_CLKCTRL_XTAL (0x00000050) | ||
132 | #define HW_CLKCTRL_XTAL_SET (0x00000054) | ||
133 | #define HW_CLKCTRL_XTAL_CLR (0x00000058) | ||
134 | #define HW_CLKCTRL_XTAL_TOG (0x0000005c) | ||
135 | |||
136 | #define BP_CLKCTRL_XTAL_UART_CLK_GATE 31 | ||
137 | #define BM_CLKCTRL_XTAL_UART_CLK_GATE 0x80000000 | ||
138 | #define BP_CLKCTRL_XTAL_FILT_CLK24M_GATE 30 | ||
139 | #define BM_CLKCTRL_XTAL_FILT_CLK24M_GATE 0x40000000 | ||
140 | #define BP_CLKCTRL_XTAL_PWM_CLK24M_GATE 29 | ||
141 | #define BM_CLKCTRL_XTAL_PWM_CLK24M_GATE 0x20000000 | ||
142 | #define BM_CLKCTRL_XTAL_DRI_CLK24M_GATE 0x10000000 | ||
143 | #define BM_CLKCTRL_XTAL_DIGCTRL_CLK1M_GATE 0x08000000 | ||
144 | #define BP_CLKCTRL_XTAL_TIMROT_CLK32K_GATE 26 | ||
145 | #define BM_CLKCTRL_XTAL_TIMROT_CLK32K_GATE 0x04000000 | ||
146 | #define BP_CLKCTRL_XTAL_DIV_UART 0 | ||
147 | #define BM_CLKCTRL_XTAL_DIV_UART 0x00000003 | ||
148 | #define BF_CLKCTRL_XTAL_DIV_UART(v) \ | ||
149 | (((v) << 0) & BM_CLKCTRL_XTAL_DIV_UART) | ||
150 | |||
151 | #define HW_CLKCTRL_PIX (0x00000060) | ||
152 | |||
153 | #define BP_CLKCTRL_PIX_CLKGATE 31 | ||
154 | #define BM_CLKCTRL_PIX_CLKGATE 0x80000000 | ||
155 | #define BM_CLKCTRL_PIX_BUSY 0x20000000 | ||
156 | #define BM_CLKCTRL_PIX_DIV_FRAC_EN 0x00001000 | ||
157 | #define BP_CLKCTRL_PIX_DIV 0 | ||
158 | #define BM_CLKCTRL_PIX_DIV 0x00000FFF | ||
159 | #define BF_CLKCTRL_PIX_DIV(v) \ | ||
160 | (((v) << 0) & BM_CLKCTRL_PIX_DIV) | ||
161 | |||
162 | #define HW_CLKCTRL_SSP (0x00000070) | ||
163 | |||
164 | #define BP_CLKCTRL_SSP_CLKGATE 31 | ||
165 | #define BM_CLKCTRL_SSP_CLKGATE 0x80000000 | ||
166 | #define BM_CLKCTRL_SSP_BUSY 0x20000000 | ||
167 | #define BM_CLKCTRL_SSP_DIV_FRAC_EN 0x00000200 | ||
168 | #define BP_CLKCTRL_SSP_DIV 0 | ||
169 | #define BM_CLKCTRL_SSP_DIV 0x000001FF | ||
170 | #define BF_CLKCTRL_SSP_DIV(v) \ | ||
171 | (((v) << 0) & BM_CLKCTRL_SSP_DIV) | ||
172 | |||
173 | #define HW_CLKCTRL_GPMI (0x00000080) | ||
174 | |||
175 | #define BP_CLKCTRL_GPMI_CLKGATE 31 | ||
176 | #define BM_CLKCTRL_GPMI_CLKGATE 0x80000000 | ||
177 | #define BM_CLKCTRL_GPMI_BUSY 0x20000000 | ||
178 | #define BM_CLKCTRL_GPMI_DIV_FRAC_EN 0x00000400 | ||
179 | #define BP_CLKCTRL_GPMI_DIV 0 | ||
180 | #define BM_CLKCTRL_GPMI_DIV 0x000003FF | ||
181 | #define BF_CLKCTRL_GPMI_DIV(v) \ | ||
182 | (((v) << 0) & BM_CLKCTRL_GPMI_DIV) | ||
183 | |||
184 | #define HW_CLKCTRL_SPDIF (0x00000090) | ||
185 | |||
186 | #define BM_CLKCTRL_SPDIF_CLKGATE 0x80000000 | ||
187 | |||
188 | #define HW_CLKCTRL_EMI (0x000000a0) | ||
189 | |||
190 | #define BP_CLKCTRL_EMI_CLKGATE 31 | ||
191 | #define BM_CLKCTRL_EMI_CLKGATE 0x80000000 | ||
192 | #define BM_CLKCTRL_EMI_SYNC_MODE_EN 0x40000000 | ||
193 | #define BM_CLKCTRL_EMI_BUSY_REF_XTAL 0x20000000 | ||
194 | #define BM_CLKCTRL_EMI_BUSY_REF_EMI 0x10000000 | ||
195 | #define BM_CLKCTRL_EMI_BUSY_REF_CPU 0x08000000 | ||
196 | #define BM_CLKCTRL_EMI_BUSY_SYNC_MODE 0x04000000 | ||
197 | #define BM_CLKCTRL_EMI_BUSY_DCC_RESYNC 0x00020000 | ||
198 | #define BM_CLKCTRL_EMI_DCC_RESYNC_ENABLE 0x00010000 | ||
199 | #define BP_CLKCTRL_EMI_DIV_XTAL 8 | ||
200 | #define BM_CLKCTRL_EMI_DIV_XTAL 0x00000F00 | ||
201 | #define BF_CLKCTRL_EMI_DIV_XTAL(v) \ | ||
202 | (((v) << 8) & BM_CLKCTRL_EMI_DIV_XTAL) | ||
203 | #define BP_CLKCTRL_EMI_DIV_EMI 0 | ||
204 | #define BM_CLKCTRL_EMI_DIV_EMI 0x0000003F | ||
205 | #define BF_CLKCTRL_EMI_DIV_EMI(v) \ | ||
206 | (((v) << 0) & BM_CLKCTRL_EMI_DIV_EMI) | ||
207 | |||
208 | #define HW_CLKCTRL_IR (0x000000b0) | ||
209 | |||
210 | #define BM_CLKCTRL_IR_CLKGATE 0x80000000 | ||
211 | #define BM_CLKCTRL_IR_AUTO_DIV 0x20000000 | ||
212 | #define BM_CLKCTRL_IR_IR_BUSY 0x10000000 | ||
213 | #define BM_CLKCTRL_IR_IROV_BUSY 0x08000000 | ||
214 | #define BP_CLKCTRL_IR_IROV_DIV 16 | ||
215 | #define BM_CLKCTRL_IR_IROV_DIV 0x01FF0000 | ||
216 | #define BF_CLKCTRL_IR_IROV_DIV(v) \ | ||
217 | (((v) << 16) & BM_CLKCTRL_IR_IROV_DIV) | ||
218 | #define BP_CLKCTRL_IR_IR_DIV 0 | ||
219 | #define BM_CLKCTRL_IR_IR_DIV 0x000003FF | ||
220 | #define BF_CLKCTRL_IR_IR_DIV(v) \ | ||
221 | (((v) << 0) & BM_CLKCTRL_IR_IR_DIV) | ||
222 | |||
223 | #define HW_CLKCTRL_SAIF (0x000000c0) | ||
224 | |||
225 | #define BM_CLKCTRL_SAIF_CLKGATE 0x80000000 | ||
226 | #define BM_CLKCTRL_SAIF_BUSY 0x20000000 | ||
227 | #define BM_CLKCTRL_SAIF_DIV_FRAC_EN 0x00010000 | ||
228 | #define BP_CLKCTRL_SAIF_DIV 0 | ||
229 | #define BM_CLKCTRL_SAIF_DIV 0x0000FFFF | ||
230 | #define BF_CLKCTRL_SAIF_DIV(v) \ | ||
231 | (((v) << 0) & BM_CLKCTRL_SAIF_DIV) | ||
232 | |||
233 | #define HW_CLKCTRL_TV (0x000000d0) | ||
234 | |||
235 | #define BM_CLKCTRL_TV_CLK_TV108M_GATE 0x80000000 | ||
236 | #define BM_CLKCTRL_TV_CLK_TV_GATE 0x40000000 | ||
237 | |||
238 | #define HW_CLKCTRL_ETM (0x000000e0) | ||
239 | |||
240 | #define BM_CLKCTRL_ETM_CLKGATE 0x80000000 | ||
241 | #define BM_CLKCTRL_ETM_BUSY 0x20000000 | ||
242 | #define BM_CLKCTRL_ETM_DIV_FRAC_EN 0x00000040 | ||
243 | #define BP_CLKCTRL_ETM_DIV 0 | ||
244 | #define BM_CLKCTRL_ETM_DIV 0x0000003F | ||
245 | #define BF_CLKCTRL_ETM_DIV(v) \ | ||
246 | (((v) << 0) & BM_CLKCTRL_ETM_DIV) | ||
247 | |||
248 | #define HW_CLKCTRL_FRAC (0x000000f0) | ||
249 | #define HW_CLKCTRL_FRAC_SET (0x000000f4) | ||
250 | #define HW_CLKCTRL_FRAC_CLR (0x000000f8) | ||
251 | #define HW_CLKCTRL_FRAC_TOG (0x000000fc) | ||
252 | |||
253 | #define BP_CLKCTRL_FRAC_CLKGATEIO 31 | ||
254 | #define BM_CLKCTRL_FRAC_CLKGATEIO 0x80000000 | ||
255 | #define BM_CLKCTRL_FRAC_IO_STABLE 0x40000000 | ||
256 | #define BP_CLKCTRL_FRAC_IOFRAC 24 | ||
257 | #define BM_CLKCTRL_FRAC_IOFRAC 0x3F000000 | ||
258 | #define BF_CLKCTRL_FRAC_IOFRAC(v) \ | ||
259 | (((v) << 24) & BM_CLKCTRL_FRAC_IOFRAC) | ||
260 | #define BP_CLKCTRL_FRAC_CLKGATEPIX 23 | ||
261 | #define BM_CLKCTRL_FRAC_CLKGATEPIX 0x00800000 | ||
262 | #define BM_CLKCTRL_FRAC_PIX_STABLE 0x00400000 | ||
263 | #define BP_CLKCTRL_FRAC_PIXFRAC 16 | ||
264 | #define BM_CLKCTRL_FRAC_PIXFRAC 0x003F0000 | ||
265 | #define BF_CLKCTRL_FRAC_PIXFRAC(v) \ | ||
266 | (((v) << 16) & BM_CLKCTRL_FRAC_PIXFRAC) | ||
267 | #define BP_CLKCTRL_FRAC_CLKGATEEMI 15 | ||
268 | #define BM_CLKCTRL_FRAC_CLKGATEEMI 0x00008000 | ||
269 | #define BM_CLKCTRL_FRAC_EMI_STABLE 0x00004000 | ||
270 | #define BP_CLKCTRL_FRAC_EMIFRAC 8 | ||
271 | #define BM_CLKCTRL_FRAC_EMIFRAC 0x00003F00 | ||
272 | #define BF_CLKCTRL_FRAC_EMIFRAC(v) \ | ||
273 | (((v) << 8) & BM_CLKCTRL_FRAC_EMIFRAC) | ||
274 | #define BP_CLKCTRL_FRAC_CLKGATECPU 7 | ||
275 | #define BM_CLKCTRL_FRAC_CLKGATECPU 0x00000080 | ||
276 | #define BM_CLKCTRL_FRAC_CPU_STABLE 0x00000040 | ||
277 | #define BP_CLKCTRL_FRAC_CPUFRAC 0 | ||
278 | #define BM_CLKCTRL_FRAC_CPUFRAC 0x0000003F | ||
279 | #define BF_CLKCTRL_FRAC_CPUFRAC(v) \ | ||
280 | (((v) << 0) & BM_CLKCTRL_FRAC_CPUFRAC) | ||
281 | |||
282 | #define HW_CLKCTRL_FRAC1 (0x00000100) | ||
283 | #define HW_CLKCTRL_FRAC1_SET (0x00000104) | ||
284 | #define HW_CLKCTRL_FRAC1_CLR (0x00000108) | ||
285 | #define HW_CLKCTRL_FRAC1_TOG (0x0000010c) | ||
286 | |||
287 | #define BM_CLKCTRL_FRAC1_CLKGATEVID 0x80000000 | ||
288 | #define BM_CLKCTRL_FRAC1_VID_STABLE 0x40000000 | ||
289 | |||
290 | #define HW_CLKCTRL_CLKSEQ (0x00000110) | ||
291 | #define HW_CLKCTRL_CLKSEQ_SET (0x00000114) | ||
292 | #define HW_CLKCTRL_CLKSEQ_CLR (0x00000118) | ||
293 | #define HW_CLKCTRL_CLKSEQ_TOG (0x0000011c) | ||
294 | |||
295 | #define BM_CLKCTRL_CLKSEQ_BYPASS_ETM 0x00000100 | ||
296 | #define BM_CLKCTRL_CLKSEQ_BYPASS_CPU 0x00000080 | ||
297 | #define BM_CLKCTRL_CLKSEQ_BYPASS_EMI 0x00000040 | ||
298 | #define BM_CLKCTRL_CLKSEQ_BYPASS_SSP 0x00000020 | ||
299 | #define BM_CLKCTRL_CLKSEQ_BYPASS_GPMI 0x00000010 | ||
300 | #define BM_CLKCTRL_CLKSEQ_BYPASS_IR 0x00000008 | ||
301 | #define BM_CLKCTRL_CLKSEQ_BYPASS_PIX 0x00000002 | ||
302 | #define BM_CLKCTRL_CLKSEQ_BYPASS_SAIF 0x00000001 | ||
303 | |||
304 | #define HW_CLKCTRL_RESET (0x00000120) | ||
305 | |||
306 | #define BM_CLKCTRL_RESET_CHIP 0x00000002 | ||
307 | #define BM_CLKCTRL_RESET_DIG 0x00000001 | ||
308 | |||
309 | #define HW_CLKCTRL_STATUS (0x00000130) | ||
310 | |||
311 | #define BP_CLKCTRL_STATUS_CPU_LIMIT 30 | ||
312 | #define BM_CLKCTRL_STATUS_CPU_LIMIT 0xC0000000 | ||
313 | #define BF_CLKCTRL_STATUS_CPU_LIMIT(v) \ | ||
314 | (((v) << 30) & BM_CLKCTRL_STATUS_CPU_LIMIT) | ||
315 | |||
316 | #define HW_CLKCTRL_VERSION (0x00000140) | ||
317 | |||
318 | #define BP_CLKCTRL_VERSION_MAJOR 24 | ||
319 | #define BM_CLKCTRL_VERSION_MAJOR 0xFF000000 | ||
320 | #define BF_CLKCTRL_VERSION_MAJOR(v) \ | ||
321 | (((v) << 24) & BM_CLKCTRL_VERSION_MAJOR) | ||
322 | #define BP_CLKCTRL_VERSION_MINOR 16 | ||
323 | #define BM_CLKCTRL_VERSION_MINOR 0x00FF0000 | ||
324 | #define BF_CLKCTRL_VERSION_MINOR(v) \ | ||
325 | (((v) << 16) & BM_CLKCTRL_VERSION_MINOR) | ||
326 | #define BP_CLKCTRL_VERSION_STEP 0 | ||
327 | #define BM_CLKCTRL_VERSION_STEP 0x0000FFFF | ||
328 | #define BF_CLKCTRL_VERSION_STEP(v) \ | ||
329 | (((v) << 0) & BM_CLKCTRL_VERSION_STEP) | ||
330 | |||
331 | #endif /* __REGS_CLKCTRL_MX23_H__ */ | ||
diff --git a/arch/arm/mach-mxs/regs-clkctrl-mx28.h b/arch/arm/mach-mxs/regs-clkctrl-mx28.h new file mode 100644 index 00000000000..7d1b061d794 --- /dev/null +++ b/arch/arm/mach-mxs/regs-clkctrl-mx28.h | |||
@@ -0,0 +1,486 @@ | |||
1 | /* | ||
2 | * Freescale CLKCTRL Register Definitions | ||
3 | * | ||
4 | * Copyright 2009-2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License as published by | ||
8 | * the Free Software Foundation; either version 2 of the License, or | ||
9 | * (at your option) any later version. | ||
10 | * | ||
11 | * This program is distributed in the hope that it will be useful, | ||
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
14 | * GNU General Public License for more details. | ||
15 | * | ||
16 | * You should have received a copy of the GNU General Public License | ||
17 | * along with this program; if not, write to the Free Software | ||
18 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
19 | * | ||
20 | * This file is created by xml file. Don't Edit it. | ||
21 | * | ||
22 | * Xml Revision: 1.48 | ||
23 | * Template revision: 26195 | ||
24 | */ | ||
25 | |||
26 | #ifndef __REGS_CLKCTRL_MX28_H__ | ||
27 | #define __REGS_CLKCTRL_MX28_H__ | ||
28 | |||
29 | #define HW_CLKCTRL_PLL0CTRL0 (0x00000000) | ||
30 | #define HW_CLKCTRL_PLL0CTRL0_SET (0x00000004) | ||
31 | #define HW_CLKCTRL_PLL0CTRL0_CLR (0x00000008) | ||
32 | #define HW_CLKCTRL_PLL0CTRL0_TOG (0x0000000c) | ||
33 | |||
34 | #define BP_CLKCTRL_PLL0CTRL0_LFR_SEL 28 | ||
35 | #define BM_CLKCTRL_PLL0CTRL0_LFR_SEL 0x30000000 | ||
36 | #define BF_CLKCTRL_PLL0CTRL0_LFR_SEL(v) \ | ||
37 | (((v) << 28) & BM_CLKCTRL_PLL0CTRL0_LFR_SEL) | ||
38 | #define BV_CLKCTRL_PLL0CTRL0_LFR_SEL__DEFAULT 0x0 | ||
39 | #define BV_CLKCTRL_PLL0CTRL0_LFR_SEL__TIMES_2 0x1 | ||
40 | #define BV_CLKCTRL_PLL0CTRL0_LFR_SEL__TIMES_05 0x2 | ||
41 | #define BV_CLKCTRL_PLL0CTRL0_LFR_SEL__UNDEFINED 0x3 | ||
42 | #define BP_CLKCTRL_PLL0CTRL0_CP_SEL 24 | ||
43 | #define BM_CLKCTRL_PLL0CTRL0_CP_SEL 0x03000000 | ||
44 | #define BF_CLKCTRL_PLL0CTRL0_CP_SEL(v) \ | ||
45 | (((v) << 24) & BM_CLKCTRL_PLL0CTRL0_CP_SEL) | ||
46 | #define BV_CLKCTRL_PLL0CTRL0_CP_SEL__DEFAULT 0x0 | ||
47 | #define BV_CLKCTRL_PLL0CTRL0_CP_SEL__TIMES_2 0x1 | ||
48 | #define BV_CLKCTRL_PLL0CTRL0_CP_SEL__TIMES_05 0x2 | ||
49 | #define BV_CLKCTRL_PLL0CTRL0_CP_SEL__UNDEFINED 0x3 | ||
50 | #define BP_CLKCTRL_PLL0CTRL0_DIV_SEL 20 | ||
51 | #define BM_CLKCTRL_PLL0CTRL0_DIV_SEL 0x00300000 | ||
52 | #define BF_CLKCTRL_PLL0CTRL0_DIV_SEL(v) \ | ||
53 | (((v) << 20) & BM_CLKCTRL_PLL0CTRL0_DIV_SEL) | ||
54 | #define BV_CLKCTRL_PLL0CTRL0_DIV_SEL__DEFAULT 0x0 | ||
55 | #define BV_CLKCTRL_PLL0CTRL0_DIV_SEL__LOWER 0x1 | ||
56 | #define BV_CLKCTRL_PLL0CTRL0_DIV_SEL__LOWEST 0x2 | ||
57 | #define BV_CLKCTRL_PLL0CTRL0_DIV_SEL__UNDEFINED 0x3 | ||
58 | #define BM_CLKCTRL_PLL0CTRL0_EN_USB_CLKS 0x00040000 | ||
59 | #define BM_CLKCTRL_PLL0CTRL0_POWER 0x00020000 | ||
60 | |||
61 | #define HW_CLKCTRL_PLL0CTRL1 (0x00000010) | ||
62 | |||
63 | #define BM_CLKCTRL_PLL0CTRL1_LOCK 0x80000000 | ||
64 | #define BM_CLKCTRL_PLL0CTRL1_FORCE_LOCK 0x40000000 | ||
65 | #define BP_CLKCTRL_PLL0CTRL1_LOCK_COUNT 0 | ||
66 | #define BM_CLKCTRL_PLL0CTRL1_LOCK_COUNT 0x0000FFFF | ||
67 | #define BF_CLKCTRL_PLL0CTRL1_LOCK_COUNT(v) \ | ||
68 | (((v) << 0) & BM_CLKCTRL_PLL0CTRL1_LOCK_COUNT) | ||
69 | |||
70 | #define HW_CLKCTRL_PLL1CTRL0 (0x00000020) | ||
71 | #define HW_CLKCTRL_PLL1CTRL0_SET (0x00000024) | ||
72 | #define HW_CLKCTRL_PLL1CTRL0_CLR (0x00000028) | ||
73 | #define HW_CLKCTRL_PLL1CTRL0_TOG (0x0000002c) | ||
74 | |||
75 | #define BM_CLKCTRL_PLL1CTRL0_CLKGATEEMI 0x80000000 | ||
76 | #define BP_CLKCTRL_PLL1CTRL0_LFR_SEL 28 | ||
77 | #define BM_CLKCTRL_PLL1CTRL0_LFR_SEL 0x30000000 | ||
78 | #define BF_CLKCTRL_PLL1CTRL0_LFR_SEL(v) \ | ||
79 | (((v) << 28) & BM_CLKCTRL_PLL1CTRL0_LFR_SEL) | ||
80 | #define BV_CLKCTRL_PLL1CTRL0_LFR_SEL__DEFAULT 0x0 | ||
81 | #define BV_CLKCTRL_PLL1CTRL0_LFR_SEL__TIMES_2 0x1 | ||
82 | #define BV_CLKCTRL_PLL1CTRL0_LFR_SEL__TIMES_05 0x2 | ||
83 | #define BV_CLKCTRL_PLL1CTRL0_LFR_SEL__UNDEFINED 0x3 | ||
84 | #define BP_CLKCTRL_PLL1CTRL0_CP_SEL 24 | ||
85 | #define BM_CLKCTRL_PLL1CTRL0_CP_SEL 0x03000000 | ||
86 | #define BF_CLKCTRL_PLL1CTRL0_CP_SEL(v) \ | ||
87 | (((v) << 24) & BM_CLKCTRL_PLL1CTRL0_CP_SEL) | ||
88 | #define BV_CLKCTRL_PLL1CTRL0_CP_SEL__DEFAULT 0x0 | ||
89 | #define BV_CLKCTRL_PLL1CTRL0_CP_SEL__TIMES_2 0x1 | ||
90 | #define BV_CLKCTRL_PLL1CTRL0_CP_SEL__TIMES_05 0x2 | ||
91 | #define BV_CLKCTRL_PLL1CTRL0_CP_SEL__UNDEFINED 0x3 | ||
92 | #define BP_CLKCTRL_PLL1CTRL0_DIV_SEL 20 | ||
93 | #define BM_CLKCTRL_PLL1CTRL0_DIV_SEL 0x00300000 | ||
94 | #define BF_CLKCTRL_PLL1CTRL0_DIV_SEL(v) \ | ||
95 | (((v) << 20) & BM_CLKCTRL_PLL1CTRL0_DIV_SEL) | ||
96 | #define BV_CLKCTRL_PLL1CTRL0_DIV_SEL__DEFAULT 0x0 | ||
97 | #define BV_CLKCTRL_PLL1CTRL0_DIV_SEL__LOWER 0x1 | ||
98 | #define BV_CLKCTRL_PLL1CTRL0_DIV_SEL__LOWEST 0x2 | ||
99 | #define BV_CLKCTRL_PLL1CTRL0_DIV_SEL__UNDEFINED 0x3 | ||
100 | #define BM_CLKCTRL_PLL1CTRL0_EN_USB_CLKS 0x00040000 | ||
101 | #define BM_CLKCTRL_PLL1CTRL0_POWER 0x00020000 | ||
102 | |||
103 | #define HW_CLKCTRL_PLL1CTRL1 (0x00000030) | ||
104 | |||
105 | #define BM_CLKCTRL_PLL1CTRL1_LOCK 0x80000000 | ||
106 | #define BM_CLKCTRL_PLL1CTRL1_FORCE_LOCK 0x40000000 | ||
107 | #define BP_CLKCTRL_PLL1CTRL1_LOCK_COUNT 0 | ||
108 | #define BM_CLKCTRL_PLL1CTRL1_LOCK_COUNT 0x0000FFFF | ||
109 | #define BF_CLKCTRL_PLL1CTRL1_LOCK_COUNT(v) \ | ||
110 | (((v) << 0) & BM_CLKCTRL_PLL1CTRL1_LOCK_COUNT) | ||
111 | |||
112 | #define HW_CLKCTRL_PLL2CTRL0 (0x00000040) | ||
113 | #define HW_CLKCTRL_PLL2CTRL0_SET (0x00000044) | ||
114 | #define HW_CLKCTRL_PLL2CTRL0_CLR (0x00000048) | ||
115 | #define HW_CLKCTRL_PLL2CTRL0_TOG (0x0000004c) | ||
116 | |||
117 | #define BM_CLKCTRL_PLL2CTRL0_CLKGATE 0x80000000 | ||
118 | #define BP_CLKCTRL_PLL2CTRL0_LFR_SEL 28 | ||
119 | #define BM_CLKCTRL_PLL2CTRL0_LFR_SEL 0x30000000 | ||
120 | #define BF_CLKCTRL_PLL2CTRL0_LFR_SEL(v) \ | ||
121 | (((v) << 28) & BM_CLKCTRL_PLL2CTRL0_LFR_SEL) | ||
122 | #define BM_CLKCTRL_PLL2CTRL0_HOLD_RING_OFF_B 0x04000000 | ||
123 | #define BP_CLKCTRL_PLL2CTRL0_CP_SEL 24 | ||
124 | #define BM_CLKCTRL_PLL2CTRL0_CP_SEL 0x03000000 | ||
125 | #define BF_CLKCTRL_PLL2CTRL0_CP_SEL(v) \ | ||
126 | (((v) << 24) & BM_CLKCTRL_PLL2CTRL0_CP_SEL) | ||
127 | #define BM_CLKCTRL_PLL2CTRL0_POWER 0x00800000 | ||
128 | |||
129 | #define HW_CLKCTRL_CPU (0x00000050) | ||
130 | #define HW_CLKCTRL_CPU_SET (0x00000054) | ||
131 | #define HW_CLKCTRL_CPU_CLR (0x00000058) | ||
132 | #define HW_CLKCTRL_CPU_TOG (0x0000005c) | ||
133 | |||
134 | #define BM_CLKCTRL_CPU_BUSY_REF_XTAL 0x20000000 | ||
135 | #define BM_CLKCTRL_CPU_BUSY_REF_CPU 0x10000000 | ||
136 | #define BM_CLKCTRL_CPU_DIV_XTAL_FRAC_EN 0x04000000 | ||
137 | #define BP_CLKCTRL_CPU_DIV_XTAL 16 | ||
138 | #define BM_CLKCTRL_CPU_DIV_XTAL 0x03FF0000 | ||
139 | #define BF_CLKCTRL_CPU_DIV_XTAL(v) \ | ||
140 | (((v) << 16) & BM_CLKCTRL_CPU_DIV_XTAL) | ||
141 | #define BM_CLKCTRL_CPU_INTERRUPT_WAIT 0x00001000 | ||
142 | #define BM_CLKCTRL_CPU_DIV_CPU_FRAC_EN 0x00000400 | ||
143 | #define BP_CLKCTRL_CPU_DIV_CPU 0 | ||
144 | #define BM_CLKCTRL_CPU_DIV_CPU 0x0000003F | ||
145 | #define BF_CLKCTRL_CPU_DIV_CPU(v) \ | ||
146 | (((v) << 0) & BM_CLKCTRL_CPU_DIV_CPU) | ||
147 | |||
148 | #define HW_CLKCTRL_HBUS (0x00000060) | ||
149 | #define HW_CLKCTRL_HBUS_SET (0x00000064) | ||
150 | #define HW_CLKCTRL_HBUS_CLR (0x00000068) | ||
151 | #define HW_CLKCTRL_HBUS_TOG (0x0000006c) | ||
152 | |||
153 | #define BM_CLKCTRL_HBUS_ASM_BUSY 0x80000000 | ||
154 | #define BM_CLKCTRL_HBUS_DCP_AS_ENABLE 0x40000000 | ||
155 | #define BM_CLKCTRL_HBUS_PXP_AS_ENABLE 0x20000000 | ||
156 | #define BM_CLKCTRL_HBUS_ASM_EMIPORT_AS_ENABLE 0x08000000 | ||
157 | #define BM_CLKCTRL_HBUS_APBHDMA_AS_ENABLE 0x04000000 | ||
158 | #define BM_CLKCTRL_HBUS_APBXDMA_AS_ENABLE 0x02000000 | ||
159 | #define BM_CLKCTRL_HBUS_TRAFFIC_JAM_AS_ENABLE 0x01000000 | ||
160 | #define BM_CLKCTRL_HBUS_TRAFFIC_AS_ENABLE 0x00800000 | ||
161 | #define BM_CLKCTRL_HBUS_CPU_DATA_AS_ENABLE 0x00400000 | ||
162 | #define BM_CLKCTRL_HBUS_CPU_INSTR_AS_ENABLE 0x00200000 | ||
163 | #define BM_CLKCTRL_HBUS_ASM_ENABLE 0x00100000 | ||
164 | #define BM_CLKCTRL_HBUS_AUTO_CLEAR_DIV_ENABLE 0x00080000 | ||
165 | #define BP_CLKCTRL_HBUS_SLOW_DIV 16 | ||
166 | #define BM_CLKCTRL_HBUS_SLOW_DIV 0x00070000 | ||
167 | #define BF_CLKCTRL_HBUS_SLOW_DIV(v) \ | ||
168 | (((v) << 16) & BM_CLKCTRL_HBUS_SLOW_DIV) | ||
169 | #define BV_CLKCTRL_HBUS_SLOW_DIV__BY1 0x0 | ||
170 | #define BV_CLKCTRL_HBUS_SLOW_DIV__BY2 0x1 | ||
171 | #define BV_CLKCTRL_HBUS_SLOW_DIV__BY4 0x2 | ||
172 | #define BV_CLKCTRL_HBUS_SLOW_DIV__BY8 0x3 | ||
173 | #define BV_CLKCTRL_HBUS_SLOW_DIV__BY16 0x4 | ||
174 | #define BV_CLKCTRL_HBUS_SLOW_DIV__BY32 0x5 | ||
175 | #define BM_CLKCTRL_HBUS_DIV_FRAC_EN 0x00000020 | ||
176 | #define BP_CLKCTRL_HBUS_DIV 0 | ||
177 | #define BM_CLKCTRL_HBUS_DIV 0x0000001F | ||
178 | #define BF_CLKCTRL_HBUS_DIV(v) \ | ||
179 | (((v) << 0) & BM_CLKCTRL_HBUS_DIV) | ||
180 | |||
181 | #define HW_CLKCTRL_XBUS (0x00000070) | ||
182 | |||
183 | #define BM_CLKCTRL_XBUS_BUSY 0x80000000 | ||
184 | #define BM_CLKCTRL_XBUS_AUTO_CLEAR_DIV_ENABLE 0x00000800 | ||
185 | #define BM_CLKCTRL_XBUS_DIV_FRAC_EN 0x00000400 | ||
186 | #define BP_CLKCTRL_XBUS_DIV 0 | ||
187 | #define BM_CLKCTRL_XBUS_DIV 0x000003FF | ||
188 | #define BF_CLKCTRL_XBUS_DIV(v) \ | ||
189 | (((v) << 0) & BM_CLKCTRL_XBUS_DIV) | ||
190 | |||
191 | #define HW_CLKCTRL_XTAL (0x00000080) | ||
192 | #define HW_CLKCTRL_XTAL_SET (0x00000084) | ||
193 | #define HW_CLKCTRL_XTAL_CLR (0x00000088) | ||
194 | #define HW_CLKCTRL_XTAL_TOG (0x0000008c) | ||
195 | |||
196 | #define BP_CLKCTRL_XTAL_UART_CLK_GATE 31 | ||
197 | #define BM_CLKCTRL_XTAL_UART_CLK_GATE 0x80000000 | ||
198 | #define BP_CLKCTRL_XTAL_PWM_CLK24M_GATE 29 | ||
199 | #define BM_CLKCTRL_XTAL_PWM_CLK24M_GATE 0x20000000 | ||
200 | #define BP_CLKCTRL_XTAL_TIMROT_CLK32K_GATE 26 | ||
201 | #define BM_CLKCTRL_XTAL_TIMROT_CLK32K_GATE 0x04000000 | ||
202 | #define BP_CLKCTRL_XTAL_DIV_UART 0 | ||
203 | #define BM_CLKCTRL_XTAL_DIV_UART 0x00000003 | ||
204 | #define BF_CLKCTRL_XTAL_DIV_UART(v) \ | ||
205 | (((v) << 0) & BM_CLKCTRL_XTAL_DIV_UART) | ||
206 | |||
207 | #define HW_CLKCTRL_SSP0 (0x00000090) | ||
208 | |||
209 | #define BP_CLKCTRL_SSP0_CLKGATE 31 | ||
210 | #define BM_CLKCTRL_SSP0_CLKGATE 0x80000000 | ||
211 | #define BM_CLKCTRL_SSP0_BUSY 0x20000000 | ||
212 | #define BM_CLKCTRL_SSP0_DIV_FRAC_EN 0x00000200 | ||
213 | #define BP_CLKCTRL_SSP0_DIV 0 | ||
214 | #define BM_CLKCTRL_SSP0_DIV 0x000001FF | ||
215 | #define BF_CLKCTRL_SSP0_DIV(v) \ | ||
216 | (((v) << 0) & BM_CLKCTRL_SSP0_DIV) | ||
217 | |||
218 | #define HW_CLKCTRL_SSP1 (0x000000a0) | ||
219 | |||
220 | #define BP_CLKCTRL_SSP1_CLKGATE 31 | ||
221 | #define BM_CLKCTRL_SSP1_CLKGATE 0x80000000 | ||
222 | #define BM_CLKCTRL_SSP1_BUSY 0x20000000 | ||
223 | #define BM_CLKCTRL_SSP1_DIV_FRAC_EN 0x00000200 | ||
224 | #define BP_CLKCTRL_SSP1_DIV 0 | ||
225 | #define BM_CLKCTRL_SSP1_DIV 0x000001FF | ||
226 | #define BF_CLKCTRL_SSP1_DIV(v) \ | ||
227 | (((v) << 0) & BM_CLKCTRL_SSP1_DIV) | ||
228 | |||
229 | #define HW_CLKCTRL_SSP2 (0x000000b0) | ||
230 | |||
231 | #define BP_CLKCTRL_SSP2_CLKGATE 31 | ||
232 | #define BM_CLKCTRL_SSP2_CLKGATE 0x80000000 | ||
233 | #define BM_CLKCTRL_SSP2_BUSY 0x20000000 | ||
234 | #define BM_CLKCTRL_SSP2_DIV_FRAC_EN 0x00000200 | ||
235 | #define BP_CLKCTRL_SSP2_DIV 0 | ||
236 | #define BM_CLKCTRL_SSP2_DIV 0x000001FF | ||
237 | #define BF_CLKCTRL_SSP2_DIV(v) \ | ||
238 | (((v) << 0) & BM_CLKCTRL_SSP2_DIV) | ||
239 | |||
240 | #define HW_CLKCTRL_SSP3 (0x000000c0) | ||
241 | |||
242 | #define BP_CLKCTRL_SSP3_CLKGATE 31 | ||
243 | #define BM_CLKCTRL_SSP3_CLKGATE 0x80000000 | ||
244 | #define BM_CLKCTRL_SSP3_BUSY 0x20000000 | ||
245 | #define BM_CLKCTRL_SSP3_DIV_FRAC_EN 0x00000200 | ||
246 | #define BP_CLKCTRL_SSP3_DIV 0 | ||
247 | #define BM_CLKCTRL_SSP3_DIV 0x000001FF | ||
248 | #define BF_CLKCTRL_SSP3_DIV(v) \ | ||
249 | (((v) << 0) & BM_CLKCTRL_SSP3_DIV) | ||
250 | |||
251 | #define HW_CLKCTRL_GPMI (0x000000d0) | ||
252 | |||
253 | #define BP_CLKCTRL_GPMI_CLKGATE 31 | ||
254 | #define BM_CLKCTRL_GPMI_CLKGATE 0x80000000 | ||
255 | #define BM_CLKCTRL_GPMI_BUSY 0x20000000 | ||
256 | #define BM_CLKCTRL_GPMI_DIV_FRAC_EN 0x00000400 | ||
257 | #define BP_CLKCTRL_GPMI_DIV 0 | ||
258 | #define BM_CLKCTRL_GPMI_DIV 0x000003FF | ||
259 | #define BF_CLKCTRL_GPMI_DIV(v) \ | ||
260 | (((v) << 0) & BM_CLKCTRL_GPMI_DIV) | ||
261 | |||
262 | #define HW_CLKCTRL_SPDIF (0x000000e0) | ||
263 | |||
264 | #define BP_CLKCTRL_SPDIF_CLKGATE 31 | ||
265 | #define BM_CLKCTRL_SPDIF_CLKGATE 0x80000000 | ||
266 | |||
267 | #define HW_CLKCTRL_EMI (0x000000f0) | ||
268 | |||
269 | #define BP_CLKCTRL_EMI_CLKGATE 31 | ||
270 | #define BM_CLKCTRL_EMI_CLKGATE 0x80000000 | ||
271 | #define BM_CLKCTRL_EMI_SYNC_MODE_EN 0x40000000 | ||
272 | #define BM_CLKCTRL_EMI_BUSY_REF_XTAL 0x20000000 | ||
273 | #define BM_CLKCTRL_EMI_BUSY_REF_EMI 0x10000000 | ||
274 | #define BM_CLKCTRL_EMI_BUSY_REF_CPU 0x08000000 | ||
275 | #define BM_CLKCTRL_EMI_BUSY_SYNC_MODE 0x04000000 | ||
276 | #define BM_CLKCTRL_EMI_BUSY_DCC_RESYNC 0x00020000 | ||
277 | #define BM_CLKCTRL_EMI_DCC_RESYNC_ENABLE 0x00010000 | ||
278 | #define BP_CLKCTRL_EMI_DIV_XTAL 8 | ||
279 | #define BM_CLKCTRL_EMI_DIV_XTAL 0x00000F00 | ||
280 | #define BF_CLKCTRL_EMI_DIV_XTAL(v) \ | ||
281 | (((v) << 8) & BM_CLKCTRL_EMI_DIV_XTAL) | ||
282 | #define BP_CLKCTRL_EMI_DIV_EMI 0 | ||
283 | #define BM_CLKCTRL_EMI_DIV_EMI 0x0000003F | ||
284 | #define BF_CLKCTRL_EMI_DIV_EMI(v) \ | ||
285 | (((v) << 0) & BM_CLKCTRL_EMI_DIV_EMI) | ||
286 | |||
287 | #define HW_CLKCTRL_SAIF0 (0x00000100) | ||
288 | |||
289 | #define BP_CLKCTRL_SAIF0_CLKGATE 31 | ||
290 | #define BM_CLKCTRL_SAIF0_CLKGATE 0x80000000 | ||
291 | #define BM_CLKCTRL_SAIF0_BUSY 0x20000000 | ||
292 | #define BM_CLKCTRL_SAIF0_DIV_FRAC_EN 0x00010000 | ||
293 | #define BP_CLKCTRL_SAIF0_DIV 0 | ||
294 | #define BM_CLKCTRL_SAIF0_DIV 0x0000FFFF | ||
295 | #define BF_CLKCTRL_SAIF0_DIV(v) \ | ||
296 | (((v) << 0) & BM_CLKCTRL_SAIF0_DIV) | ||
297 | |||
298 | #define HW_CLKCTRL_SAIF1 (0x00000110) | ||
299 | |||
300 | #define BP_CLKCTRL_SAIF1_CLKGATE 31 | ||
301 | #define BM_CLKCTRL_SAIF1_CLKGATE 0x80000000 | ||
302 | #define BM_CLKCTRL_SAIF1_BUSY 0x20000000 | ||
303 | #define BM_CLKCTRL_SAIF1_DIV_FRAC_EN 0x00010000 | ||
304 | #define BP_CLKCTRL_SAIF1_DIV 0 | ||
305 | #define BM_CLKCTRL_SAIF1_DIV 0x0000FFFF | ||
306 | #define BF_CLKCTRL_SAIF1_DIV(v) \ | ||
307 | (((v) << 0) & BM_CLKCTRL_SAIF1_DIV) | ||
308 | |||
309 | #define HW_CLKCTRL_DIS_LCDIF (0x00000120) | ||
310 | |||
311 | #define BP_CLKCTRL_DIS_LCDIF_CLKGATE 31 | ||
312 | #define BM_CLKCTRL_DIS_LCDIF_CLKGATE 0x80000000 | ||
313 | #define BM_CLKCTRL_DIS_LCDIF_BUSY 0x20000000 | ||
314 | #define BM_CLKCTRL_DIS_LCDIF_DIV_FRAC_EN 0x00002000 | ||
315 | #define BP_CLKCTRL_DIS_LCDIF_DIV 0 | ||
316 | #define BM_CLKCTRL_DIS_LCDIF_DIV 0x00001FFF | ||
317 | #define BF_CLKCTRL_DIS_LCDIF_DIV(v) \ | ||
318 | (((v) << 0) & BM_CLKCTRL_DIS_LCDIF_DIV) | ||
319 | |||
320 | #define HW_CLKCTRL_ETM (0x00000130) | ||
321 | |||
322 | #define BM_CLKCTRL_ETM_CLKGATE 0x80000000 | ||
323 | #define BM_CLKCTRL_ETM_BUSY 0x20000000 | ||
324 | #define BM_CLKCTRL_ETM_DIV_FRAC_EN 0x00000080 | ||
325 | #define BP_CLKCTRL_ETM_DIV 0 | ||
326 | #define BM_CLKCTRL_ETM_DIV 0x0000007F | ||
327 | #define BF_CLKCTRL_ETM_DIV(v) \ | ||
328 | (((v) << 0) & BM_CLKCTRL_ETM_DIV) | ||
329 | |||
330 | #define HW_CLKCTRL_ENET (0x00000140) | ||
331 | |||
332 | #define BM_CLKCTRL_ENET_SLEEP 0x80000000 | ||
333 | #define BP_CLKCTRL_ENET_DISABLE 30 | ||
334 | #define BM_CLKCTRL_ENET_DISABLE 0x40000000 | ||
335 | #define BM_CLKCTRL_ENET_STATUS 0x20000000 | ||
336 | #define BM_CLKCTRL_ENET_BUSY_TIME 0x08000000 | ||
337 | #define BP_CLKCTRL_ENET_DIV_TIME 21 | ||
338 | #define BM_CLKCTRL_ENET_DIV_TIME 0x07E00000 | ||
339 | #define BF_CLKCTRL_ENET_DIV_TIME(v) \ | ||
340 | (((v) << 21) & BM_CLKCTRL_ENET_DIV_TIME) | ||
341 | #define BM_CLKCTRL_ENET_BUSY 0x08000000 | ||
342 | #define BP_CLKCTRL_ENET_DIV 21 | ||
343 | #define BM_CLKCTRL_ENET_DIV 0x07E00000 | ||
344 | #define BF_CLKCTRL_ENET_DIV(v) \ | ||
345 | (((v) << 21) & BM_CLKCTRL_ENET_DIV) | ||
346 | #define BP_CLKCTRL_ENET_TIME_SEL 19 | ||
347 | #define BM_CLKCTRL_ENET_TIME_SEL 0x00180000 | ||
348 | #define BF_CLKCTRL_ENET_TIME_SEL(v) \ | ||
349 | (((v) << 19) & BM_CLKCTRL_ENET_TIME_SEL) | ||
350 | #define BV_CLKCTRL_ENET_TIME_SEL__XTAL 0x0 | ||
351 | #define BV_CLKCTRL_ENET_TIME_SEL__PLL 0x1 | ||
352 | #define BV_CLKCTRL_ENET_TIME_SEL__RMII_CLK 0x2 | ||
353 | #define BV_CLKCTRL_ENET_TIME_SEL__UNDEFINED 0x3 | ||
354 | #define BM_CLKCTRL_ENET_CLK_OUT_EN 0x00040000 | ||
355 | #define BM_CLKCTRL_ENET_RESET_BY_SW_CHIP 0x00020000 | ||
356 | #define BM_CLKCTRL_ENET_RESET_BY_SW 0x00010000 | ||
357 | |||
358 | #define HW_CLKCTRL_HSADC (0x00000150) | ||
359 | |||
360 | #define BM_CLKCTRL_HSADC_RESETB 0x40000000 | ||
361 | #define BP_CLKCTRL_HSADC_FREQDIV 28 | ||
362 | #define BM_CLKCTRL_HSADC_FREQDIV 0x30000000 | ||
363 | #define BF_CLKCTRL_HSADC_FREQDIV(v) \ | ||
364 | (((v) << 28) & BM_CLKCTRL_HSADC_FREQDIV) | ||
365 | |||
366 | #define HW_CLKCTRL_FLEXCAN (0x00000160) | ||
367 | |||
368 | #define BP_CLKCTRL_FLEXCAN_STOP_CAN0 30 | ||
369 | #define BM_CLKCTRL_FLEXCAN_STOP_CAN0 0x40000000 | ||
370 | #define BM_CLKCTRL_FLEXCAN_CAN0_STATUS 0x20000000 | ||
371 | #define BP_CLKCTRL_FLEXCAN_STOP_CAN1 28 | ||
372 | #define BM_CLKCTRL_FLEXCAN_STOP_CAN1 0x10000000 | ||
373 | #define BM_CLKCTRL_FLEXCAN_CAN1_STATUS 0x08000000 | ||
374 | |||
375 | #define HW_CLKCTRL_FRAC0 (0x000001b0) | ||
376 | #define HW_CLKCTRL_FRAC0_SET (0x000001b4) | ||
377 | #define HW_CLKCTRL_FRAC0_CLR (0x000001b8) | ||
378 | #define HW_CLKCTRL_FRAC0_TOG (0x000001bc) | ||
379 | |||
380 | #define BP_CLKCTRL_FRAC0_CLKGATEIO0 31 | ||
381 | #define BM_CLKCTRL_FRAC0_CLKGATEIO0 0x80000000 | ||
382 | #define BM_CLKCTRL_FRAC0_IO0_STABLE 0x40000000 | ||
383 | #define BP_CLKCTRL_FRAC0_IO0FRAC 24 | ||
384 | #define BM_CLKCTRL_FRAC0_IO0FRAC 0x3F000000 | ||
385 | #define BF_CLKCTRL_FRAC0_IO0FRAC(v) \ | ||
386 | (((v) << 24) & BM_CLKCTRL_FRAC0_IO0FRAC) | ||
387 | #define BP_CLKCTRL_FRAC0_CLKGATEIO1 23 | ||
388 | #define BM_CLKCTRL_FRAC0_CLKGATEIO1 0x00800000 | ||
389 | #define BM_CLKCTRL_FRAC0_IO1_STABLE 0x00400000 | ||
390 | #define BP_CLKCTRL_FRAC0_IO1FRAC 16 | ||
391 | #define BM_CLKCTRL_FRAC0_IO1FRAC 0x003F0000 | ||
392 | #define BF_CLKCTRL_FRAC0_IO1FRAC(v) \ | ||
393 | (((v) << 16) & BM_CLKCTRL_FRAC0_IO1FRAC) | ||
394 | #define BP_CLKCTRL_FRAC0_CLKGATEEMI 15 | ||
395 | #define BM_CLKCTRL_FRAC0_CLKGATEEMI 0x00008000 | ||
396 | #define BM_CLKCTRL_FRAC0_EMI_STABLE 0x00004000 | ||
397 | #define BP_CLKCTRL_FRAC0_EMIFRAC 8 | ||
398 | #define BM_CLKCTRL_FRAC0_EMIFRAC 0x00003F00 | ||
399 | #define BF_CLKCTRL_FRAC0_EMIFRAC(v) \ | ||
400 | (((v) << 8) & BM_CLKCTRL_FRAC0_EMIFRAC) | ||
401 | #define BP_CLKCTRL_FRAC0_CLKGATECPU 7 | ||
402 | #define BM_CLKCTRL_FRAC0_CLKGATECPU 0x00000080 | ||
403 | #define BM_CLKCTRL_FRAC0_CPU_STABLE 0x00000040 | ||
404 | #define BP_CLKCTRL_FRAC0_CPUFRAC 0 | ||
405 | #define BM_CLKCTRL_FRAC0_CPUFRAC 0x0000003F | ||
406 | #define BF_CLKCTRL_FRAC0_CPUFRAC(v) \ | ||
407 | (((v) << 0) & BM_CLKCTRL_FRAC0_CPUFRAC) | ||
408 | |||
409 | #define HW_CLKCTRL_FRAC1 (0x000001c0) | ||
410 | #define HW_CLKCTRL_FRAC1_SET (0x000001c4) | ||
411 | #define HW_CLKCTRL_FRAC1_CLR (0x000001c8) | ||
412 | #define HW_CLKCTRL_FRAC1_TOG (0x000001cc) | ||
413 | |||
414 | #define BP_CLKCTRL_FRAC1_CLKGATEGPMI 23 | ||
415 | #define BM_CLKCTRL_FRAC1_CLKGATEGPMI 0x00800000 | ||
416 | #define BM_CLKCTRL_FRAC1_GPMI_STABLE 0x00400000 | ||
417 | #define BP_CLKCTRL_FRAC1_GPMIFRAC 16 | ||
418 | #define BM_CLKCTRL_FRAC1_GPMIFRAC 0x003F0000 | ||
419 | #define BF_CLKCTRL_FRAC1_GPMIFRAC(v) \ | ||
420 | (((v) << 16) & BM_CLKCTRL_FRAC1_GPMIFRAC) | ||
421 | #define BP_CLKCTRL_FRAC1_CLKGATEHSADC 15 | ||
422 | #define BM_CLKCTRL_FRAC1_CLKGATEHSADC 0x00008000 | ||
423 | #define BM_CLKCTRL_FRAC1_HSADC_STABLE 0x00004000 | ||
424 | #define BP_CLKCTRL_FRAC1_HSADCFRAC 8 | ||
425 | #define BM_CLKCTRL_FRAC1_HSADCFRAC 0x00003F00 | ||
426 | #define BF_CLKCTRL_FRAC1_HSADCFRAC(v) \ | ||
427 | (((v) << 8) & BM_CLKCTRL_FRAC1_HSADCFRAC) | ||
428 | #define BP_CLKCTRL_FRAC1_CLKGATEPIX 7 | ||
429 | #define BM_CLKCTRL_FRAC1_CLKGATEPIX 0x00000080 | ||
430 | #define BM_CLKCTRL_FRAC1_PIX_STABLE 0x00000040 | ||
431 | #define BP_CLKCTRL_FRAC1_PIXFRAC 0 | ||
432 | #define BM_CLKCTRL_FRAC1_PIXFRAC 0x0000003F | ||
433 | #define BF_CLKCTRL_FRAC1_PIXFRAC(v) \ | ||
434 | (((v) << 0) & BM_CLKCTRL_FRAC1_PIXFRAC) | ||
435 | |||
436 | #define HW_CLKCTRL_CLKSEQ (0x000001d0) | ||
437 | #define HW_CLKCTRL_CLKSEQ_SET (0x000001d4) | ||
438 | #define HW_CLKCTRL_CLKSEQ_CLR (0x000001d8) | ||
439 | #define HW_CLKCTRL_CLKSEQ_TOG (0x000001dc) | ||
440 | |||
441 | #define BM_CLKCTRL_CLKSEQ_BYPASS_CPU 0x00040000 | ||
442 | #define BM_CLKCTRL_CLKSEQ_BYPASS_DIS_LCDIF 0x00004000 | ||
443 | #define BV_CLKCTRL_CLKSEQ_BYPASS_DIS_LCDIF__BYPASS 0x1 | ||
444 | #define BV_CLKCTRL_CLKSEQ_BYPASS_DIS_LCDIF__PFD 0x0 | ||
445 | #define BM_CLKCTRL_CLKSEQ_BYPASS_ETM 0x00000100 | ||
446 | #define BM_CLKCTRL_CLKSEQ_BYPASS_EMI 0x00000080 | ||
447 | #define BM_CLKCTRL_CLKSEQ_BYPASS_SSP3 0x00000040 | ||
448 | #define BM_CLKCTRL_CLKSEQ_BYPASS_SSP2 0x00000020 | ||
449 | #define BM_CLKCTRL_CLKSEQ_BYPASS_SSP1 0x00000010 | ||
450 | #define BM_CLKCTRL_CLKSEQ_BYPASS_SSP0 0x00000008 | ||
451 | #define BM_CLKCTRL_CLKSEQ_BYPASS_GPMI 0x00000004 | ||
452 | #define BM_CLKCTRL_CLKSEQ_BYPASS_SAIF1 0x00000002 | ||
453 | #define BM_CLKCTRL_CLKSEQ_BYPASS_SAIF0 0x00000001 | ||
454 | |||
455 | #define HW_CLKCTRL_RESET (0x000001e0) | ||
456 | |||
457 | #define BM_CLKCTRL_RESET_WDOG_POR_DISABLE 0x00000020 | ||
458 | #define BM_CLKCTRL_RESET_EXTERNAL_RESET_ENABLE 0x00000010 | ||
459 | #define BM_CLKCTRL_RESET_THERMAL_RESET_ENABLE 0x00000008 | ||
460 | #define BM_CLKCTRL_RESET_THERMAL_RESET_DEFAULT 0x00000004 | ||
461 | #define BM_CLKCTRL_RESET_CHIP 0x00000002 | ||
462 | #define BM_CLKCTRL_RESET_DIG 0x00000001 | ||
463 | |||
464 | #define HW_CLKCTRL_STATUS (0x000001f0) | ||
465 | |||
466 | #define BP_CLKCTRL_STATUS_CPU_LIMIT 30 | ||
467 | #define BM_CLKCTRL_STATUS_CPU_LIMIT 0xC0000000 | ||
468 | #define BF_CLKCTRL_STATUS_CPU_LIMIT(v) \ | ||
469 | (((v) << 30) & BM_CLKCTRL_STATUS_CPU_LIMIT) | ||
470 | |||
471 | #define HW_CLKCTRL_VERSION (0x00000200) | ||
472 | |||
473 | #define BP_CLKCTRL_VERSION_MAJOR 24 | ||
474 | #define BM_CLKCTRL_VERSION_MAJOR 0xFF000000 | ||
475 | #define BF_CLKCTRL_VERSION_MAJOR(v) \ | ||
476 | (((v) << 24) & BM_CLKCTRL_VERSION_MAJOR) | ||
477 | #define BP_CLKCTRL_VERSION_MINOR 16 | ||
478 | #define BM_CLKCTRL_VERSION_MINOR 0x00FF0000 | ||
479 | #define BF_CLKCTRL_VERSION_MINOR(v) \ | ||
480 | (((v) << 16) & BM_CLKCTRL_VERSION_MINOR) | ||
481 | #define BP_CLKCTRL_VERSION_STEP 0 | ||
482 | #define BM_CLKCTRL_VERSION_STEP 0x0000FFFF | ||
483 | #define BF_CLKCTRL_VERSION_STEP(v) \ | ||
484 | (((v) << 0) & BM_CLKCTRL_VERSION_STEP) | ||
485 | |||
486 | #endif /* __REGS_CLKCTRL_MX28_H__ */ | ||