2 * Copyright (C) 2017 Zodiac Inflight Innovations
4 * This file is dual-licensed: you can use it either under the terms
5 * of the GPL or the X11 license, at your option. Note that this dual
6 * licensing only applies to this file, and not this project as a
9 * a) This file is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * version 2 as published by the Free Software Foundation.
13 * This file is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
20 * b) Permission is hereby granted, free of charge, to any person
21 * obtaining a copy of this software and associated documentation
22 * files (the "Software"), to deal in the Software without
23 * restriction, including without limitation the rights to use,
24 * copy, modify, merge, publish, distribute, sublicense, and/or
25 * sell copies of the Software, and to permit persons to whom the
26 * Software is furnished to do so, subject to the following
29 * The above copyright notice and this permission notice shall be
30 * included in all copies or substantial portions of the Software.
32 * THE SOFTWARE IS PROVIDED , WITHOUT WARRANTY OF ANY KIND,
33 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
34 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
35 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
36 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
37 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
38 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
39 * OTHER DEALINGS IN THE SOFTWARE.
44 #include <dt-bindings/sound/fsl-imx-audmux.h>
47 model = "ZII RDU1 Board";
48 compatible = "zii,imx51-rdu1", "fsl,imx51";
54 /* Will be filled by the bootloader */
60 mdio-gpio0 = &mdio_gpio;
64 clk_26M_osc: 26M_osc {
65 compatible = "fixed-clock";
67 clock-frequency = <26000000>;
70 clk_26M_osc_gate: 26M_gate {
71 compatible = "gpio-gate-clock";
72 pinctrl-names = "default";
73 pinctrl-0 = <&pinctrl_clk26mhz>;
74 clocks = <&clk_26M_osc>;
76 enable-gpios = <&gpio3 1 GPIO_ACTIVE_HIGH>;
79 clk_26M_usb: usbhost_gate {
80 compatible = "gpio-gate-clock";
81 pinctrl-names = "default";
82 pinctrl-0 = <&pinctrl_usbgate26mhz>;
83 clocks = <&clk_26M_osc_gate>;
85 enable-gpios = <&gpio1 19 GPIO_ACTIVE_LOW>;
88 clk_26M_snd: snd_gate {
89 compatible = "gpio-gate-clock";
90 pinctrl-names = "default";
91 pinctrl-0 = <&pinctrl_sndgate26mhz>;
92 clocks = <&clk_26M_osc_gate>;
94 enable-gpios = <&gpio4 26 GPIO_ACTIVE_LOW>;
97 reg_5p0v_main: regulator-5p0v-main {
98 compatible = "regulator-fixed";
99 regulator-name = "5V_MAIN";
100 regulator-min-microvolt = <5000000>;
101 regulator-max-microvolt = <5000000>;
105 reg_3p3v: regulator-3p3v {
106 compatible = "regulator-fixed";
107 regulator-name = "3.3V";
108 regulator-min-microvolt = <3300000>;
109 regulator-max-microvolt = <3300000>;
114 compatible = "fsl,imx-parallel-display";
115 pinctrl-names = "default";
116 pinctrl-0 = <&pinctrl_ipu_disp1>;
118 #address-cells = <1>;
124 display_in: endpoint {
125 remote-endpoint = <&ipu_di0_disp1>;
132 display_out: endpoint {
133 remote-endpoint = <&panel_in>;
139 /* no compatible here, bootloader will patch in correct one */
140 pinctrl-names = "default";
141 pinctrl-0 = <&pinctrl_panel>;
142 power-supply = <®_3p3v>;
143 enable-gpios = <&gpio3 3 GPIO_ACTIVE_HIGH>;
148 remote-endpoint = <&display_out>;
154 compatible = "i2c-gpio";
155 pinctrl-names = "default";
156 pinctrl-0 = <&pinctrl_swi2c>;
157 gpios = <&gpio1 2 GPIO_ACTIVE_HIGH>, /* sda */
158 <&gpio3 4 GPIO_ACTIVE_HIGH>; /* scl */
159 i2c-gpio,delay-us = <50>;
162 #address-cells = <1>;
166 compatible = "fsl,sgtl5000";
168 clocks = <&clk_26M_snd>;
169 VDDA-supply = <&vdig_reg>;
170 VDDIO-supply = <&vvideo_reg>;
171 #sound-dai-cells = <0>;
176 compatible = "spi-gpio";
177 #address-cells = <1>;
179 pinctrl-names = "default";
180 pinctrl-0 = <&pinctrl_gpiospi0>;
183 gpio-sck = <&gpio4 15 GPIO_ACTIVE_HIGH>;
184 gpio-mosi = <&gpio4 12 GPIO_ACTIVE_HIGH>;
185 gpio-miso = <&gpio4 11 GPIO_ACTIVE_HIGH>;
186 num-chipselects = <1>;
187 cs-gpios = <&gpio4 14 GPIO_ACTIVE_HIGH>;
190 compatible = "eeprom-93xx46";
192 spi-max-frequency = <1000000>;
198 mdio_gpio: mdio-gpio {
199 compatible = "virtual,mdio-gpio";
200 pinctrl-names = "default";
201 pinctrl-0 = <&pinctrl_swmdio>;
202 gpios = <&gpio3 26 GPIO_ACTIVE_HIGH>, /* mdc */
203 <&gpio3 25 GPIO_ACTIVE_HIGH>; /* mdio */
205 #address-cells = <1>;
209 compatible = "marvell,mv88e6085";
214 #address-cells = <1>;
247 compatible = "simple-audio-card";
248 simple-audio-card,name = "Front";
249 simple-audio-card,format = "i2s";
250 simple-audio-card,bitclock-master = <&sound_codec>;
251 simple-audio-card,frame-master = <&sound_codec>;
252 simple-audio-card,widgets =
253 "Headphone", "Headphone Jack";
254 simple-audio-card,routing =
255 "Headphone Jack", "HPLEFT",
256 "Headphone Jack", "HPRIGHT";
257 simple-audio-card,aux-devs = <&hpa1>;
259 sound_cpu: simple-audio-card,cpu {
263 sound_codec: simple-audio-card,codec {
264 sound-dai = <&sgtl5000>;
265 clocks = <&clk_26M_snd>;
270 compatible = "usb-nop-xceiv";
271 pinctrl-names = "default";
272 pinctrl-0 = <&pinctrl_usbh1phy>;
273 clocks = <&clk_26M_usb>;
274 clock-names = "main_clk";
275 reset-gpios = <&gpio4 8 GPIO_ACTIVE_LOW>;
276 vcc-supply = <&vusb_reg>;
281 compatible = "usb-nop-xceiv";
282 pinctrl-names = "default";
283 pinctrl-0 = <&pinctrl_usbh2phy>;
284 clocks = <&clk_26M_usb>;
285 clock-names = "main_clk";
286 reset-gpios = <&gpio4 7 GPIO_ACTIVE_LOW>;
287 vcc-supply = <&vusb_reg>;
293 pinctrl-names = "default";
294 pinctrl-0 = <&pinctrl_audmux>;
298 fsl,audmux-port = <1>;
300 (IMX_AUDMUX_V2_PTCR_SYN |
301 IMX_AUDMUX_V2_PTCR_TFSEL(2) |
302 IMX_AUDMUX_V2_PTCR_TCSEL(2) |
303 IMX_AUDMUX_V2_PTCR_TFSDIR |
304 IMX_AUDMUX_V2_PTCR_TCLKDIR)
305 IMX_AUDMUX_V2_PDCR_RXDSEL(2)
310 fsl,audmux-port = <2>;
312 IMX_AUDMUX_V2_PTCR_SYN
313 IMX_AUDMUX_V2_PDCR_RXDSEL(1)
319 cpu-supply = <&sw1_reg>;
323 pinctrl-names = "default";
324 pinctrl-0 = <&pinctrl_ecspi1>;
325 cs-gpios = <&gpio4 24 GPIO_ACTIVE_HIGH>,
326 <&gpio4 25 GPIO_ACTIVE_LOW>;
330 compatible = "fsl,mc13892";
331 pinctrl-names = "default";
332 pinctrl-0 = <&pinctrl_pmic>;
333 spi-max-frequency = <6000000>;
336 interrupt-parent = <&gpio1>;
337 interrupts = <8 IRQ_TYPE_LEVEL_HIGH>;
338 fsl,mc13xxx-uses-adc;
342 regulator-min-microvolt = <600000>;
343 regulator-max-microvolt = <1375000>;
349 regulator-min-microvolt = <900000>;
350 regulator-max-microvolt = <1850000>;
356 regulator-min-microvolt = <1100000>;
357 regulator-max-microvolt = <1850000>;
363 regulator-min-microvolt = <1100000>;
364 regulator-max-microvolt = <1850000>;
370 regulator-min-microvolt = <1050000>;
371 regulator-max-microvolt = <1800000>;
377 regulator-min-microvolt = <1650000>;
378 regulator-max-microvolt = <1650000>;
383 regulator-min-microvolt = <1800000>;
384 regulator-max-microvolt = <3150000>;
392 regulator-min-microvolt = <2400000>;
393 regulator-max-microvolt = <2775000>;
399 regulator-min-microvolt = <2775000>;
400 regulator-max-microvolt = <2775000>;
404 regulator-min-microvolt = <2300000>;
405 regulator-max-microvolt = <3000000>;
409 regulator-min-microvolt = <2500000>;
410 regulator-max-microvolt = <3000000>;
414 regulator-min-microvolt = <1200000>;
415 regulator-max-microvolt = <1200000>;
419 regulator-min-microvolt = <1200000>;
420 regulator-max-microvolt = <3150000>;
425 regulator-min-microvolt = <1800000>;
426 regulator-max-microvolt = <2900000>;
432 #address-cells = <1>;
434 led-control = <0x0 0x0 0x3f83f8 0x0>;
438 label = "system:green:status";
439 linux,default-trigger = "default-on";
444 label = "system:green:act";
445 linux,default-trigger = "heartbeat";
451 #address-cells = <1>;
453 compatible = "atmel,at45db642d", "atmel,at45", "atmel,dataflash";
454 spi-max-frequency = <25000000>;
460 pinctrl-names = "default";
461 pinctrl-0 = <&pinctrl_esdhc1>;
471 pinctrl-names = "default";
472 pinctrl-0 = <&pinctrl_fec>;
474 phy-reset-gpios = <&gpio2 14 GPIO_ACTIVE_LOW>;
475 phy-supply = <&vgen3_reg>;
480 pinctrl-names = "default";
481 pinctrl-0 = <&pinctrl_i2c2>;
485 compatible = "atmel,24c04";
491 compatible = "ti,tpa6130a2";
493 pinctrl-names = "default";
494 pinctrl-0 = <&pinctrl_ampgpio>;
495 power-gpio = <&gpio1 9 GPIO_ACTIVE_HIGH>;
496 Vdd-supply = <®_3p3v>;
500 compatible = "maxim,ds1341";
504 /* touch nodes default disabled, bootloader will enable the right one */
507 compatible = "atmel,maxtouch";
509 pinctrl-names = "default";
510 pinctrl-0 = <&pinctrl_ts>;
511 interrupt-parent = <&gpio3>;
512 interrupts = <12 IRQ_TYPE_LEVEL_LOW>;
517 compatible = "atmel,maxtouch";
519 pinctrl-names = "default";
520 pinctrl-0 = <&pinctrl_ts>;
521 interrupt-parent = <&gpio3>;
522 interrupts = <12 IRQ_TYPE_LEVEL_LOW>;
527 compatible = "syna,rmi4-i2c";
529 pinctrl-names = "default";
530 pinctrl-0 = <&pinctrl_ts>;
531 interrupt-parent = <&gpio3>;
532 interrupts = <12 IRQ_TYPE_LEVEL_LOW>;
535 #address-cells = <1>;
540 syna,nosleep-mode = <2>;
545 touchscreen-inverted-y;
546 touchscreen-swapped-x-y;
547 syna,sensor-type = <1>;
554 remote-endpoint = <&display_in>;
562 pinctrl-names = "default";
563 pinctrl-0 = <&pinctrl_uart1>;
568 pinctrl-names = "default";
569 pinctrl-0 = <&pinctrl_uart2>;
574 pinctrl-names = "default";
575 pinctrl-0 = <&pinctrl_uart3>;
579 compatible = "zii,rave-sp-rdu1";
580 current-speed = <38400>;
583 compatible = "zii,rave-sp-watchdog";
589 pinctrl-names = "default";
590 pinctrl-0 = <&pinctrl_usbh1>;
593 fsl,usbphy = <&usbh1phy>;
594 disable-over-current;
595 maximum-speed = "full-speed";
596 vbus-supply = <®_5p0v_main>;
601 pinctrl-names = "default";
602 pinctrl-0 = <&pinctrl_usbh2>;
605 fsl,usbphy = <&usbh2phy>;
606 disable-over-current;
607 vbus-supply = <®_5p0v_main>;
612 vcc-supply = <&vusb_reg>;
617 disable-over-current;
618 phy_type = "utmi_wide";
619 vbus-supply = <®_5p0v_main>;
624 pinctrl_ampgpio: ampgpiogrp {
626 MX51_PAD_GPIO1_9__GPIO1_9 0x5e
630 pinctrl_audmux: audmuxgrp {
632 MX51_PAD_AUD3_BB_TXD__AUD3_TXD 0xa5
633 MX51_PAD_AUD3_BB_RXD__AUD3_RXD 0x85
634 MX51_PAD_AUD3_BB_CK__AUD3_TXC 0xa5
635 MX51_PAD_AUD3_BB_FS__AUD3_TXFS 0x85
639 pinctrl_clk26mhz: clk26mhzgrp {
641 MX51_PAD_DI1_PIN12__GPIO3_1 0x85
645 pinctrl_ecspi1: ecspi1grp {
647 MX51_PAD_CSPI1_MISO__ECSPI1_MISO 0x185
648 MX51_PAD_CSPI1_MOSI__ECSPI1_MOSI 0x185
649 MX51_PAD_CSPI1_SCLK__ECSPI1_SCLK 0x185
650 MX51_PAD_CSPI1_SS0__GPIO4_24 0x85
651 MX51_PAD_CSPI1_SS1__GPIO4_25 0x85
655 pinctrl_esdhc1: esdhc1grp {
657 MX51_PAD_SD1_CMD__SD1_CMD 0x400020d5
658 MX51_PAD_SD1_CLK__SD1_CLK 0x20d5
659 MX51_PAD_SD1_DATA0__SD1_DATA0 0x20d5
660 MX51_PAD_SD1_DATA1__SD1_DATA1 0x20d5
661 MX51_PAD_SD1_DATA2__SD1_DATA2 0x20d5
662 MX51_PAD_SD1_DATA3__SD1_DATA3 0x20d5
666 pinctrl_fec: fecgrp {
668 MX51_PAD_EIM_EB2__FEC_MDIO 0x1f5
669 MX51_PAD_NANDF_D9__FEC_RDATA0 0x2180
670 MX51_PAD_EIM_EB3__FEC_RDATA1 0x180
671 MX51_PAD_EIM_CS2__FEC_RDATA2 0x180
672 MX51_PAD_EIM_CS3__FEC_RDATA3 0x180
673 MX51_PAD_EIM_CS4__FEC_RX_ER 0x180
674 MX51_PAD_NANDF_D11__FEC_RX_DV 0x2084
675 MX51_PAD_EIM_CS5__FEC_CRS 0x180
676 MX51_PAD_NANDF_RB2__FEC_COL 0x2180
677 MX51_PAD_NANDF_RB3__FEC_RX_CLK 0x2180
678 MX51_PAD_NANDF_CS2__FEC_TX_ER 0x2004
679 MX51_PAD_NANDF_CS3__FEC_MDC 0x2004
680 MX51_PAD_NANDF_D8__FEC_TDATA0 0x2180
681 MX51_PAD_NANDF_CS4__FEC_TDATA1 0x2004
682 MX51_PAD_NANDF_CS5__FEC_TDATA2 0x2004
683 MX51_PAD_NANDF_CS6__FEC_TDATA3 0x2004
684 MX51_PAD_DISP2_DAT9__FEC_TX_EN 0x2004
685 MX51_PAD_DISP2_DAT13__FEC_TX_CLK 0x2180
686 MX51_PAD_EIM_A20__GPIO2_14 0x85
690 pinctrl_gpiospi0: gpiospi0grp {
692 MX51_PAD_CSI2_D18__GPIO4_11 0x85
693 MX51_PAD_CSI2_D19__GPIO4_12 0x85
694 MX51_PAD_CSI2_HSYNC__GPIO4_14 0x85
695 MX51_PAD_CSI2_PIXCLK__GPIO4_15 0x85
699 pinctrl_i2c2: i2c2grp {
701 MX51_PAD_KEY_COL4__I2C2_SCL 0x400001ed
702 MX51_PAD_KEY_COL5__I2C2_SDA 0x400001ed
706 pinctrl_ipu_disp1: ipudisp1grp {
708 MX51_PAD_DISP1_DAT0__DISP1_DAT0 0x5
709 MX51_PAD_DISP1_DAT1__DISP1_DAT1 0x5
710 MX51_PAD_DISP1_DAT2__DISP1_DAT2 0x5
711 MX51_PAD_DISP1_DAT3__DISP1_DAT3 0x5
712 MX51_PAD_DISP1_DAT4__DISP1_DAT4 0x5
713 MX51_PAD_DISP1_DAT5__DISP1_DAT5 0x5
714 MX51_PAD_DISP1_DAT6__DISP1_DAT6 0x5
715 MX51_PAD_DISP1_DAT7__DISP1_DAT7 0x5
716 MX51_PAD_DISP1_DAT8__DISP1_DAT8 0x5
717 MX51_PAD_DISP1_DAT9__DISP1_DAT9 0x5
718 MX51_PAD_DISP1_DAT10__DISP1_DAT10 0x5
719 MX51_PAD_DISP1_DAT11__DISP1_DAT11 0x5
720 MX51_PAD_DISP1_DAT12__DISP1_DAT12 0x5
721 MX51_PAD_DISP1_DAT13__DISP1_DAT13 0x5
722 MX51_PAD_DISP1_DAT14__DISP1_DAT14 0x5
723 MX51_PAD_DISP1_DAT15__DISP1_DAT15 0x5
724 MX51_PAD_DISP1_DAT16__DISP1_DAT16 0x5
725 MX51_PAD_DISP1_DAT17__DISP1_DAT17 0x5
726 MX51_PAD_DISP1_DAT18__DISP1_DAT18 0x5
727 MX51_PAD_DISP1_DAT19__DISP1_DAT19 0x5
728 MX51_PAD_DISP1_DAT20__DISP1_DAT20 0x5
729 MX51_PAD_DISP1_DAT21__DISP1_DAT21 0x5
730 MX51_PAD_DISP1_DAT22__DISP1_DAT22 0x5
731 MX51_PAD_DISP1_DAT23__DISP1_DAT23 0x5
732 MX51_PAD_DI1_PIN2__DI1_PIN2 0x5
733 MX51_PAD_DI1_PIN3__DI1_PIN3 0x5
734 MX51_PAD_DI2_DISP_CLK__DI2_DISP_CLK 0x5
738 pinctrl_panel: panelgrp {
740 MX51_PAD_DI1_D0_CS__GPIO3_3 0x85
744 pinctrl_pmic: pmicgrp {
746 MX51_PAD_GPIO1_4__GPIO1_4 0x1e0
747 MX51_PAD_GPIO1_8__GPIO1_8 0x21e2
751 pinctrl_sndgate26mhz: sndgate26mhzgrp {
753 MX51_PAD_CSPI1_RDY__GPIO4_26 0x85
757 pinctrl_swi2c: swi2cgrp {
759 MX51_PAD_GPIO1_2__GPIO1_2 0xc5
760 MX51_PAD_DI1_D1_CS__GPIO3_4 0x400001f5
764 pinctrl_swmdio: swmdiogrp {
766 MX51_PAD_NANDF_D14__GPIO3_26 0x21e6
767 MX51_PAD_NANDF_D15__GPIO3_25 0x21e6
773 MX51_PAD_CSI1_D8__GPIO3_12 0x04
774 MX51_PAD_CSI1_D9__GPIO3_13 0x85
778 pinctrl_uart1: uart1grp {
780 MX51_PAD_UART1_RXD__UART1_RXD 0x1c5
781 MX51_PAD_UART1_TXD__UART1_TXD 0x1c5
782 MX51_PAD_UART1_RTS__UART1_RTS 0x1c4
783 MX51_PAD_UART1_CTS__UART1_CTS 0x1c4
787 pinctrl_uart2: uart2grp {
789 MX51_PAD_UART2_RXD__UART2_RXD 0xc5
790 MX51_PAD_UART2_TXD__UART2_TXD 0xc5
794 pinctrl_uart3: uart3grp {
796 MX51_PAD_EIM_D25__UART3_RXD 0x1c5
797 MX51_PAD_EIM_D26__UART3_TXD 0x1c5
801 pinctrl_usbgate26mhz: usbgate26mhzgrp {
803 MX51_PAD_DISP2_DAT6__GPIO1_19 0x85
807 pinctrl_usbh1: usbh1grp {
809 MX51_PAD_USBH1_STP__USBH1_STP 0x0
810 MX51_PAD_USBH1_CLK__USBH1_CLK 0x0
811 MX51_PAD_USBH1_DIR__USBH1_DIR 0x0
812 MX51_PAD_USBH1_NXT__USBH1_NXT 0x0
813 MX51_PAD_USBH1_DATA0__USBH1_DATA0 0x0
814 MX51_PAD_USBH1_DATA1__USBH1_DATA1 0x0
815 MX51_PAD_USBH1_DATA2__USBH1_DATA2 0x0
816 MX51_PAD_USBH1_DATA3__USBH1_DATA3 0x0
817 MX51_PAD_USBH1_DATA4__USBH1_DATA4 0x0
818 MX51_PAD_USBH1_DATA5__USBH1_DATA5 0x0
819 MX51_PAD_USBH1_DATA6__USBH1_DATA6 0x0
820 MX51_PAD_USBH1_DATA7__USBH1_DATA7 0x0
824 pinctrl_usbh1phy: usbh1phygrp {
826 MX51_PAD_NANDF_D0__GPIO4_8 0x85
830 pinctrl_usbh2: usbh2grp {
832 MX51_PAD_EIM_A26__USBH2_STP 0x0
833 MX51_PAD_EIM_A24__USBH2_CLK 0x0
834 MX51_PAD_EIM_A25__USBH2_DIR 0x0
835 MX51_PAD_EIM_A27__USBH2_NXT 0x0
836 MX51_PAD_EIM_D16__USBH2_DATA0 0x0
837 MX51_PAD_EIM_D17__USBH2_DATA1 0x0
838 MX51_PAD_EIM_D18__USBH2_DATA2 0x0
839 MX51_PAD_EIM_D19__USBH2_DATA3 0x0
840 MX51_PAD_EIM_D20__USBH2_DATA4 0x0
841 MX51_PAD_EIM_D21__USBH2_DATA5 0x0
842 MX51_PAD_EIM_D22__USBH2_DATA6 0x0
843 MX51_PAD_EIM_D23__USBH2_DATA7 0x0
847 pinctrl_usbh2phy: usbh2phygrp {
849 MX51_PAD_NANDF_D1__GPIO4_7 0x85