Loading...
1/*
2 * Copyright 2011 Freescale Semiconductor, Inc.
3 * Copyright 2011 Linaro Ltd.
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/dts-v1/;
14#include "imx51.dtsi"
15
16/ {
17 model = "Freescale i.MX51 Babbage Board";
18 compatible = "fsl,imx51-babbage", "fsl,imx51";
19
20 chosen {
21 stdout-path = &uart1;
22 };
23
24 memory@90000000 {
25 reg = <0x90000000 0x20000000>;
26 };
27
28 ckih1 {
29 clock-frequency = <22579200>;
30 };
31
32 clk_osc: clk-osc {
33 compatible = "fixed-clock";
34 #clock-cells = <0>;
35 clock-frequency = <26000000>;
36 };
37
38 clk_osc_gate: clk-osc-gate {
39 compatible = "gpio-gate-clock";
40 pinctrl-names = "default";
41 pinctrl-0 = <&pinctrl_clk26mhz_osc>;
42 clocks = <&clk_osc>;
43 #clock-cells = <0>;
44 enable-gpios = <&gpio3 1 GPIO_ACTIVE_HIGH>;
45 };
46
47 clk_audio: clk-audio {
48 compatible = "gpio-gate-clock";
49 pinctrl-names = "default";
50 pinctrl-0 = <&pinctrl_clk26mhz_audio>;
51 clocks = <&clk_osc_gate>;
52 #clock-cells = <0>;
53 enable-gpios = <&gpio4 26 GPIO_ACTIVE_LOW>;
54 };
55
56 clk_usb: clk-usb {
57 compatible = "gpio-gate-clock";
58 pinctrl-names = "default";
59 pinctrl-0 = <&pinctrl_clk26mhz_usb>;
60 clocks = <&clk_osc_gate>;
61 #clock-cells = <0>;
62 enable-gpios = <&gpio2 1 GPIO_ACTIVE_LOW>;
63 };
64
65 display1: disp1 {
66 compatible = "fsl,imx-parallel-display";
67 interface-pix-fmt = "rgb24";
68 pinctrl-names = "default";
69 pinctrl-0 = <&pinctrl_ipu_disp1>;
70 display-timings {
71 native-mode = <&timing0>;
72 timing0: dvi {
73 clock-frequency = <65000000>;
74 hactive = <1024>;
75 vactive = <768>;
76 hback-porch = <220>;
77 hfront-porch = <40>;
78 vback-porch = <21>;
79 vfront-porch = <7>;
80 hsync-len = <60>;
81 vsync-len = <10>;
82 };
83 };
84
85 port {
86 display0_in: endpoint {
87 remote-endpoint = <&ipu_di0_disp1>;
88 };
89 };
90 };
91
92 display2: disp2 {
93 compatible = "fsl,imx-parallel-display";
94 interface-pix-fmt = "rgb565";
95 pinctrl-names = "default";
96 pinctrl-0 = <&pinctrl_ipu_disp2>;
97 status = "disabled";
98 display-timings {
99 native-mode = <&timing1>;
100 timing1: claawvga {
101 clock-frequency = <27000000>;
102 hactive = <800>;
103 vactive = <480>;
104 hback-porch = <40>;
105 hfront-porch = <60>;
106 vback-porch = <10>;
107 vfront-porch = <10>;
108 hsync-len = <20>;
109 vsync-len = <10>;
110 hsync-active = <0>;
111 vsync-active = <0>;
112 de-active = <1>;
113 pixelclk-active = <0>;
114 };
115 };
116
117 port {
118 display1_in: endpoint {
119 remote-endpoint = <&ipu_di1_disp2>;
120 };
121 };
122 };
123
124 gpio-keys {
125 compatible = "gpio-keys";
126 pinctrl-names = "default";
127 pinctrl-0 = <&pinctrl_gpio_keys>;
128
129 power {
130 label = "Power Button";
131 gpios = <&gpio2 21 GPIO_ACTIVE_HIGH>;
132 linux,code = <KEY_POWER>;
133 wakeup-source;
134 };
135 };
136
137 leds {
138 compatible = "gpio-leds";
139 pinctrl-names = "default";
140 pinctrl-0 = <&pinctrl_gpio_leds>;
141
142 led-diagnostic {
143 label = "diagnostic";
144 gpios = <&gpio2 6 GPIO_ACTIVE_HIGH>;
145 };
146 };
147
148 regulators {
149 compatible = "simple-bus";
150 #address-cells = <1>;
151 #size-cells = <0>;
152
153 reg_hub_reset: regulator@0 {
154 compatible = "regulator-fixed";
155 pinctrl-names = "default";
156 pinctrl-0 = <&pinctrl_usbotgreg>;
157 reg = <0>;
158 regulator-name = "hub_reset";
159 regulator-min-microvolt = <5000000>;
160 regulator-max-microvolt = <5000000>;
161 gpio = <&gpio1 7 GPIO_ACTIVE_HIGH>;
162 enable-active-high;
163 };
164 };
165
166 sound {
167 compatible = "fsl,imx51-babbage-sgtl5000",
168 "fsl,imx-audio-sgtl5000";
169 model = "imx51-babbage-sgtl5000";
170 ssi-controller = <&ssi2>;
171 audio-codec = <&sgtl5000>;
172 audio-routing =
173 "MIC_IN", "Mic Jack",
174 "Mic Jack", "Mic Bias",
175 "Headphone Jack", "HP_OUT";
176 mux-int-port = <2>;
177 mux-ext-port = <3>;
178 };
179
180 usbphy {
181 #address-cells = <1>;
182 #size-cells = <0>;
183 compatible = "simple-bus";
184
185 usbh1phy: usbh1phy@0 {
186 compatible = "usb-nop-xceiv";
187 reg = <0>;
188 clocks = <&clk_usb>;
189 clock-names = "main_clk";
190 reset-gpios = <&gpio2 5 GPIO_ACTIVE_LOW>;
191 vcc-supply = <&vusb_reg>;
192 #phy-cells = <0>;
193 };
194 };
195};
196
197&audmux {
198 pinctrl-names = "default";
199 pinctrl-0 = <&pinctrl_audmux>;
200 status = "okay";
201};
202
203&ecspi1 {
204 pinctrl-names = "default";
205 pinctrl-0 = <&pinctrl_ecspi1>;
206 cs-gpios = <&gpio4 24 GPIO_ACTIVE_HIGH>,
207 <&gpio4 25 GPIO_ACTIVE_LOW>;
208 status = "okay";
209
210 pmic: mc13892@0 {
211 compatible = "fsl,mc13892";
212 pinctrl-names = "default";
213 pinctrl-0 = <&pinctrl_pmic>;
214 spi-max-frequency = <6000000>;
215 spi-cs-high;
216 reg = <0>;
217 interrupt-parent = <&gpio1>;
218 interrupts = <8 IRQ_TYPE_LEVEL_HIGH>;
219 fsl,mc13xxx-uses-rtc;
220
221 regulators {
222 sw1_reg: sw1 {
223 regulator-min-microvolt = <600000>;
224 regulator-max-microvolt = <1375000>;
225 regulator-boot-on;
226 regulator-always-on;
227 };
228
229 sw2_reg: sw2 {
230 regulator-min-microvolt = <900000>;
231 regulator-max-microvolt = <1850000>;
232 regulator-boot-on;
233 regulator-always-on;
234 };
235
236 sw3_reg: sw3 {
237 regulator-min-microvolt = <1100000>;
238 regulator-max-microvolt = <1850000>;
239 regulator-boot-on;
240 regulator-always-on;
241 };
242
243 sw4_reg: sw4 {
244 regulator-min-microvolt = <1100000>;
245 regulator-max-microvolt = <1850000>;
246 regulator-boot-on;
247 regulator-always-on;
248 };
249
250 vpll_reg: vpll {
251 regulator-min-microvolt = <1050000>;
252 regulator-max-microvolt = <1800000>;
253 regulator-boot-on;
254 regulator-always-on;
255 };
256
257 vdig_reg: vdig {
258 regulator-min-microvolt = <1650000>;
259 regulator-max-microvolt = <1650000>;
260 regulator-boot-on;
261 };
262
263 vsd_reg: vsd {
264 regulator-min-microvolt = <1800000>;
265 regulator-max-microvolt = <3150000>;
266 };
267
268 vusb_reg: vusb {
269 regulator-boot-on;
270 };
271
272 vusb2_reg: vusb2 {
273 regulator-min-microvolt = <2400000>;
274 regulator-max-microvolt = <2775000>;
275 regulator-boot-on;
276 regulator-always-on;
277 };
278
279 vvideo_reg: vvideo {
280 regulator-min-microvolt = <2775000>;
281 regulator-max-microvolt = <2775000>;
282 };
283
284 vaudio_reg: vaudio {
285 regulator-min-microvolt = <2300000>;
286 regulator-max-microvolt = <3000000>;
287 };
288
289 vcam_reg: vcam {
290 regulator-min-microvolt = <2500000>;
291 regulator-max-microvolt = <3000000>;
292 };
293
294 vgen1_reg: vgen1 {
295 regulator-min-microvolt = <1200000>;
296 regulator-max-microvolt = <1200000>;
297 };
298
299 vgen2_reg: vgen2 {
300 regulator-min-microvolt = <1200000>;
301 regulator-max-microvolt = <3150000>;
302 regulator-always-on;
303 };
304
305 vgen3_reg: vgen3 {
306 regulator-min-microvolt = <1800000>;
307 regulator-max-microvolt = <2900000>;
308 regulator-always-on;
309 };
310 };
311 };
312
313 flash: at45db321d@1 {
314 #address-cells = <1>;
315 #size-cells = <1>;
316 compatible = "atmel,at45db321d", "atmel,at45", "atmel,dataflash";
317 spi-max-frequency = <25000000>;
318 reg = <1>;
319
320 partition@0 {
321 label = "U-Boot";
322 reg = <0x0 0x40000>;
323 read-only;
324 };
325
326 partition@40000 {
327 label = "Kernel";
328 reg = <0x40000 0x3c0000>;
329 };
330 };
331};
332
333&esdhc1 {
334 pinctrl-names = "default";
335 pinctrl-0 = <&pinctrl_esdhc1>;
336 cd-gpios = <&gpio1 0 GPIO_ACTIVE_LOW>;
337 wp-gpios = <&gpio1 1 GPIO_ACTIVE_HIGH>;
338 status = "okay";
339};
340
341&esdhc2 {
342 pinctrl-names = "default";
343 pinctrl-0 = <&pinctrl_esdhc2>;
344 cd-gpios = <&gpio1 6 GPIO_ACTIVE_LOW>;
345 wp-gpios = <&gpio1 5 GPIO_ACTIVE_HIGH>;
346 status = "okay";
347};
348
349&fec {
350 pinctrl-names = "default";
351 pinctrl-0 = <&pinctrl_fec>;
352 phy-mode = "mii";
353 phy-reset-gpios = <&gpio2 14 GPIO_ACTIVE_LOW>;
354 phy-reset-duration = <1>;
355 status = "okay";
356};
357
358&i2c1 {
359 pinctrl-names = "default";
360 pinctrl-0 = <&pinctrl_i2c1>;
361 status = "okay";
362};
363
364&i2c2 {
365 pinctrl-names = "default";
366 pinctrl-0 = <&pinctrl_i2c2>;
367 status = "okay";
368
369 sgtl5000: codec@a {
370 compatible = "fsl,sgtl5000";
371 reg = <0x0a>;
372 #sound-dai-cells = <0>;
373 clocks = <&clk_audio>;
374 VDDA-supply = <&vdig_reg>;
375 VDDIO-supply = <&vvideo_reg>;
376 };
377};
378
379&ipu_di0_disp1 {
380 remote-endpoint = <&display0_in>;
381};
382
383&ipu_di1_disp2 {
384 remote-endpoint = <&display1_in>;
385};
386
387&kpp {
388 pinctrl-names = "default";
389 pinctrl-0 = <&pinctrl_kpp>;
390 linux,keymap = <
391 MATRIX_KEY(0, 0, KEY_UP)
392 MATRIX_KEY(0, 1, KEY_DOWN)
393 MATRIX_KEY(0, 2, KEY_VOLUMEDOWN)
394 MATRIX_KEY(0, 3, KEY_HOME)
395 MATRIX_KEY(1, 0, KEY_RIGHT)
396 MATRIX_KEY(1, 1, KEY_LEFT)
397 MATRIX_KEY(1, 2, KEY_ENTER)
398 MATRIX_KEY(1, 3, KEY_VOLUMEUP)
399 MATRIX_KEY(2, 0, KEY_F6)
400 MATRIX_KEY(2, 1, KEY_F8)
401 MATRIX_KEY(2, 2, KEY_F9)
402 MATRIX_KEY(2, 3, KEY_F10)
403 MATRIX_KEY(3, 0, KEY_F1)
404 MATRIX_KEY(3, 1, KEY_F2)
405 MATRIX_KEY(3, 2, KEY_F3)
406 MATRIX_KEY(3, 3, KEY_POWER)
407 >;
408 status = "okay";
409};
410
411&ssi2 {
412 status = "okay";
413};
414
415&uart1 {
416 pinctrl-names = "default";
417 pinctrl-0 = <&pinctrl_uart1>;
418 uart-has-rtscts;
419 status = "okay";
420};
421
422&uart2 {
423 pinctrl-names = "default";
424 pinctrl-0 = <&pinctrl_uart2>;
425 status = "okay";
426};
427
428&uart3 {
429 pinctrl-names = "default";
430 pinctrl-0 = <&pinctrl_uart3>;
431 uart-has-rtscts;
432 status = "okay";
433};
434
435&usbh1 {
436 pinctrl-names = "default";
437 pinctrl-0 = <&pinctrl_usbh1>;
438 vbus-supply = <®_hub_reset>;
439 fsl,usbphy = <&usbh1phy>;
440 phy_type = "ulpi";
441 status = "okay";
442};
443
444&usbphy0 {
445 vcc-supply = <&vusb_reg>;
446};
447
448&usbotg {
449 dr_mode = "otg";
450 disable-over-current;
451 phy_type = "utmi_wide";
452 status = "okay";
453};
454
455&iomuxc {
456 imx51-babbage {
457 pinctrl_audmux: audmuxgrp {
458 fsl,pins = <
459 MX51_PAD_AUD3_BB_TXD__AUD3_TXD 0x80000000
460 MX51_PAD_AUD3_BB_RXD__AUD3_RXD 0x80000000
461 MX51_PAD_AUD3_BB_CK__AUD3_TXC 0x80000000
462 MX51_PAD_AUD3_BB_FS__AUD3_TXFS 0x80000000
463 >;
464 };
465
466 pinctrl_clk26mhz_audio: clk26mhzaudiocgrp {
467 fsl,pins = <
468 MX51_PAD_CSPI1_RDY__GPIO4_26 0x85
469 >;
470 };
471
472 pinctrl_clk26mhz_osc: clk26mhzoscgrp {
473 fsl,pins = <
474 MX51_PAD_DI1_PIN12__GPIO3_1 0x85
475 >;
476 };
477
478 pinctrl_clk26mhz_usb: clk26mhzusbgrp {
479 fsl,pins = <
480 MX51_PAD_EIM_D17__GPIO2_1 0x85
481 >;
482 };
483
484 pinctrl_ecspi1: ecspi1grp {
485 fsl,pins = <
486 MX51_PAD_CSPI1_MISO__ECSPI1_MISO 0x185
487 MX51_PAD_CSPI1_MOSI__ECSPI1_MOSI 0x185
488 MX51_PAD_CSPI1_SCLK__ECSPI1_SCLK 0x185
489 MX51_PAD_CSPI1_SS0__GPIO4_24 0x85 /* CS0 */
490 MX51_PAD_CSPI1_SS1__GPIO4_25 0x85 /* CS1 */
491 >;
492 };
493
494 pinctrl_esdhc1: esdhc1grp {
495 fsl,pins = <
496 MX51_PAD_SD1_CMD__SD1_CMD 0x400020d5
497 MX51_PAD_SD1_CLK__SD1_CLK 0x20d5
498 MX51_PAD_SD1_DATA0__SD1_DATA0 0x20d5
499 MX51_PAD_SD1_DATA1__SD1_DATA1 0x20d5
500 MX51_PAD_SD1_DATA2__SD1_DATA2 0x20d5
501 MX51_PAD_SD1_DATA3__SD1_DATA3 0x20d5
502 MX51_PAD_GPIO1_0__GPIO1_0 0x100
503 MX51_PAD_GPIO1_1__GPIO1_1 0x100
504 >;
505 };
506
507 pinctrl_esdhc2: esdhc2grp {
508 fsl,pins = <
509 MX51_PAD_SD2_CMD__SD2_CMD 0x400020d5
510 MX51_PAD_SD2_CLK__SD2_CLK 0x20d5
511 MX51_PAD_SD2_DATA0__SD2_DATA0 0x20d5
512 MX51_PAD_SD2_DATA1__SD2_DATA1 0x20d5
513 MX51_PAD_SD2_DATA2__SD2_DATA2 0x20d5
514 MX51_PAD_SD2_DATA3__SD2_DATA3 0x20d5
515 MX51_PAD_GPIO1_5__GPIO1_5 0x100 /* WP */
516 MX51_PAD_GPIO1_6__GPIO1_6 0x100 /* CD */
517 >;
518 };
519
520 pinctrl_fec: fecgrp {
521 fsl,pins = <
522 MX51_PAD_EIM_EB2__FEC_MDIO 0x000001f5
523 MX51_PAD_EIM_EB3__FEC_RDATA1 0x00000085
524 MX51_PAD_EIM_CS2__FEC_RDATA2 0x00000085
525 MX51_PAD_EIM_CS3__FEC_RDATA3 0x00000085
526 MX51_PAD_EIM_CS4__FEC_RX_ER 0x00000180
527 MX51_PAD_EIM_CS5__FEC_CRS 0x00000180
528 MX51_PAD_NANDF_RB2__FEC_COL 0x00000180
529 MX51_PAD_NANDF_RB3__FEC_RX_CLK 0x00000180
530 MX51_PAD_NANDF_D9__FEC_RDATA0 0x00002180
531 MX51_PAD_NANDF_D8__FEC_TDATA0 0x00002004
532 MX51_PAD_NANDF_CS2__FEC_TX_ER 0x00002004
533 MX51_PAD_NANDF_CS3__FEC_MDC 0x00002004
534 MX51_PAD_NANDF_CS4__FEC_TDATA1 0x00002004
535 MX51_PAD_NANDF_CS5__FEC_TDATA2 0x00002004
536 MX51_PAD_NANDF_CS6__FEC_TDATA3 0x00002004
537 MX51_PAD_NANDF_CS7__FEC_TX_EN 0x00002004
538 MX51_PAD_NANDF_RDY_INT__FEC_TX_CLK 0x00002180
539 MX51_PAD_NANDF_D11__FEC_RX_DV 0x000020a4
540 MX51_PAD_EIM_A20__GPIO2_14 0x00000085 /* Phy Reset */
541 >;
542 };
543
544 pinctrl_gpio_keys: gpiokeysgrp {
545 fsl,pins = <
546 MX51_PAD_EIM_A27__GPIO2_21 0x5
547 >;
548 };
549
550 pinctrl_gpio_leds: gpioledsgrp {
551 fsl,pins = <
552 MX51_PAD_EIM_D22__GPIO2_6 0x80000000
553 >;
554 };
555
556 pinctrl_i2c1: i2c1grp {
557 fsl,pins = <
558 MX51_PAD_EIM_D19__I2C1_SCL 0x400001ed
559 MX51_PAD_EIM_D16__I2C1_SDA 0x400001ed
560 >;
561 };
562
563 pinctrl_i2c2: i2c2grp {
564 fsl,pins = <
565 MX51_PAD_KEY_COL4__I2C2_SCL 0x400001ed
566 MX51_PAD_KEY_COL5__I2C2_SDA 0x400001ed
567 >;
568 };
569
570 pinctrl_ipu_disp1: ipudisp1grp {
571 fsl,pins = <
572 MX51_PAD_DISP1_DAT0__DISP1_DAT0 0x5
573 MX51_PAD_DISP1_DAT1__DISP1_DAT1 0x5
574 MX51_PAD_DISP1_DAT2__DISP1_DAT2 0x5
575 MX51_PAD_DISP1_DAT3__DISP1_DAT3 0x5
576 MX51_PAD_DISP1_DAT4__DISP1_DAT4 0x5
577 MX51_PAD_DISP1_DAT5__DISP1_DAT5 0x5
578 MX51_PAD_DISP1_DAT6__DISP1_DAT6 0x5
579 MX51_PAD_DISP1_DAT7__DISP1_DAT7 0x5
580 MX51_PAD_DISP1_DAT8__DISP1_DAT8 0x5
581 MX51_PAD_DISP1_DAT9__DISP1_DAT9 0x5
582 MX51_PAD_DISP1_DAT10__DISP1_DAT10 0x5
583 MX51_PAD_DISP1_DAT11__DISP1_DAT11 0x5
584 MX51_PAD_DISP1_DAT12__DISP1_DAT12 0x5
585 MX51_PAD_DISP1_DAT13__DISP1_DAT13 0x5
586 MX51_PAD_DISP1_DAT14__DISP1_DAT14 0x5
587 MX51_PAD_DISP1_DAT15__DISP1_DAT15 0x5
588 MX51_PAD_DISP1_DAT16__DISP1_DAT16 0x5
589 MX51_PAD_DISP1_DAT17__DISP1_DAT17 0x5
590 MX51_PAD_DISP1_DAT18__DISP1_DAT18 0x5
591 MX51_PAD_DISP1_DAT19__DISP1_DAT19 0x5
592 MX51_PAD_DISP1_DAT20__DISP1_DAT20 0x5
593 MX51_PAD_DISP1_DAT21__DISP1_DAT21 0x5
594 MX51_PAD_DISP1_DAT22__DISP1_DAT22 0x5
595 MX51_PAD_DISP1_DAT23__DISP1_DAT23 0x5
596 MX51_PAD_DI1_PIN2__DI1_PIN2 0x5
597 MX51_PAD_DI1_PIN3__DI1_PIN3 0x5
598 >;
599 };
600
601 pinctrl_ipu_disp2: ipudisp2grp {
602 fsl,pins = <
603 MX51_PAD_DISP2_DAT0__DISP2_DAT0 0x5
604 MX51_PAD_DISP2_DAT1__DISP2_DAT1 0x5
605 MX51_PAD_DISP2_DAT2__DISP2_DAT2 0x5
606 MX51_PAD_DISP2_DAT3__DISP2_DAT3 0x5
607 MX51_PAD_DISP2_DAT4__DISP2_DAT4 0x5
608 MX51_PAD_DISP2_DAT5__DISP2_DAT5 0x5
609 MX51_PAD_DISP2_DAT6__DISP2_DAT6 0x5
610 MX51_PAD_DISP2_DAT7__DISP2_DAT7 0x5
611 MX51_PAD_DISP2_DAT8__DISP2_DAT8 0x5
612 MX51_PAD_DISP2_DAT9__DISP2_DAT9 0x5
613 MX51_PAD_DISP2_DAT10__DISP2_DAT10 0x5
614 MX51_PAD_DISP2_DAT11__DISP2_DAT11 0x5
615 MX51_PAD_DISP2_DAT12__DISP2_DAT12 0x5
616 MX51_PAD_DISP2_DAT13__DISP2_DAT13 0x5
617 MX51_PAD_DISP2_DAT14__DISP2_DAT14 0x5
618 MX51_PAD_DISP2_DAT15__DISP2_DAT15 0x5
619 MX51_PAD_DI2_PIN2__DI2_PIN2 0x5
620 MX51_PAD_DI2_PIN3__DI2_PIN3 0x5
621 MX51_PAD_DI2_DISP_CLK__DI2_DISP_CLK 0x5
622 MX51_PAD_DI_GP4__DI2_PIN15 0x5
623 >;
624 };
625
626 pinctrl_kpp: kppgrp {
627 fsl,pins = <
628 MX51_PAD_KEY_ROW0__KEY_ROW0 0xe0
629 MX51_PAD_KEY_ROW1__KEY_ROW1 0xe0
630 MX51_PAD_KEY_ROW2__KEY_ROW2 0xe0
631 MX51_PAD_KEY_ROW3__KEY_ROW3 0xe0
632 MX51_PAD_KEY_COL0__KEY_COL0 0xe8
633 MX51_PAD_KEY_COL1__KEY_COL1 0xe8
634 MX51_PAD_KEY_COL2__KEY_COL2 0xe8
635 MX51_PAD_KEY_COL3__KEY_COL3 0xe8
636 >;
637 };
638
639 pinctrl_pmic: pmicgrp {
640 fsl,pins = <
641 MX51_PAD_GPIO1_8__GPIO1_8 0xe5 /* IRQ */
642 >;
643 };
644
645 pinctrl_uart1: uart1grp {
646 fsl,pins = <
647 MX51_PAD_UART1_RXD__UART1_RXD 0x1c5
648 MX51_PAD_UART1_TXD__UART1_TXD 0x1c5
649 MX51_PAD_UART1_RTS__UART1_RTS 0x1c5
650 MX51_PAD_UART1_CTS__UART1_CTS 0x1c5
651 >;
652 };
653
654 pinctrl_uart2: uart2grp {
655 fsl,pins = <
656 MX51_PAD_UART2_RXD__UART2_RXD 0x1c5
657 MX51_PAD_UART2_TXD__UART2_TXD 0x1c5
658 >;
659 };
660
661 pinctrl_uart3: uart3grp {
662 fsl,pins = <
663 MX51_PAD_EIM_D25__UART3_RXD 0x1c5
664 MX51_PAD_EIM_D26__UART3_TXD 0x1c5
665 MX51_PAD_EIM_D27__UART3_RTS 0x1c5
666 MX51_PAD_EIM_D24__UART3_CTS 0x1c5
667 >;
668 };
669
670 pinctrl_usbh1: usbh1grp {
671 fsl,pins = <
672 MX51_PAD_USBH1_CLK__USBH1_CLK 0x80000000
673 MX51_PAD_USBH1_DIR__USBH1_DIR 0x80000000
674 MX51_PAD_USBH1_NXT__USBH1_NXT 0x80000000
675 MX51_PAD_USBH1_DATA0__USBH1_DATA0 0x80000000
676 MX51_PAD_USBH1_DATA1__USBH1_DATA1 0x80000000
677 MX51_PAD_USBH1_DATA2__USBH1_DATA2 0x80000000
678 MX51_PAD_USBH1_DATA3__USBH1_DATA3 0x80000000
679 MX51_PAD_USBH1_DATA4__USBH1_DATA4 0x80000000
680 MX51_PAD_USBH1_DATA5__USBH1_DATA5 0x80000000
681 MX51_PAD_USBH1_DATA6__USBH1_DATA6 0x80000000
682 MX51_PAD_USBH1_DATA7__USBH1_DATA7 0x80000000
683 >;
684 };
685
686 pinctrl_usbh1reg: usbh1reggrp {
687 fsl,pins = <
688 MX51_PAD_EIM_D21__GPIO2_5 0x85
689 >;
690 };
691
692 pinctrl_usbotgreg: usbotgreggrp {
693 fsl,pins = <
694 MX51_PAD_GPIO1_7__GPIO1_7 0x85
695 >;
696 };
697 };
698};
1/*
2 * Copyright 2011 Freescale Semiconductor, Inc.
3 * Copyright 2011 Linaro Ltd.
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/dts-v1/;
14#include "imx51.dtsi"
15
16/ {
17 model = "Freescale i.MX51 Babbage Board";
18 compatible = "fsl,imx51-babbage", "fsl,imx51";
19
20 memory {
21 reg = <0x90000000 0x20000000>;
22 };
23
24 display0: display@di0 {
25 compatible = "fsl,imx-parallel-display";
26 interface-pix-fmt = "rgb24";
27 pinctrl-names = "default";
28 pinctrl-0 = <&pinctrl_ipu_disp1>;
29 display-timings {
30 native-mode = <&timing0>;
31 timing0: dvi {
32 clock-frequency = <65000000>;
33 hactive = <1024>;
34 vactive = <768>;
35 hback-porch = <220>;
36 hfront-porch = <40>;
37 vback-porch = <21>;
38 vfront-porch = <7>;
39 hsync-len = <60>;
40 vsync-len = <10>;
41 };
42 };
43
44 port {
45 display0_in: endpoint {
46 remote-endpoint = <&ipu_di0_disp0>;
47 };
48 };
49 };
50
51 display1: display@di1 {
52 compatible = "fsl,imx-parallel-display";
53 interface-pix-fmt = "rgb565";
54 pinctrl-names = "default";
55 pinctrl-0 = <&pinctrl_ipu_disp2>;
56 status = "disabled";
57 display-timings {
58 native-mode = <&timing1>;
59 timing1: claawvga {
60 clock-frequency = <27000000>;
61 hactive = <800>;
62 vactive = <480>;
63 hback-porch = <40>;
64 hfront-porch = <60>;
65 vback-porch = <10>;
66 vfront-porch = <10>;
67 hsync-len = <20>;
68 vsync-len = <10>;
69 hsync-active = <0>;
70 vsync-active = <0>;
71 de-active = <1>;
72 pixelclk-active = <0>;
73 };
74 };
75
76 port {
77 display1_in: endpoint {
78 remote-endpoint = <&ipu_di1_disp1>;
79 };
80 };
81 };
82
83 gpio-keys {
84 compatible = "gpio-keys";
85
86 power {
87 label = "Power Button";
88 gpios = <&gpio2 21 GPIO_ACTIVE_HIGH>;
89 linux,code = <116>; /* KEY_POWER */
90 gpio-key,wakeup;
91 };
92 };
93
94 leds {
95 compatible = "gpio-leds";
96 pinctrl-names = "default";
97 pinctrl-0 = <&pinctrl_gpio_leds>;
98
99 led-diagnostic {
100 label = "diagnostic";
101 gpios = <&gpio2 6 GPIO_ACTIVE_HIGH>;
102 };
103 };
104
105 sound {
106 compatible = "fsl,imx51-babbage-sgtl5000",
107 "fsl,imx-audio-sgtl5000";
108 model = "imx51-babbage-sgtl5000";
109 ssi-controller = <&ssi2>;
110 audio-codec = <&sgtl5000>;
111 audio-routing =
112 "MIC_IN", "Mic Jack",
113 "Mic Jack", "Mic Bias",
114 "Headphone Jack", "HP_OUT";
115 mux-int-port = <2>;
116 mux-ext-port = <3>;
117 };
118
119 clocks {
120 ckih1 {
121 clock-frequency = <22579200>;
122 };
123
124 clk_26M: codec_clock {
125 compatible = "fixed-clock";
126 reg=<0>;
127 #clock-cells = <0>;
128 clock-frequency = <26000000>;
129 gpios = <&gpio4 26 GPIO_ACTIVE_LOW>;
130 };
131 };
132};
133
134&esdhc1 {
135 pinctrl-names = "default";
136 pinctrl-0 = <&pinctrl_esdhc1>;
137 fsl,cd-controller;
138 fsl,wp-controller;
139 status = "okay";
140};
141
142&esdhc2 {
143 pinctrl-names = "default";
144 pinctrl-0 = <&pinctrl_esdhc2>;
145 cd-gpios = <&gpio1 6 GPIO_ACTIVE_HIGH>;
146 wp-gpios = <&gpio1 5 GPIO_ACTIVE_HIGH>;
147 status = "okay";
148};
149
150&uart3 {
151 pinctrl-names = "default";
152 pinctrl-0 = <&pinctrl_uart3>;
153 fsl,uart-has-rtscts;
154 status = "okay";
155};
156
157&ecspi1 {
158 pinctrl-names = "default";
159 pinctrl-0 = <&pinctrl_ecspi1>;
160 fsl,spi-num-chipselects = <2>;
161 cs-gpios = <&gpio4 24 GPIO_ACTIVE_HIGH>,
162 <&gpio4 25 GPIO_ACTIVE_LOW>;
163 status = "okay";
164
165 pmic: mc13892@0 {
166 #address-cells = <1>;
167 #size-cells = <0>;
168 compatible = "fsl,mc13892";
169 spi-max-frequency = <6000000>;
170 spi-cs-high;
171 reg = <0>;
172 interrupt-parent = <&gpio1>;
173 interrupts = <8 IRQ_TYPE_LEVEL_HIGH>;
174
175 regulators {
176 sw1_reg: sw1 {
177 regulator-min-microvolt = <600000>;
178 regulator-max-microvolt = <1375000>;
179 regulator-boot-on;
180 regulator-always-on;
181 };
182
183 sw2_reg: sw2 {
184 regulator-min-microvolt = <900000>;
185 regulator-max-microvolt = <1850000>;
186 regulator-boot-on;
187 regulator-always-on;
188 };
189
190 sw3_reg: sw3 {
191 regulator-min-microvolt = <1100000>;
192 regulator-max-microvolt = <1850000>;
193 regulator-boot-on;
194 regulator-always-on;
195 };
196
197 sw4_reg: sw4 {
198 regulator-min-microvolt = <1100000>;
199 regulator-max-microvolt = <1850000>;
200 regulator-boot-on;
201 regulator-always-on;
202 };
203
204 vpll_reg: vpll {
205 regulator-min-microvolt = <1050000>;
206 regulator-max-microvolt = <1800000>;
207 regulator-boot-on;
208 regulator-always-on;
209 };
210
211 vdig_reg: vdig {
212 regulator-min-microvolt = <1650000>;
213 regulator-max-microvolt = <1650000>;
214 regulator-boot-on;
215 };
216
217 vsd_reg: vsd {
218 regulator-min-microvolt = <1800000>;
219 regulator-max-microvolt = <3150000>;
220 };
221
222 vusb2_reg: vusb2 {
223 regulator-min-microvolt = <2400000>;
224 regulator-max-microvolt = <2775000>;
225 regulator-boot-on;
226 regulator-always-on;
227 };
228
229 vvideo_reg: vvideo {
230 regulator-min-microvolt = <2775000>;
231 regulator-max-microvolt = <2775000>;
232 };
233
234 vaudio_reg: vaudio {
235 regulator-min-microvolt = <2300000>;
236 regulator-max-microvolt = <3000000>;
237 };
238
239 vcam_reg: vcam {
240 regulator-min-microvolt = <2500000>;
241 regulator-max-microvolt = <3000000>;
242 };
243
244 vgen1_reg: vgen1 {
245 regulator-min-microvolt = <1200000>;
246 regulator-max-microvolt = <1200000>;
247 };
248
249 vgen2_reg: vgen2 {
250 regulator-min-microvolt = <1200000>;
251 regulator-max-microvolt = <3150000>;
252 regulator-always-on;
253 };
254
255 vgen3_reg: vgen3 {
256 regulator-min-microvolt = <1800000>;
257 regulator-max-microvolt = <2900000>;
258 regulator-always-on;
259 };
260 };
261 };
262
263 flash: at45db321d@1 {
264 #address-cells = <1>;
265 #size-cells = <1>;
266 compatible = "atmel,at45db321d", "atmel,at45", "atmel,dataflash";
267 spi-max-frequency = <25000000>;
268 reg = <1>;
269
270 partition@0 {
271 label = "U-Boot";
272 reg = <0x0 0x40000>;
273 read-only;
274 };
275
276 partition@40000 {
277 label = "Kernel";
278 reg = <0x40000 0x3c0000>;
279 };
280 };
281};
282
283&ipu_di0_disp0 {
284 remote-endpoint = <&display0_in>;
285};
286
287&ipu_di1_disp1 {
288 remote-endpoint = <&display1_in>;
289};
290
291&ssi2 {
292 fsl,mode = "i2s-slave";
293 status = "okay";
294};
295
296&iomuxc {
297 pinctrl-names = "default";
298 pinctrl-0 = <&pinctrl_hog>;
299
300 imx51-babbage {
301 pinctrl_hog: hoggrp {
302 fsl,pins = <
303 MX51_PAD_GPIO1_0__SD1_CD 0x20d5
304 MX51_PAD_GPIO1_1__SD1_WP 0x20d5
305 MX51_PAD_GPIO1_5__GPIO1_5 0x100
306 MX51_PAD_GPIO1_6__GPIO1_6 0x100
307 MX51_PAD_EIM_A27__GPIO2_21 0x5
308 MX51_PAD_CSPI1_SS0__GPIO4_24 0x85
309 MX51_PAD_CSPI1_SS1__GPIO4_25 0x85
310 MX51_PAD_CSPI1_RDY__GPIO4_26 0x80000000
311 >;
312 };
313
314 pinctrl_audmux: audmuxgrp {
315 fsl,pins = <
316 MX51_PAD_AUD3_BB_TXD__AUD3_TXD 0x80000000
317 MX51_PAD_AUD3_BB_RXD__AUD3_RXD 0x80000000
318 MX51_PAD_AUD3_BB_CK__AUD3_TXC 0x80000000
319 MX51_PAD_AUD3_BB_FS__AUD3_TXFS 0x80000000
320 >;
321 };
322
323 pinctrl_ecspi1: ecspi1grp {
324 fsl,pins = <
325 MX51_PAD_CSPI1_MISO__ECSPI1_MISO 0x185
326 MX51_PAD_CSPI1_MOSI__ECSPI1_MOSI 0x185
327 MX51_PAD_CSPI1_SCLK__ECSPI1_SCLK 0x185
328 >;
329 };
330
331 pinctrl_esdhc1: esdhc1grp {
332 fsl,pins = <
333 MX51_PAD_SD1_CMD__SD1_CMD 0x400020d5
334 MX51_PAD_SD1_CLK__SD1_CLK 0x20d5
335 MX51_PAD_SD1_DATA0__SD1_DATA0 0x20d5
336 MX51_PAD_SD1_DATA1__SD1_DATA1 0x20d5
337 MX51_PAD_SD1_DATA2__SD1_DATA2 0x20d5
338 MX51_PAD_SD1_DATA3__SD1_DATA3 0x20d5
339 >;
340 };
341
342 pinctrl_esdhc2: esdhc2grp {
343 fsl,pins = <
344 MX51_PAD_SD2_CMD__SD2_CMD 0x400020d5
345 MX51_PAD_SD2_CLK__SD2_CLK 0x20d5
346 MX51_PAD_SD2_DATA0__SD2_DATA0 0x20d5
347 MX51_PAD_SD2_DATA1__SD2_DATA1 0x20d5
348 MX51_PAD_SD2_DATA2__SD2_DATA2 0x20d5
349 MX51_PAD_SD2_DATA3__SD2_DATA3 0x20d5
350 >;
351 };
352
353 pinctrl_fec: fecgrp {
354 fsl,pins = <
355 MX51_PAD_EIM_EB2__FEC_MDIO 0x80000000
356 MX51_PAD_EIM_EB3__FEC_RDATA1 0x80000000
357 MX51_PAD_EIM_CS2__FEC_RDATA2 0x80000000
358 MX51_PAD_EIM_CS3__FEC_RDATA3 0x80000000
359 MX51_PAD_EIM_CS4__FEC_RX_ER 0x80000000
360 MX51_PAD_EIM_CS5__FEC_CRS 0x80000000
361 MX51_PAD_NANDF_RB2__FEC_COL 0x80000000
362 MX51_PAD_NANDF_RB3__FEC_RX_CLK 0x80000000
363 MX51_PAD_NANDF_D9__FEC_RDATA0 0x80000000
364 MX51_PAD_NANDF_D8__FEC_TDATA0 0x80000000
365 MX51_PAD_NANDF_CS2__FEC_TX_ER 0x80000000
366 MX51_PAD_NANDF_CS3__FEC_MDC 0x80000000
367 MX51_PAD_NANDF_CS4__FEC_TDATA1 0x80000000
368 MX51_PAD_NANDF_CS5__FEC_TDATA2 0x80000000
369 MX51_PAD_NANDF_CS6__FEC_TDATA3 0x80000000
370 MX51_PAD_NANDF_CS7__FEC_TX_EN 0x80000000
371 MX51_PAD_NANDF_RDY_INT__FEC_TX_CLK 0x80000000
372 MX51_PAD_EIM_A20__GPIO2_14 0x85 /* Reset */
373 >;
374 };
375
376 pinctrl_gpio_leds: gpioledsgrp {
377 fsl,pins = <
378 MX51_PAD_EIM_D22__GPIO2_6 0x80000000
379 >;
380 };
381
382 pinctrl_i2c2: i2c2grp {
383 fsl,pins = <
384 MX51_PAD_KEY_COL4__I2C2_SCL 0x400001ed
385 MX51_PAD_KEY_COL5__I2C2_SDA 0x400001ed
386 >;
387 };
388
389 pinctrl_ipu_disp1: ipudisp1grp {
390 fsl,pins = <
391 MX51_PAD_DISP1_DAT0__DISP1_DAT0 0x5
392 MX51_PAD_DISP1_DAT1__DISP1_DAT1 0x5
393 MX51_PAD_DISP1_DAT2__DISP1_DAT2 0x5
394 MX51_PAD_DISP1_DAT3__DISP1_DAT3 0x5
395 MX51_PAD_DISP1_DAT4__DISP1_DAT4 0x5
396 MX51_PAD_DISP1_DAT5__DISP1_DAT5 0x5
397 MX51_PAD_DISP1_DAT6__DISP1_DAT6 0x5
398 MX51_PAD_DISP1_DAT7__DISP1_DAT7 0x5
399 MX51_PAD_DISP1_DAT8__DISP1_DAT8 0x5
400 MX51_PAD_DISP1_DAT9__DISP1_DAT9 0x5
401 MX51_PAD_DISP1_DAT10__DISP1_DAT10 0x5
402 MX51_PAD_DISP1_DAT11__DISP1_DAT11 0x5
403 MX51_PAD_DISP1_DAT12__DISP1_DAT12 0x5
404 MX51_PAD_DISP1_DAT13__DISP1_DAT13 0x5
405 MX51_PAD_DISP1_DAT14__DISP1_DAT14 0x5
406 MX51_PAD_DISP1_DAT15__DISP1_DAT15 0x5
407 MX51_PAD_DISP1_DAT16__DISP1_DAT16 0x5
408 MX51_PAD_DISP1_DAT17__DISP1_DAT17 0x5
409 MX51_PAD_DISP1_DAT18__DISP1_DAT18 0x5
410 MX51_PAD_DISP1_DAT19__DISP1_DAT19 0x5
411 MX51_PAD_DISP1_DAT20__DISP1_DAT20 0x5
412 MX51_PAD_DISP1_DAT21__DISP1_DAT21 0x5
413 MX51_PAD_DISP1_DAT22__DISP1_DAT22 0x5
414 MX51_PAD_DISP1_DAT23__DISP1_DAT23 0x5
415 MX51_PAD_DI1_PIN2__DI1_PIN2 0x5
416 MX51_PAD_DI1_PIN3__DI1_PIN3 0x5
417 >;
418 };
419
420 pinctrl_ipu_disp2: ipudisp2grp {
421 fsl,pins = <
422 MX51_PAD_DISP2_DAT0__DISP2_DAT0 0x5
423 MX51_PAD_DISP2_DAT1__DISP2_DAT1 0x5
424 MX51_PAD_DISP2_DAT2__DISP2_DAT2 0x5
425 MX51_PAD_DISP2_DAT3__DISP2_DAT3 0x5
426 MX51_PAD_DISP2_DAT4__DISP2_DAT4 0x5
427 MX51_PAD_DISP2_DAT5__DISP2_DAT5 0x5
428 MX51_PAD_DISP2_DAT6__DISP2_DAT6 0x5
429 MX51_PAD_DISP2_DAT7__DISP2_DAT7 0x5
430 MX51_PAD_DISP2_DAT8__DISP2_DAT8 0x5
431 MX51_PAD_DISP2_DAT9__DISP2_DAT9 0x5
432 MX51_PAD_DISP2_DAT10__DISP2_DAT10 0x5
433 MX51_PAD_DISP2_DAT11__DISP2_DAT11 0x5
434 MX51_PAD_DISP2_DAT12__DISP2_DAT12 0x5
435 MX51_PAD_DISP2_DAT13__DISP2_DAT13 0x5
436 MX51_PAD_DISP2_DAT14__DISP2_DAT14 0x5
437 MX51_PAD_DISP2_DAT15__DISP2_DAT15 0x5
438 MX51_PAD_DI2_PIN2__DI2_PIN2 0x5
439 MX51_PAD_DI2_PIN3__DI2_PIN3 0x5
440 MX51_PAD_DI2_DISP_CLK__DI2_DISP_CLK 0x5
441 MX51_PAD_DI_GP4__DI2_PIN15 0x5
442 >;
443 };
444
445 pinctrl_kpp: kppgrp {
446 fsl,pins = <
447 MX51_PAD_KEY_ROW0__KEY_ROW0 0xe0
448 MX51_PAD_KEY_ROW1__KEY_ROW1 0xe0
449 MX51_PAD_KEY_ROW2__KEY_ROW2 0xe0
450 MX51_PAD_KEY_ROW3__KEY_ROW3 0xe0
451 MX51_PAD_KEY_COL0__KEY_COL0 0xe8
452 MX51_PAD_KEY_COL1__KEY_COL1 0xe8
453 MX51_PAD_KEY_COL2__KEY_COL2 0xe8
454 MX51_PAD_KEY_COL3__KEY_COL3 0xe8
455 >;
456 };
457
458 pinctrl_uart1: uart1grp {
459 fsl,pins = <
460 MX51_PAD_UART1_RXD__UART1_RXD 0x1c5
461 MX51_PAD_UART1_TXD__UART1_TXD 0x1c5
462 MX51_PAD_UART1_RTS__UART1_RTS 0x1c5
463 MX51_PAD_UART1_CTS__UART1_CTS 0x1c5
464 >;
465 };
466
467 pinctrl_uart2: uart2grp {
468 fsl,pins = <
469 MX51_PAD_UART2_RXD__UART2_RXD 0x1c5
470 MX51_PAD_UART2_TXD__UART2_TXD 0x1c5
471 >;
472 };
473
474 pinctrl_uart3: uart3grp {
475 fsl,pins = <
476 MX51_PAD_EIM_D25__UART3_RXD 0x1c5
477 MX51_PAD_EIM_D26__UART3_TXD 0x1c5
478 MX51_PAD_EIM_D27__UART3_RTS 0x1c5
479 MX51_PAD_EIM_D24__UART3_CTS 0x1c5
480 >;
481 };
482 };
483};
484
485&uart1 {
486 pinctrl-names = "default";
487 pinctrl-0 = <&pinctrl_uart1>;
488 fsl,uart-has-rtscts;
489 status = "okay";
490};
491
492&uart2 {
493 pinctrl-names = "default";
494 pinctrl-0 = <&pinctrl_uart2>;
495 status = "okay";
496};
497
498&i2c2 {
499 pinctrl-names = "default";
500 pinctrl-0 = <&pinctrl_i2c2>;
501 status = "okay";
502
503 sgtl5000: codec@0a {
504 compatible = "fsl,sgtl5000";
505 reg = <0x0a>;
506 clocks = <&clk_26M>;
507 VDDA-supply = <&vdig_reg>;
508 VDDIO-supply = <&vvideo_reg>;
509 };
510};
511
512&audmux {
513 pinctrl-names = "default";
514 pinctrl-0 = <&pinctrl_audmux>;
515 status = "okay";
516};
517
518&fec {
519 pinctrl-names = "default";
520 pinctrl-0 = <&pinctrl_fec>;
521 phy-mode = "mii";
522 phy-reset-gpios = <&gpio2 14 GPIO_ACTIVE_LOW>;
523 phy-reset-duration = <1>;
524 status = "okay";
525};
526
527&kpp {
528 pinctrl-names = "default";
529 pinctrl-0 = <&pinctrl_kpp>;
530 linux,keymap = <
531 MATRIX_KEY(0, 0, KEY_UP)
532 MATRIX_KEY(0, 1, KEY_DOWN)
533 MATRIX_KEY(0, 2, KEY_VOLUMEDOWN)
534 MATRIX_KEY(0, 3, KEY_HOME)
535 MATRIX_KEY(1, 0, KEY_RIGHT)
536 MATRIX_KEY(1, 1, KEY_LEFT)
537 MATRIX_KEY(1, 2, KEY_ENTER)
538 MATRIX_KEY(1, 3, KEY_VOLUMEUP)
539 MATRIX_KEY(2, 0, KEY_F6)
540 MATRIX_KEY(2, 1, KEY_F8)
541 MATRIX_KEY(2, 2, KEY_F9)
542 MATRIX_KEY(2, 3, KEY_F10)
543 MATRIX_KEY(3, 0, KEY_F1)
544 MATRIX_KEY(3, 1, KEY_F2)
545 MATRIX_KEY(3, 2, KEY_F3)
546 MATRIX_KEY(3, 3, KEY_POWER)
547 >;
548 status = "okay";
549};