2 * Copyright 2012 Freescale Semiconductor, Inc.
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:
8 * http://www.opensource.org/licenses/gpl-license.html
9 * http://www.gnu.org/copyleft/gpl.html
12 #include <dt-bindings/gpio/gpio.h>
13 #include "skeleton.dtsi"
14 #include "imx28-pinfunc.h"
17 interrupt-parent = <&icoll>;
45 compatible = "arm,arm926ej-s";
51 compatible = "simple-bus";
54 reg = <0x80000000 0x80000>;
58 compatible = "simple-bus";
61 reg = <0x80000000 0x3c900>;
64 icoll: interrupt-controller@80000000 {
65 compatible = "fsl,imx28-icoll", "fsl,icoll";
67 #interrupt-cells = <1>;
68 reg = <0x80000000 0x2000>;
71 hsadc: hsadc@80002000 {
72 reg = <0x80002000 0x2000>;
74 dmas = <&dma_apbh 12>;
79 dma_apbh: dma-apbh@80004000 {
80 compatible = "fsl,imx28-dma-apbh";
81 reg = <0x80004000 0x2000>;
82 interrupts = <82 83 84 85
86 interrupt-names = "ssp0", "ssp1", "ssp2", "ssp3",
87 "gpmi0", "gmpi1", "gpmi2", "gmpi3",
88 "gpmi4", "gmpi5", "gpmi6", "gmpi7",
89 "hsadc", "lcdif", "empty", "empty";
95 perfmon: perfmon@80006000 {
96 reg = <0x80006000 0x800>;
101 gpmi: gpmi-nand@8000c000 {
102 compatible = "fsl,imx28-gpmi-nand";
103 #address-cells = <1>;
105 reg = <0x8000c000 0x2000>, <0x8000a000 0x2000>;
106 reg-names = "gpmi-nand", "bch";
108 interrupt-names = "bch";
110 clock-names = "gpmi_io";
111 dmas = <&dma_apbh 4>;
117 #address-cells = <1>;
119 reg = <0x80010000 0x2000>;
122 dmas = <&dma_apbh 0>;
128 #address-cells = <1>;
130 reg = <0x80012000 0x2000>;
133 dmas = <&dma_apbh 1>;
139 #address-cells = <1>;
141 reg = <0x80014000 0x2000>;
144 dmas = <&dma_apbh 2>;
150 #address-cells = <1>;
152 reg = <0x80016000 0x2000>;
155 dmas = <&dma_apbh 3>;
160 pinctrl: pinctrl@80018000 {
161 #address-cells = <1>;
163 compatible = "fsl,imx28-pinctrl", "simple-bus";
164 reg = <0x80018000 0x2000>;
167 compatible = "fsl,imx28-gpio", "fsl,mxs-gpio";
171 interrupt-controller;
172 #interrupt-cells = <2>;
176 compatible = "fsl,imx28-gpio", "fsl,mxs-gpio";
180 interrupt-controller;
181 #interrupt-cells = <2>;
185 compatible = "fsl,imx28-gpio", "fsl,mxs-gpio";
189 interrupt-controller;
190 #interrupt-cells = <2>;
194 compatible = "fsl,imx28-gpio", "fsl,mxs-gpio";
198 interrupt-controller;
199 #interrupt-cells = <2>;
203 compatible = "fsl,imx28-gpio", "fsl,mxs-gpio";
207 interrupt-controller;
208 #interrupt-cells = <2>;
211 duart_pins_a: duart@0 {
214 MX28_PAD_PWM0__DUART_RX
215 MX28_PAD_PWM1__DUART_TX
217 fsl,drive-strength = <MXS_DRIVE_4mA>;
218 fsl,voltage = <MXS_VOLTAGE_HIGH>;
219 fsl,pull-up = <MXS_PULL_DISABLE>;
222 duart_pins_b: duart@1 {
225 MX28_PAD_AUART0_CTS__DUART_RX
226 MX28_PAD_AUART0_RTS__DUART_TX
228 fsl,drive-strength = <MXS_DRIVE_4mA>;
229 fsl,voltage = <MXS_VOLTAGE_HIGH>;
230 fsl,pull-up = <MXS_PULL_DISABLE>;
233 duart_4pins_a: duart-4pins@0 {
236 MX28_PAD_AUART0_CTS__DUART_RX
237 MX28_PAD_AUART0_RTS__DUART_TX
238 MX28_PAD_AUART0_RX__DUART_CTS
239 MX28_PAD_AUART0_TX__DUART_RTS
241 fsl,drive-strength = <MXS_DRIVE_4mA>;
242 fsl,voltage = <MXS_VOLTAGE_HIGH>;
243 fsl,pull-up = <MXS_PULL_DISABLE>;
246 gpmi_pins_a: gpmi-nand@0 {
249 MX28_PAD_GPMI_D00__GPMI_D0
250 MX28_PAD_GPMI_D01__GPMI_D1
251 MX28_PAD_GPMI_D02__GPMI_D2
252 MX28_PAD_GPMI_D03__GPMI_D3
253 MX28_PAD_GPMI_D04__GPMI_D4
254 MX28_PAD_GPMI_D05__GPMI_D5
255 MX28_PAD_GPMI_D06__GPMI_D6
256 MX28_PAD_GPMI_D07__GPMI_D7
257 MX28_PAD_GPMI_CE0N__GPMI_CE0N
258 MX28_PAD_GPMI_RDY0__GPMI_READY0
259 MX28_PAD_GPMI_RDN__GPMI_RDN
260 MX28_PAD_GPMI_WRN__GPMI_WRN
261 MX28_PAD_GPMI_ALE__GPMI_ALE
262 MX28_PAD_GPMI_CLE__GPMI_CLE
263 MX28_PAD_GPMI_RESETN__GPMI_RESETN
265 fsl,drive-strength = <MXS_DRIVE_4mA>;
266 fsl,voltage = <MXS_VOLTAGE_HIGH>;
267 fsl,pull-up = <MXS_PULL_DISABLE>;
270 gpmi_status_cfg: gpmi-status-cfg {
272 MX28_PAD_GPMI_RDN__GPMI_RDN
273 MX28_PAD_GPMI_WRN__GPMI_WRN
274 MX28_PAD_GPMI_RESETN__GPMI_RESETN
276 fsl,drive-strength = <MXS_DRIVE_12mA>;
279 auart0_pins_a: auart0@0 {
282 MX28_PAD_AUART0_RX__AUART0_RX
283 MX28_PAD_AUART0_TX__AUART0_TX
284 MX28_PAD_AUART0_CTS__AUART0_CTS
285 MX28_PAD_AUART0_RTS__AUART0_RTS
287 fsl,drive-strength = <MXS_DRIVE_4mA>;
288 fsl,voltage = <MXS_VOLTAGE_HIGH>;
289 fsl,pull-up = <MXS_PULL_DISABLE>;
292 auart0_2pins_a: auart0-2pins@0 {
295 MX28_PAD_AUART0_RX__AUART0_RX
296 MX28_PAD_AUART0_TX__AUART0_TX
298 fsl,drive-strength = <MXS_DRIVE_4mA>;
299 fsl,voltage = <MXS_VOLTAGE_HIGH>;
300 fsl,pull-up = <MXS_PULL_DISABLE>;
303 auart1_pins_a: auart1@0 {
306 MX28_PAD_AUART1_RX__AUART1_RX
307 MX28_PAD_AUART1_TX__AUART1_TX
308 MX28_PAD_AUART1_CTS__AUART1_CTS
309 MX28_PAD_AUART1_RTS__AUART1_RTS
311 fsl,drive-strength = <MXS_DRIVE_4mA>;
312 fsl,voltage = <MXS_VOLTAGE_HIGH>;
313 fsl,pull-up = <MXS_PULL_DISABLE>;
316 auart1_2pins_a: auart1-2pins@0 {
319 MX28_PAD_AUART1_RX__AUART1_RX
320 MX28_PAD_AUART1_TX__AUART1_TX
322 fsl,drive-strength = <MXS_DRIVE_4mA>;
323 fsl,voltage = <MXS_VOLTAGE_HIGH>;
324 fsl,pull-up = <MXS_PULL_DISABLE>;
327 auart2_2pins_a: auart2-2pins@0 {
330 MX28_PAD_SSP2_SCK__AUART2_RX
331 MX28_PAD_SSP2_MOSI__AUART2_TX
333 fsl,drive-strength = <MXS_DRIVE_4mA>;
334 fsl,voltage = <MXS_VOLTAGE_HIGH>;
335 fsl,pull-up = <MXS_PULL_DISABLE>;
338 auart2_2pins_b: auart2-2pins@1 {
341 MX28_PAD_AUART2_RX__AUART2_RX
342 MX28_PAD_AUART2_TX__AUART2_TX
344 fsl,drive-strength = <MXS_DRIVE_4mA>;
345 fsl,voltage = <MXS_VOLTAGE_HIGH>;
346 fsl,pull-up = <MXS_PULL_DISABLE>;
349 auart2_pins_a: auart2-pins@0 {
352 MX28_PAD_AUART2_RX__AUART2_RX
353 MX28_PAD_AUART2_TX__AUART2_TX
354 MX28_PAD_AUART2_CTS__AUART2_CTS
355 MX28_PAD_AUART2_RTS__AUART2_RTS
357 fsl,drive-strength = <MXS_DRIVE_4mA>;
358 fsl,voltage = <MXS_VOLTAGE_HIGH>;
359 fsl,pull-up = <MXS_PULL_DISABLE>;
362 auart3_pins_a: auart3@0 {
365 MX28_PAD_AUART3_RX__AUART3_RX
366 MX28_PAD_AUART3_TX__AUART3_TX
367 MX28_PAD_AUART3_CTS__AUART3_CTS
368 MX28_PAD_AUART3_RTS__AUART3_RTS
370 fsl,drive-strength = <MXS_DRIVE_4mA>;
371 fsl,voltage = <MXS_VOLTAGE_HIGH>;
372 fsl,pull-up = <MXS_PULL_DISABLE>;
375 auart3_2pins_a: auart3-2pins@0 {
378 MX28_PAD_SSP2_MISO__AUART3_RX
379 MX28_PAD_SSP2_SS0__AUART3_TX
381 fsl,drive-strength = <MXS_DRIVE_4mA>;
382 fsl,voltage = <MXS_VOLTAGE_HIGH>;
383 fsl,pull-up = <MXS_PULL_DISABLE>;
386 auart3_2pins_b: auart3-2pins@1 {
389 MX28_PAD_AUART3_RX__AUART3_RX
390 MX28_PAD_AUART3_TX__AUART3_TX
392 fsl,drive-strength = <MXS_DRIVE_4mA>;
393 fsl,voltage = <MXS_VOLTAGE_HIGH>;
394 fsl,pull-up = <MXS_PULL_DISABLE>;
397 auart4_2pins_a: auart4@0 {
400 MX28_PAD_SSP3_SCK__AUART4_TX
401 MX28_PAD_SSP3_MOSI__AUART4_RX
403 fsl,drive-strength = <MXS_DRIVE_4mA>;
404 fsl,voltage = <MXS_VOLTAGE_HIGH>;
405 fsl,pull-up = <MXS_PULL_DISABLE>;
408 mac0_pins_a: mac0@0 {
411 MX28_PAD_ENET0_MDC__ENET0_MDC
412 MX28_PAD_ENET0_MDIO__ENET0_MDIO
413 MX28_PAD_ENET0_RX_EN__ENET0_RX_EN
414 MX28_PAD_ENET0_RXD0__ENET0_RXD0
415 MX28_PAD_ENET0_RXD1__ENET0_RXD1
416 MX28_PAD_ENET0_TX_EN__ENET0_TX_EN
417 MX28_PAD_ENET0_TXD0__ENET0_TXD0
418 MX28_PAD_ENET0_TXD1__ENET0_TXD1
419 MX28_PAD_ENET_CLK__CLKCTRL_ENET
421 fsl,drive-strength = <MXS_DRIVE_8mA>;
422 fsl,voltage = <MXS_VOLTAGE_HIGH>;
423 fsl,pull-up = <MXS_PULL_ENABLE>;
426 mac1_pins_a: mac1@0 {
429 MX28_PAD_ENET0_CRS__ENET1_RX_EN
430 MX28_PAD_ENET0_RXD2__ENET1_RXD0
431 MX28_PAD_ENET0_RXD3__ENET1_RXD1
432 MX28_PAD_ENET0_COL__ENET1_TX_EN
433 MX28_PAD_ENET0_TXD2__ENET1_TXD0
434 MX28_PAD_ENET0_TXD3__ENET1_TXD1
436 fsl,drive-strength = <MXS_DRIVE_8mA>;
437 fsl,voltage = <MXS_VOLTAGE_HIGH>;
438 fsl,pull-up = <MXS_PULL_ENABLE>;
441 mmc0_8bit_pins_a: mmc0-8bit@0 {
444 MX28_PAD_SSP0_DATA0__SSP0_D0
445 MX28_PAD_SSP0_DATA1__SSP0_D1
446 MX28_PAD_SSP0_DATA2__SSP0_D2
447 MX28_PAD_SSP0_DATA3__SSP0_D3
448 MX28_PAD_SSP0_DATA4__SSP0_D4
449 MX28_PAD_SSP0_DATA5__SSP0_D5
450 MX28_PAD_SSP0_DATA6__SSP0_D6
451 MX28_PAD_SSP0_DATA7__SSP0_D7
452 MX28_PAD_SSP0_CMD__SSP0_CMD
453 MX28_PAD_SSP0_DETECT__SSP0_CARD_DETECT
454 MX28_PAD_SSP0_SCK__SSP0_SCK
456 fsl,drive-strength = <MXS_DRIVE_8mA>;
457 fsl,voltage = <MXS_VOLTAGE_HIGH>;
458 fsl,pull-up = <MXS_PULL_ENABLE>;
461 mmc0_4bit_pins_a: mmc0-4bit@0 {
464 MX28_PAD_SSP0_DATA0__SSP0_D0
465 MX28_PAD_SSP0_DATA1__SSP0_D1
466 MX28_PAD_SSP0_DATA2__SSP0_D2
467 MX28_PAD_SSP0_DATA3__SSP0_D3
468 MX28_PAD_SSP0_CMD__SSP0_CMD
469 MX28_PAD_SSP0_DETECT__SSP0_CARD_DETECT
470 MX28_PAD_SSP0_SCK__SSP0_SCK
472 fsl,drive-strength = <MXS_DRIVE_8mA>;
473 fsl,voltage = <MXS_VOLTAGE_HIGH>;
474 fsl,pull-up = <MXS_PULL_ENABLE>;
477 mmc0_cd_cfg: mmc0-cd-cfg {
479 MX28_PAD_SSP0_DETECT__SSP0_CARD_DETECT
481 fsl,pull-up = <MXS_PULL_DISABLE>;
484 mmc0_sck_cfg: mmc0-sck-cfg {
486 MX28_PAD_SSP0_SCK__SSP0_SCK
488 fsl,drive-strength = <MXS_DRIVE_12mA>;
489 fsl,pull-up = <MXS_PULL_DISABLE>;
492 mmc1_4bit_pins_a: mmc1-4bit@0 {
495 MX28_PAD_GPMI_D00__SSP1_D0
496 MX28_PAD_GPMI_D01__SSP1_D1
497 MX28_PAD_GPMI_D02__SSP1_D2
498 MX28_PAD_GPMI_D03__SSP1_D3
499 MX28_PAD_GPMI_RDY1__SSP1_CMD
500 MX28_PAD_GPMI_RDY0__SSP1_CARD_DETECT
501 MX28_PAD_GPMI_WRN__SSP1_SCK
503 fsl,drive-strength = <MXS_DRIVE_8mA>;
504 fsl,voltage = <MXS_VOLTAGE_HIGH>;
505 fsl,pull-up = <MXS_PULL_ENABLE>;
508 mmc1_cd_cfg: mmc1-cd-cfg {
510 MX28_PAD_GPMI_RDY0__SSP1_CARD_DETECT
512 fsl,pull-up = <MXS_PULL_DISABLE>;
515 mmc1_sck_cfg: mmc1-sck-cfg {
517 MX28_PAD_GPMI_WRN__SSP1_SCK
519 fsl,drive-strength = <MXS_DRIVE_12mA>;
520 fsl,pull-up = <MXS_PULL_DISABLE>;
524 mmc2_4bit_pins_a: mmc2-4bit@0 {
527 MX28_PAD_SSP0_DATA4__SSP2_D0
528 MX28_PAD_SSP1_SCK__SSP2_D1
529 MX28_PAD_SSP1_CMD__SSP2_D2
530 MX28_PAD_SSP0_DATA5__SSP2_D3
531 MX28_PAD_SSP0_DATA6__SSP2_CMD
532 MX28_PAD_AUART1_RX__SSP2_CARD_DETECT
533 MX28_PAD_SSP0_DATA7__SSP2_SCK
535 fsl,drive-strength = <MXS_DRIVE_8mA>;
536 fsl,voltage = <MXS_VOLTAGE_HIGH>;
537 fsl,pull-up = <MXS_PULL_ENABLE>;
540 mmc2_cd_cfg: mmc2-cd-cfg {
542 MX28_PAD_AUART1_RX__SSP2_CARD_DETECT
544 fsl,pull-up = <MXS_PULL_DISABLE>;
547 mmc2_sck_cfg: mmc2-sck-cfg {
549 MX28_PAD_SSP0_DATA7__SSP2_SCK
551 fsl,drive-strength = <MXS_DRIVE_12mA>;
552 fsl,pull-up = <MXS_PULL_DISABLE>;
555 i2c0_pins_a: i2c0@0 {
558 MX28_PAD_I2C0_SCL__I2C0_SCL
559 MX28_PAD_I2C0_SDA__I2C0_SDA
561 fsl,drive-strength = <MXS_DRIVE_8mA>;
562 fsl,voltage = <MXS_VOLTAGE_HIGH>;
563 fsl,pull-up = <MXS_PULL_ENABLE>;
566 i2c0_pins_b: i2c0@1 {
569 MX28_PAD_AUART0_RX__I2C0_SCL
570 MX28_PAD_AUART0_TX__I2C0_SDA
572 fsl,drive-strength = <MXS_DRIVE_8mA>;
573 fsl,voltage = <MXS_VOLTAGE_HIGH>;
574 fsl,pull-up = <MXS_PULL_ENABLE>;
577 i2c1_pins_a: i2c1@0 {
580 MX28_PAD_PWM0__I2C1_SCL
581 MX28_PAD_PWM1__I2C1_SDA
583 fsl,drive-strength = <MXS_DRIVE_8mA>;
584 fsl,voltage = <MXS_VOLTAGE_HIGH>;
585 fsl,pull-up = <MXS_PULL_ENABLE>;
588 i2c1_pins_b: i2c1@1 {
591 MX28_PAD_AUART2_CTS__I2C1_SCL
592 MX28_PAD_AUART2_RTS__I2C1_SDA
594 fsl,drive-strength = <MXS_DRIVE_8mA>;
595 fsl,voltage = <MXS_VOLTAGE_HIGH>;
596 fsl,pull-up = <MXS_PULL_ENABLE>;
599 saif0_pins_a: saif0@0 {
602 MX28_PAD_SAIF0_MCLK__SAIF0_MCLK
603 MX28_PAD_SAIF0_LRCLK__SAIF0_LRCLK
604 MX28_PAD_SAIF0_BITCLK__SAIF0_BITCLK
605 MX28_PAD_SAIF0_SDATA0__SAIF0_SDATA0
607 fsl,drive-strength = <MXS_DRIVE_12mA>;
608 fsl,voltage = <MXS_VOLTAGE_HIGH>;
609 fsl,pull-up = <MXS_PULL_ENABLE>;
612 saif0_pins_b: saif0@1 {
615 MX28_PAD_SAIF0_LRCLK__SAIF0_LRCLK
616 MX28_PAD_SAIF0_BITCLK__SAIF0_BITCLK
617 MX28_PAD_SAIF0_SDATA0__SAIF0_SDATA0
619 fsl,drive-strength = <MXS_DRIVE_12mA>;
620 fsl,voltage = <MXS_VOLTAGE_HIGH>;
621 fsl,pull-up = <MXS_PULL_ENABLE>;
624 saif1_pins_a: saif1@0 {
627 MX28_PAD_SAIF1_SDATA0__SAIF1_SDATA0
629 fsl,drive-strength = <MXS_DRIVE_12mA>;
630 fsl,voltage = <MXS_VOLTAGE_HIGH>;
631 fsl,pull-up = <MXS_PULL_ENABLE>;
634 pwm0_pins_a: pwm0@0 {
639 fsl,drive-strength = <MXS_DRIVE_4mA>;
640 fsl,voltage = <MXS_VOLTAGE_HIGH>;
641 fsl,pull-up = <MXS_PULL_DISABLE>;
644 pwm2_pins_a: pwm2@0 {
649 fsl,drive-strength = <MXS_DRIVE_4mA>;
650 fsl,voltage = <MXS_VOLTAGE_HIGH>;
651 fsl,pull-up = <MXS_PULL_DISABLE>;
654 pwm3_pins_a: pwm3@0 {
659 fsl,drive-strength = <MXS_DRIVE_4mA>;
660 fsl,voltage = <MXS_VOLTAGE_HIGH>;
661 fsl,pull-up = <MXS_PULL_DISABLE>;
664 pwm3_pins_b: pwm3@1 {
667 MX28_PAD_SAIF0_MCLK__PWM_3
669 fsl,drive-strength = <MXS_DRIVE_4mA>;
670 fsl,voltage = <MXS_VOLTAGE_HIGH>;
671 fsl,pull-up = <MXS_PULL_DISABLE>;
674 pwm4_pins_a: pwm4@0 {
679 fsl,drive-strength = <MXS_DRIVE_4mA>;
680 fsl,voltage = <MXS_VOLTAGE_HIGH>;
681 fsl,pull-up = <MXS_PULL_DISABLE>;
684 lcdif_24bit_pins_a: lcdif-24bit@0 {
687 MX28_PAD_LCD_D00__LCD_D0
688 MX28_PAD_LCD_D01__LCD_D1
689 MX28_PAD_LCD_D02__LCD_D2
690 MX28_PAD_LCD_D03__LCD_D3
691 MX28_PAD_LCD_D04__LCD_D4
692 MX28_PAD_LCD_D05__LCD_D5
693 MX28_PAD_LCD_D06__LCD_D6
694 MX28_PAD_LCD_D07__LCD_D7
695 MX28_PAD_LCD_D08__LCD_D8
696 MX28_PAD_LCD_D09__LCD_D9
697 MX28_PAD_LCD_D10__LCD_D10
698 MX28_PAD_LCD_D11__LCD_D11
699 MX28_PAD_LCD_D12__LCD_D12
700 MX28_PAD_LCD_D13__LCD_D13
701 MX28_PAD_LCD_D14__LCD_D14
702 MX28_PAD_LCD_D15__LCD_D15
703 MX28_PAD_LCD_D16__LCD_D16
704 MX28_PAD_LCD_D17__LCD_D17
705 MX28_PAD_LCD_D18__LCD_D18
706 MX28_PAD_LCD_D19__LCD_D19
707 MX28_PAD_LCD_D20__LCD_D20
708 MX28_PAD_LCD_D21__LCD_D21
709 MX28_PAD_LCD_D22__LCD_D22
710 MX28_PAD_LCD_D23__LCD_D23
712 fsl,drive-strength = <MXS_DRIVE_4mA>;
713 fsl,voltage = <MXS_VOLTAGE_HIGH>;
714 fsl,pull-up = <MXS_PULL_DISABLE>;
717 lcdif_18bit_pins_a: lcdif-18bit@0 {
720 MX28_PAD_LCD_D00__LCD_D0
721 MX28_PAD_LCD_D01__LCD_D1
722 MX28_PAD_LCD_D02__LCD_D2
723 MX28_PAD_LCD_D03__LCD_D3
724 MX28_PAD_LCD_D04__LCD_D4
725 MX28_PAD_LCD_D05__LCD_D5
726 MX28_PAD_LCD_D06__LCD_D6
727 MX28_PAD_LCD_D07__LCD_D7
728 MX28_PAD_LCD_D08__LCD_D8
729 MX28_PAD_LCD_D09__LCD_D9
730 MX28_PAD_LCD_D10__LCD_D10
731 MX28_PAD_LCD_D11__LCD_D11
732 MX28_PAD_LCD_D12__LCD_D12
733 MX28_PAD_LCD_D13__LCD_D13
734 MX28_PAD_LCD_D14__LCD_D14
735 MX28_PAD_LCD_D15__LCD_D15
736 MX28_PAD_LCD_D16__LCD_D16
737 MX28_PAD_LCD_D17__LCD_D17
739 fsl,drive-strength = <MXS_DRIVE_4mA>;
740 fsl,voltage = <MXS_VOLTAGE_HIGH>;
741 fsl,pull-up = <MXS_PULL_DISABLE>;
744 lcdif_16bit_pins_a: lcdif-16bit@0 {
747 MX28_PAD_LCD_D00__LCD_D0
748 MX28_PAD_LCD_D01__LCD_D1
749 MX28_PAD_LCD_D02__LCD_D2
750 MX28_PAD_LCD_D03__LCD_D3
751 MX28_PAD_LCD_D04__LCD_D4
752 MX28_PAD_LCD_D05__LCD_D5
753 MX28_PAD_LCD_D06__LCD_D6
754 MX28_PAD_LCD_D07__LCD_D7
755 MX28_PAD_LCD_D08__LCD_D8
756 MX28_PAD_LCD_D09__LCD_D9
757 MX28_PAD_LCD_D10__LCD_D10
758 MX28_PAD_LCD_D11__LCD_D11
759 MX28_PAD_LCD_D12__LCD_D12
760 MX28_PAD_LCD_D13__LCD_D13
761 MX28_PAD_LCD_D14__LCD_D14
762 MX28_PAD_LCD_D15__LCD_D15
764 fsl,drive-strength = <MXS_DRIVE_4mA>;
765 fsl,voltage = <MXS_VOLTAGE_HIGH>;
766 fsl,pull-up = <MXS_PULL_DISABLE>;
769 lcdif_sync_pins_a: lcdif-sync@0 {
772 MX28_PAD_LCD_RS__LCD_DOTCLK
773 MX28_PAD_LCD_CS__LCD_ENABLE
774 MX28_PAD_LCD_RD_E__LCD_VSYNC
775 MX28_PAD_LCD_WR_RWN__LCD_HSYNC
777 fsl,drive-strength = <MXS_DRIVE_4mA>;
778 fsl,voltage = <MXS_VOLTAGE_HIGH>;
779 fsl,pull-up = <MXS_PULL_DISABLE>;
782 can0_pins_a: can0@0 {
785 MX28_PAD_GPMI_RDY2__CAN0_TX
786 MX28_PAD_GPMI_RDY3__CAN0_RX
788 fsl,drive-strength = <MXS_DRIVE_4mA>;
789 fsl,voltage = <MXS_VOLTAGE_HIGH>;
790 fsl,pull-up = <MXS_PULL_DISABLE>;
793 can1_pins_a: can1@0 {
796 MX28_PAD_GPMI_CE2N__CAN1_TX
797 MX28_PAD_GPMI_CE3N__CAN1_RX
799 fsl,drive-strength = <MXS_DRIVE_4mA>;
800 fsl,voltage = <MXS_VOLTAGE_HIGH>;
801 fsl,pull-up = <MXS_PULL_DISABLE>;
804 spi2_pins_a: spi2@0 {
807 MX28_PAD_SSP2_SCK__SSP2_SCK
808 MX28_PAD_SSP2_MOSI__SSP2_CMD
809 MX28_PAD_SSP2_MISO__SSP2_D0
810 MX28_PAD_SSP2_SS0__SSP2_D3
812 fsl,drive-strength = <MXS_DRIVE_8mA>;
813 fsl,voltage = <MXS_VOLTAGE_HIGH>;
814 fsl,pull-up = <MXS_PULL_ENABLE>;
817 spi3_pins_a: spi3@0 {
820 MX28_PAD_AUART2_RX__SSP3_D4
821 MX28_PAD_AUART2_TX__SSP3_D5
822 MX28_PAD_SSP3_SCK__SSP3_SCK
823 MX28_PAD_SSP3_MOSI__SSP3_CMD
824 MX28_PAD_SSP3_MISO__SSP3_D0
825 MX28_PAD_SSP3_SS0__SSP3_D3
827 fsl,drive-strength = <MXS_DRIVE_8mA>;
828 fsl,voltage = <MXS_VOLTAGE_HIGH>;
829 fsl,pull-up = <MXS_PULL_DISABLE>;
832 spi3_pins_b: spi3@1 {
835 MX28_PAD_SSP3_SCK__SSP3_SCK
836 MX28_PAD_SSP3_MOSI__SSP3_CMD
837 MX28_PAD_SSP3_MISO__SSP3_D0
838 MX28_PAD_SSP3_SS0__SSP3_D3
840 fsl,drive-strength = <MXS_DRIVE_8mA>;
841 fsl,voltage = <MXS_VOLTAGE_HIGH>;
842 fsl,pull-up = <MXS_PULL_ENABLE>;
845 usb0_pins_a: usb0@0 {
848 MX28_PAD_SSP2_SS2__USB0_OVERCURRENT
850 fsl,drive-strength = <MXS_DRIVE_12mA>;
851 fsl,voltage = <MXS_VOLTAGE_HIGH>;
852 fsl,pull-up = <MXS_PULL_DISABLE>;
855 usb0_pins_b: usb0@1 {
858 MX28_PAD_AUART1_CTS__USB0_OVERCURRENT
860 fsl,drive-strength = <MXS_DRIVE_12mA>;
861 fsl,voltage = <MXS_VOLTAGE_HIGH>;
862 fsl,pull-up = <MXS_PULL_DISABLE>;
865 usb1_pins_a: usb1@0 {
868 MX28_PAD_SSP2_SS1__USB1_OVERCURRENT
870 fsl,drive-strength = <MXS_DRIVE_12mA>;
871 fsl,voltage = <MXS_VOLTAGE_HIGH>;
872 fsl,pull-up = <MXS_PULL_DISABLE>;
875 usb0_id_pins_a: usb0id@0 {
878 MX28_PAD_AUART1_RTS__USB0_ID
880 fsl,drive-strength = <MXS_DRIVE_12mA>;
881 fsl,voltage = <MXS_VOLTAGE_HIGH>;
882 fsl,pull-up = <MXS_PULL_ENABLE>;
885 usb0_id_pins_b: usb0id1@0 {
888 MX28_PAD_PWM2__USB0_ID
890 fsl,drive-strength = <MXS_DRIVE_12mA>;
891 fsl,voltage = <MXS_VOLTAGE_HIGH>;
892 fsl,pull-up = <MXS_PULL_ENABLE>;
897 digctl: digctl@8001c000 {
898 compatible = "fsl,imx28-digctl", "fsl,imx23-digctl";
899 reg = <0x8001c000 0x2000>;
905 reg = <0x80022000 0x2000>;
909 dma_apbx: dma-apbx@80024000 {
910 compatible = "fsl,imx28-dma-apbx";
911 reg = <0x80024000 0x2000>;
912 interrupts = <78 79 66 0
916 interrupt-names = "auart4-rx", "auart4-tx", "spdif-tx", "empty",
917 "saif0", "saif1", "i2c0", "i2c1",
918 "auart0-rx", "auart0-tx", "auart1-rx", "auart1-tx",
919 "auart2-rx", "auart2-tx", "auart3-rx", "auart3-tx";
926 compatible = "fsl,imx28-dcp", "fsl,imx23-dcp";
927 reg = <0x80028000 0x2000>;
928 interrupts = <52 53 54>;
933 reg = <0x8002a000 0x2000>;
938 ocotp: ocotp@8002c000 {
939 compatible = "fsl,ocotp";
940 reg = <0x8002c000 0x2000>;
945 reg = <0x8002e000 0x2000>;
949 lcdif: lcdif@80030000 {
950 compatible = "fsl,imx28-lcdif";
951 reg = <0x80030000 0x2000>;
954 dmas = <&dma_apbh 13>;
960 compatible = "fsl,imx28-flexcan", "fsl,p1010-flexcan";
961 reg = <0x80032000 0x2000>;
963 clocks = <&clks 58>, <&clks 58>;
964 clock-names = "ipg", "per";
969 compatible = "fsl,imx28-flexcan", "fsl,p1010-flexcan";
970 reg = <0x80034000 0x2000>;
972 clocks = <&clks 59>, <&clks 59>;
973 clock-names = "ipg", "per";
977 simdbg: simdbg@8003c000 {
978 reg = <0x8003c000 0x200>;
982 simgpmisel: simgpmisel@8003c200 {
983 reg = <0x8003c200 0x100>;
987 simsspsel: simsspsel@8003c300 {
988 reg = <0x8003c300 0x100>;
992 simmemsel: simmemsel@8003c400 {
993 reg = <0x8003c400 0x100>;
997 gpiomon: gpiomon@8003c500 {
998 reg = <0x8003c500 0x100>;
1002 simenet: simenet@8003c700 {
1003 reg = <0x8003c700 0x100>;
1004 status = "disabled";
1007 armjtag: armjtag@8003c800 {
1008 reg = <0x8003c800 0x100>;
1009 status = "disabled";
1014 compatible = "simple-bus";
1015 #address-cells = <1>;
1017 reg = <0x80040000 0x40000>;
1020 clks: clkctrl@80040000 {
1021 compatible = "fsl,imx28-clkctrl", "fsl,clkctrl";
1022 reg = <0x80040000 0x2000>;
1026 saif0: saif@80042000 {
1027 compatible = "fsl,imx28-saif";
1028 reg = <0x80042000 0x2000>;
1031 clocks = <&clks 53>;
1032 dmas = <&dma_apbx 4>;
1033 dma-names = "rx-tx";
1034 status = "disabled";
1037 power: power@80044000 {
1038 reg = <0x80044000 0x2000>;
1039 status = "disabled";
1042 saif1: saif@80046000 {
1043 compatible = "fsl,imx28-saif";
1044 reg = <0x80046000 0x2000>;
1046 clocks = <&clks 54>;
1047 dmas = <&dma_apbx 5>;
1048 dma-names = "rx-tx";
1049 status = "disabled";
1052 lradc: lradc@80050000 {
1053 compatible = "fsl,imx28-lradc";
1054 reg = <0x80050000 0x2000>;
1055 interrupts = <10 14 15 16 17 18 19
1057 status = "disabled";
1058 clocks = <&clks 41>;
1059 #io-channel-cells = <1>;
1062 spdif: spdif@80054000 {
1063 reg = <0x80054000 0x2000>;
1065 dmas = <&dma_apbx 2>;
1067 status = "disabled";
1070 mxs_rtc: rtc@80056000 {
1071 compatible = "fsl,imx28-rtc", "fsl,stmp3xxx-rtc";
1072 reg = <0x80056000 0x2000>;
1076 i2c0: i2c@80058000 {
1077 #address-cells = <1>;
1079 compatible = "fsl,imx28-i2c";
1080 reg = <0x80058000 0x2000>;
1082 clock-frequency = <100000>;
1083 dmas = <&dma_apbx 6>;
1084 dma-names = "rx-tx";
1085 status = "disabled";
1088 i2c1: i2c@8005a000 {
1089 #address-cells = <1>;
1091 compatible = "fsl,imx28-i2c";
1092 reg = <0x8005a000 0x2000>;
1094 clock-frequency = <100000>;
1095 dmas = <&dma_apbx 7>;
1096 dma-names = "rx-tx";
1097 status = "disabled";
1101 compatible = "fsl,imx28-pwm", "fsl,imx23-pwm";
1102 reg = <0x80064000 0x2000>;
1103 clocks = <&clks 44>;
1105 fsl,pwm-number = <8>;
1106 status = "disabled";
1109 timer: timrot@80068000 {
1110 compatible = "fsl,imx28-timrot", "fsl,timrot";
1111 reg = <0x80068000 0x2000>;
1112 interrupts = <48 49 50 51>;
1113 clocks = <&clks 26>;
1116 auart0: serial@8006a000 {
1117 compatible = "fsl,imx28-auart", "fsl,imx23-auart";
1118 reg = <0x8006a000 0x2000>;
1120 dmas = <&dma_apbx 8>, <&dma_apbx 9>;
1121 dma-names = "rx", "tx";
1122 clocks = <&clks 45>;
1123 status = "disabled";
1126 auart1: serial@8006c000 {
1127 compatible = "fsl,imx28-auart", "fsl,imx23-auart";
1128 reg = <0x8006c000 0x2000>;
1130 dmas = <&dma_apbx 10>, <&dma_apbx 11>;
1131 dma-names = "rx", "tx";
1132 clocks = <&clks 45>;
1133 status = "disabled";
1136 auart2: serial@8006e000 {
1137 compatible = "fsl,imx28-auart", "fsl,imx23-auart";
1138 reg = <0x8006e000 0x2000>;
1140 dmas = <&dma_apbx 12>, <&dma_apbx 13>;
1141 dma-names = "rx", "tx";
1142 clocks = <&clks 45>;
1143 status = "disabled";
1146 auart3: serial@80070000 {
1147 compatible = "fsl,imx28-auart", "fsl,imx23-auart";
1148 reg = <0x80070000 0x2000>;
1150 dmas = <&dma_apbx 14>, <&dma_apbx 15>;
1151 dma-names = "rx", "tx";
1152 clocks = <&clks 45>;
1153 status = "disabled";
1156 auart4: serial@80072000 {
1157 compatible = "fsl,imx28-auart", "fsl,imx23-auart";
1158 reg = <0x80072000 0x2000>;
1160 dmas = <&dma_apbx 0>, <&dma_apbx 1>;
1161 dma-names = "rx", "tx";
1162 clocks = <&clks 45>;
1163 status = "disabled";
1166 duart: serial@80074000 {
1167 compatible = "arm,pl011", "arm,primecell";
1168 reg = <0x80074000 0x1000>;
1170 clocks = <&clks 45>, <&clks 26>;
1171 clock-names = "uart", "apb_pclk";
1172 status = "disabled";
1175 usbphy0: usbphy@8007c000 {
1176 compatible = "fsl,imx28-usbphy", "fsl,imx23-usbphy";
1177 reg = <0x8007c000 0x2000>;
1178 clocks = <&clks 62>;
1179 status = "disabled";
1182 usbphy1: usbphy@8007e000 {
1183 compatible = "fsl,imx28-usbphy", "fsl,imx23-usbphy";
1184 reg = <0x8007e000 0x2000>;
1185 clocks = <&clks 63>;
1186 status = "disabled";
1192 compatible = "simple-bus";
1193 #address-cells = <1>;
1195 reg = <0x80080000 0x80000>;
1198 usb0: usb@80080000 {
1199 compatible = "fsl,imx28-usb", "fsl,imx27-usb";
1200 reg = <0x80080000 0x10000>;
1202 clocks = <&clks 60>;
1203 fsl,usbphy = <&usbphy0>;
1204 status = "disabled";
1207 usb1: usb@80090000 {
1208 compatible = "fsl,imx28-usb", "fsl,imx27-usb";
1209 reg = <0x80090000 0x10000>;
1211 clocks = <&clks 61>;
1212 fsl,usbphy = <&usbphy1>;
1214 status = "disabled";
1217 dflpt: dflpt@800c0000 {
1218 reg = <0x800c0000 0x10000>;
1219 status = "disabled";
1222 mac0: ethernet@800f0000 {
1223 compatible = "fsl,imx28-fec";
1224 reg = <0x800f0000 0x4000>;
1226 clocks = <&clks 57>, <&clks 57>, <&clks 64>;
1227 clock-names = "ipg", "ahb", "enet_out";
1228 status = "disabled";
1231 mac1: ethernet@800f4000 {
1232 compatible = "fsl,imx28-fec";
1233 reg = <0x800f4000 0x4000>;
1235 clocks = <&clks 57>, <&clks 57>;
1236 clock-names = "ipg", "ahb";
1237 status = "disabled";
1240 etn_switch: switch@800f8000 {
1241 reg = <0x800f8000 0x8000>;
1242 status = "disabled";
1247 compatible = "iio-hwmon";
1248 io-channels = <&lradc 8>;