1 // SPDX-License-Identifier: GPL-2.0-or-later
3 * Copyright 2013 Gateworks Corporation
6 #include <dt-bindings/gpio/gpio.h>
7 #include <dt-bindings/input/linux-event-codes.h>
8 #include <dt-bindings/interrupt-controller/irq.h>
11 /* these are used by bootloader for disabling nodes */
21 bootargs = "console=ttymxc1,115200";
25 compatible = "gpio-keys";
29 gpios = <&gsc_gpio 0 GPIO_ACTIVE_LOW>;
36 interrupt-parent = <&gsc>;
43 interrupt-parent = <&gsc>;
50 interrupt-parent = <&gsc>;
57 interrupt-parent = <&gsc>;
62 label = "switch_hold";
64 interrupt-parent = <&gsc>;
70 compatible = "gpio-leds";
71 pinctrl-names = "default";
72 pinctrl-0 = <&pinctrl_gpio_leds>;
76 gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDG */
78 linux,default-trigger = "heartbeat";
83 gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* MX6_PANLEDR */
84 default-state = "off";
89 device_type = "memory";
90 reg = <0x10000000 0x20000000>;
94 compatible = "pps-gpio";
95 pinctrl-names = "default";
96 pinctrl-0 = <&pinctrl_pps>;
97 gpios = <&gpio1 26 GPIO_ACTIVE_HIGH>;
101 reg_3p3v: regulator-3p3v {
102 compatible = "regulator-fixed";
103 regulator-name = "3P3V";
104 regulator-min-microvolt = <3300000>;
105 regulator-max-microvolt = <3300000>;
109 reg_5p0v: regulator-5p0v {
110 compatible = "regulator-fixed";
111 regulator-name = "5P0V";
112 regulator-min-microvolt = <5000000>;
113 regulator-max-microvolt = <5000000>;
117 reg_usb_otg_vbus: regulator-usb-otg-vbus {
118 compatible = "regulator-fixed";
119 regulator-name = "usb_otg_vbus";
120 regulator-min-microvolt = <5000000>;
121 regulator-max-microvolt = <5000000>;
122 gpio = <&gpio3 22 GPIO_ACTIVE_HIGH>;
128 pinctrl-names = "default";
129 pinctrl-0 = <&pinctrl_enet>;
130 phy-mode = "rgmii-id";
131 phy-reset-gpios = <&gpio1 30 GPIO_ACTIVE_LOW>;
132 phy-reset-duration = <10>;
133 phy-reset-post-delay = <100>;
138 pinctrl-names = "default";
139 pinctrl-0 = <&pinctrl_gpmi_nand>;
144 ddc-i2c-bus = <&i2c3>;
149 clock-frequency = <100000>;
150 pinctrl-names = "default";
151 pinctrl-0 = <&pinctrl_i2c1>;
155 compatible = "gw,gsc";
157 interrupt-parent = <&gpio1>;
158 interrupts = <4 IRQ_TYPE_LEVEL_LOW>;
159 interrupt-controller;
160 #interrupt-cells = <1>;
164 compatible = "gw,gsc-adc";
165 #address-cells = <1>;
243 compatible = "nxp,pca9555";
247 interrupt-parent = <&gsc>;
252 compatible = "atmel,24c02";
258 compatible = "atmel,24c02";
264 compatible = "atmel,24c02";
270 compatible = "atmel,24c02";
276 compatible = "dallas,ds1672";
282 clock-frequency = <100000>;
283 pinctrl-names = "default";
284 pinctrl-0 = <&pinctrl_i2c2>;
288 compatible = "lltc,ltc3676";
290 pinctrl-names = "default";
291 pinctrl-0 = <&pinctrl_pmic>;
292 interrupt-parent = <&gpio1>;
293 interrupts = <8 IRQ_TYPE_EDGE_FALLING>;
296 /* VDD_SOC (1+R1/R2 = 1.635) */
298 regulator-name = "vddsoc";
299 regulator-min-microvolt = <674400>;
300 regulator-max-microvolt = <1308000>;
301 lltc,fb-voltage-divider = <127000 200000>;
302 regulator-ramp-delay = <7000>;
307 /* VDD_1P8 (1+R1/R2 = 2.505): GPS/VideoIn/ENET-PHY */
309 regulator-name = "vdd1p8";
310 regulator-min-microvolt = <1033310>;
311 regulator-max-microvolt = <2004000>;
312 lltc,fb-voltage-divider = <301000 200000>;
313 regulator-ramp-delay = <7000>;
318 /* VDD_ARM (1+R1/R2 = 1.635) */
320 regulator-name = "vddarm";
321 regulator-min-microvolt = <674400>;
322 regulator-max-microvolt = <1308000>;
323 lltc,fb-voltage-divider = <127000 200000>;
324 regulator-ramp-delay = <7000>;
329 /* VDD_DDR (1+R1/R2 = 2.105) */
331 regulator-name = "vddddr";
332 regulator-min-microvolt = <868310>;
333 regulator-max-microvolt = <1684000>;
334 lltc,fb-voltage-divider = <221000 200000>;
335 regulator-ramp-delay = <7000>;
340 /* VDD_2P5 (1+R1/R2 = 3.435): PCIe/ENET-PHY */
342 regulator-name = "vdd2p5";
343 regulator-min-microvolt = <2490375>;
344 regulator-max-microvolt = <2490375>;
345 lltc,fb-voltage-divider = <487000 200000>;
350 /* VDD_HIGH (1+R1/R2 = 4.17) */
352 regulator-name = "vdd3p0";
353 regulator-min-microvolt = <3023250>;
354 regulator-max-microvolt = <3023250>;
355 lltc,fb-voltage-divider = <634000 200000>;
364 clock-frequency = <100000>;
365 pinctrl-names = "default";
366 pinctrl-0 = <&pinctrl_i2c3>;
370 compatible = "adi,adv7180";
371 pinctrl-names = "default";
372 pinctrl-0 = <&pinctrl_adv7180>;
374 powerdown-gpios = <&gpio5 20 GPIO_ACTIVE_LOW>;
375 interrupt-parent = <&gpio5>;
376 interrupts = <23 IRQ_TYPE_LEVEL_LOW>;
379 adv7180_to_ipu1_csi0_mux: endpoint {
380 remote-endpoint = <&ipu1_csi0_mux_from_parallel_sensor>;
387 &ipu1_csi0_from_ipu1_csi0_mux {
391 &ipu1_csi0_mux_from_parallel_sensor {
392 remote-endpoint = <&adv7180_to_ipu1_csi0_mux>;
397 pinctrl-names = "default";
398 pinctrl-0 = <&pinctrl_ipu1_csi0>;
402 pinctrl-names = "default";
403 pinctrl-0 = <&pinctrl_pcie>;
404 reset-gpio = <&gpio1 0 GPIO_ACTIVE_LOW>;
409 pinctrl-names = "default";
410 pinctrl-0 = <&pinctrl_pwm2>; /* MX6_DIO1 */
415 pinctrl-names = "default";
416 pinctrl-0 = <&pinctrl_pwm3>; /* MX6_DIO2 */
421 pinctrl-names = "default";
422 pinctrl-0 = <&pinctrl_pwm4>; /* MX6_DIO3 */
427 pinctrl-names = "default";
428 pinctrl-0 = <&pinctrl_uart1>;
433 pinctrl-names = "default";
434 pinctrl-0 = <&pinctrl_uart2>;
439 pinctrl-names = "default";
440 pinctrl-0 = <&pinctrl_uart3>;
445 pinctrl-names = "default";
446 pinctrl-0 = <&pinctrl_uart5>;
451 vbus-supply = <®_usb_otg_vbus>;
452 pinctrl-names = "default";
453 pinctrl-0 = <&pinctrl_usbotg>;
454 disable-over-current;
464 pinctrl-names = "default";
465 pinctrl-0 = <&pinctrl_wdog>;
466 fsl,ext-reset-output;
470 pinctrl_adv7180: adv7180grp {
472 MX6QDL_PAD_CSI0_DAT5__GPIO5_IO23 0x0001b0b0
473 MX6QDL_PAD_CSI0_DATA_EN__GPIO5_IO20 0x4001b0b0
477 pinctrl_enet: enetgrp {
479 MX6QDL_PAD_RGMII_RXC__RGMII_RXC 0x1b030
480 MX6QDL_PAD_RGMII_RD0__RGMII_RD0 0x1b030
481 MX6QDL_PAD_RGMII_RD1__RGMII_RD1 0x1b030
482 MX6QDL_PAD_RGMII_RD2__RGMII_RD2 0x1b030
483 MX6QDL_PAD_RGMII_RD3__RGMII_RD3 0x1b030
484 MX6QDL_PAD_RGMII_RX_CTL__RGMII_RX_CTL 0x1b030
485 MX6QDL_PAD_RGMII_TXC__RGMII_TXC 0x1b030
486 MX6QDL_PAD_RGMII_TD0__RGMII_TD0 0x1b030
487 MX6QDL_PAD_RGMII_TD1__RGMII_TD1 0x1b030
488 MX6QDL_PAD_RGMII_TD2__RGMII_TD2 0x1b030
489 MX6QDL_PAD_RGMII_TD3__RGMII_TD3 0x1b030
490 MX6QDL_PAD_RGMII_TX_CTL__RGMII_TX_CTL 0x1b030
491 MX6QDL_PAD_ENET_REF_CLK__ENET_TX_CLK 0x1b0b0
492 MX6QDL_PAD_ENET_MDIO__ENET_MDIO 0x1b0b0
493 MX6QDL_PAD_ENET_MDC__ENET_MDC 0x1b0b0
494 MX6QDL_PAD_GPIO_16__ENET_REF_CLK 0x4001b0a8
495 MX6QDL_PAD_ENET_TXD0__GPIO1_IO30 0x1b0b0 /* PHY Reset */
499 pinctrl_gpio_leds: gpioledsgrp {
501 MX6QDL_PAD_KEY_COL0__GPIO4_IO06 0x1b0b0
502 MX6QDL_PAD_KEY_ROW0__GPIO4_IO07 0x1b0b0
506 pinctrl_gpmi_nand: gpminandgrp {
508 MX6QDL_PAD_NANDF_CLE__NAND_CLE 0xb0b1
509 MX6QDL_PAD_NANDF_ALE__NAND_ALE 0xb0b1
510 MX6QDL_PAD_NANDF_WP_B__NAND_WP_B 0xb0b1
511 MX6QDL_PAD_NANDF_RB0__NAND_READY_B 0xb000
512 MX6QDL_PAD_NANDF_CS0__NAND_CE0_B 0xb0b1
513 MX6QDL_PAD_SD4_CMD__NAND_RE_B 0xb0b1
514 MX6QDL_PAD_SD4_CLK__NAND_WE_B 0xb0b1
515 MX6QDL_PAD_NANDF_D0__NAND_DATA00 0xb0b1
516 MX6QDL_PAD_NANDF_D1__NAND_DATA01 0xb0b1
517 MX6QDL_PAD_NANDF_D2__NAND_DATA02 0xb0b1
518 MX6QDL_PAD_NANDF_D3__NAND_DATA03 0xb0b1
519 MX6QDL_PAD_NANDF_D4__NAND_DATA04 0xb0b1
520 MX6QDL_PAD_NANDF_D5__NAND_DATA05 0xb0b1
521 MX6QDL_PAD_NANDF_D6__NAND_DATA06 0xb0b1
522 MX6QDL_PAD_NANDF_D7__NAND_DATA07 0xb0b1
526 pinctrl_i2c1: i2c1grp {
528 MX6QDL_PAD_EIM_D21__I2C1_SCL 0x4001b8b1
529 MX6QDL_PAD_EIM_D28__I2C1_SDA 0x4001b8b1
530 MX6QDL_PAD_GPIO_4__GPIO1_IO04 0x0001b0b0 /* GSC_IRQ# */
534 pinctrl_i2c2: i2c2grp {
536 MX6QDL_PAD_KEY_COL3__I2C2_SCL 0x4001b8b1
537 MX6QDL_PAD_KEY_ROW3__I2C2_SDA 0x4001b8b1
541 pinctrl_i2c3: i2c3grp {
543 MX6QDL_PAD_GPIO_3__I2C3_SCL 0x4001b8b1
544 MX6QDL_PAD_GPIO_6__I2C3_SDA 0x4001b8b1
548 pinctrl_ipu1_csi0: ipu1csi0grp {
550 MX6QDL_PAD_CSI0_DAT12__IPU1_CSI0_DATA12 0x1b0b0
551 MX6QDL_PAD_CSI0_DAT13__IPU1_CSI0_DATA13 0x1b0b0
552 MX6QDL_PAD_CSI0_DAT14__IPU1_CSI0_DATA14 0x1b0b0
553 MX6QDL_PAD_CSI0_DAT15__IPU1_CSI0_DATA15 0x1b0b0
554 MX6QDL_PAD_CSI0_DAT16__IPU1_CSI0_DATA16 0x1b0b0
555 MX6QDL_PAD_CSI0_DAT17__IPU1_CSI0_DATA17 0x1b0b0
556 MX6QDL_PAD_CSI0_DAT18__IPU1_CSI0_DATA18 0x1b0b0
557 MX6QDL_PAD_CSI0_DAT19__IPU1_CSI0_DATA19 0x1b0b0
558 MX6QDL_PAD_CSI0_MCLK__IPU1_CSI0_HSYNC 0x1b0b0
559 MX6QDL_PAD_CSI0_VSYNC__IPU1_CSI0_VSYNC 0x1b0b0
560 MX6QDL_PAD_CSI0_PIXCLK__IPU1_CSI0_PIXCLK 0x1b0b0
564 pinctrl_pcie: pciegrp {
566 MX6QDL_PAD_GPIO_0__GPIO1_IO00 0x1b0b0
570 pinctrl_pmic: pmicgrp {
572 MX6QDL_PAD_GPIO_8__GPIO1_IO08 0x0001b0b0 /* PMIC_IRQ# */
576 pinctrl_pps: ppsgrp {
578 MX6QDL_PAD_ENET_RXD1__GPIO1_IO26 0x1b0b1
582 pinctrl_pwm2: pwm2grp {
584 MX6QDL_PAD_SD1_DAT2__PWM2_OUT 0x1b0b1
588 pinctrl_pwm3: pwm3grp {
590 MX6QDL_PAD_SD1_DAT1__PWM3_OUT 0x1b0b1
594 pinctrl_pwm4: pwm4grp {
596 MX6QDL_PAD_SD1_CMD__PWM4_OUT 0x1b0b1
600 pinctrl_uart1: uart1grp {
602 MX6QDL_PAD_SD3_DAT7__UART1_TX_DATA 0x1b0b1
603 MX6QDL_PAD_SD3_DAT6__UART1_RX_DATA 0x1b0b1
607 pinctrl_uart2: uart2grp {
609 MX6QDL_PAD_SD4_DAT7__UART2_TX_DATA 0x1b0b1
610 MX6QDL_PAD_SD4_DAT4__UART2_RX_DATA 0x1b0b1
614 pinctrl_uart3: uart3grp {
616 MX6QDL_PAD_EIM_D24__UART3_TX_DATA 0x1b0b1
617 MX6QDL_PAD_EIM_D25__UART3_RX_DATA 0x1b0b1
621 pinctrl_uart5: uart5grp {
623 MX6QDL_PAD_KEY_COL1__UART5_TX_DATA 0x1b0b1
624 MX6QDL_PAD_KEY_ROW1__UART5_RX_DATA 0x1b0b1
628 pinctrl_usbotg: usbotggrp {
630 MX6QDL_PAD_GPIO_1__USB_OTG_ID 0x17059
631 MX6QDL_PAD_EIM_D22__GPIO3_IO22 0x1b0b0 /* OTG_PWR_EN */
635 pinctrl_wdog: wdoggrp {
637 MX6QDL_PAD_DISP0_DAT8__WDOG1_B 0x1b0b0