1*724ba675SRob Herring// SPDX-License-Identifier: GPL-2.0 2*724ba675SRob Herring/* 3*724ba675SRob Herring * Copyright 2013 Freescale Semiconductor, Inc. 4*724ba675SRob Herring * 5*724ba675SRob Herring * Author: Fabio Estevam <fabio.estevam@freescale.com> 6*724ba675SRob Herring */ 7*724ba675SRob Herring 8*724ba675SRob Herring#include <dt-bindings/gpio/gpio.h> 9*724ba675SRob Herring 10*724ba675SRob Herring/ { 11*724ba675SRob Herring chosen { 12*724ba675SRob Herring stdout-path = &uart1; 13*724ba675SRob Herring }; 14*724ba675SRob Herring 15*724ba675SRob Herring sound { 16*724ba675SRob Herring compatible = "fsl,imx6-wandboard-sgtl5000", 17*724ba675SRob Herring "fsl,imx-audio-sgtl5000"; 18*724ba675SRob Herring model = "imx6-wandboard-sgtl5000"; 19*724ba675SRob Herring ssi-controller = <&ssi1>; 20*724ba675SRob Herring audio-codec = <&codec>; 21*724ba675SRob Herring audio-routing = 22*724ba675SRob Herring "MIC_IN", "Mic Jack", 23*724ba675SRob Herring "Mic Jack", "Mic Bias", 24*724ba675SRob Herring "Headphone Jack", "HP_OUT"; 25*724ba675SRob Herring mux-int-port = <1>; 26*724ba675SRob Herring mux-ext-port = <3>; 27*724ba675SRob Herring }; 28*724ba675SRob Herring 29*724ba675SRob Herring sound-spdif { 30*724ba675SRob Herring compatible = "fsl,imx-audio-spdif"; 31*724ba675SRob Herring model = "imx-spdif"; 32*724ba675SRob Herring spdif-controller = <&spdif>; 33*724ba675SRob Herring spdif-out; 34*724ba675SRob Herring }; 35*724ba675SRob Herring 36*724ba675SRob Herring reg_1p5v: regulator-1p5v { 37*724ba675SRob Herring compatible = "regulator-fixed"; 38*724ba675SRob Herring regulator-name = "1P5V"; 39*724ba675SRob Herring regulator-min-microvolt = <1500000>; 40*724ba675SRob Herring regulator-max-microvolt = <1500000>; 41*724ba675SRob Herring regulator-always-on; 42*724ba675SRob Herring }; 43*724ba675SRob Herring 44*724ba675SRob Herring reg_1p8v: regulator-1p8v { 45*724ba675SRob Herring compatible = "regulator-fixed"; 46*724ba675SRob Herring regulator-name = "1P8V"; 47*724ba675SRob Herring regulator-min-microvolt = <1800000>; 48*724ba675SRob Herring regulator-max-microvolt = <1800000>; 49*724ba675SRob Herring regulator-always-on; 50*724ba675SRob Herring }; 51*724ba675SRob Herring 52*724ba675SRob Herring reg_2p8v: regulator-2p8v { 53*724ba675SRob Herring compatible = "regulator-fixed"; 54*724ba675SRob Herring regulator-name = "2P8V"; 55*724ba675SRob Herring regulator-min-microvolt = <2800000>; 56*724ba675SRob Herring regulator-max-microvolt = <2800000>; 57*724ba675SRob Herring regulator-always-on; 58*724ba675SRob Herring }; 59*724ba675SRob Herring 60*724ba675SRob Herring reg_2p5v: regulator-2p5v { 61*724ba675SRob Herring compatible = "regulator-fixed"; 62*724ba675SRob Herring regulator-name = "2P5V"; 63*724ba675SRob Herring regulator-min-microvolt = <2500000>; 64*724ba675SRob Herring regulator-max-microvolt = <2500000>; 65*724ba675SRob Herring regulator-always-on; 66*724ba675SRob Herring }; 67*724ba675SRob Herring 68*724ba675SRob Herring reg_3p3v: regulator-3p3v { 69*724ba675SRob Herring compatible = "regulator-fixed"; 70*724ba675SRob Herring regulator-name = "3P3V"; 71*724ba675SRob Herring regulator-min-microvolt = <3300000>; 72*724ba675SRob Herring regulator-max-microvolt = <3300000>; 73*724ba675SRob Herring regulator-always-on; 74*724ba675SRob Herring }; 75*724ba675SRob Herring 76*724ba675SRob Herring reg_usb_otg_vbus: regulator-usbotgvbus { 77*724ba675SRob Herring compatible = "regulator-fixed"; 78*724ba675SRob Herring regulator-name = "usb_otg_vbus"; 79*724ba675SRob Herring regulator-min-microvolt = <5000000>; 80*724ba675SRob Herring regulator-max-microvolt = <5000000>; 81*724ba675SRob Herring pinctrl-names = "default"; 82*724ba675SRob Herring pinctrl-0 = <&pinctrl_usbotgvbus>; 83*724ba675SRob Herring gpio = <&gpio3 22 GPIO_ACTIVE_LOW>; 84*724ba675SRob Herring }; 85*724ba675SRob Herring}; 86*724ba675SRob Herring 87*724ba675SRob Herring&audmux { 88*724ba675SRob Herring pinctrl-names = "default"; 89*724ba675SRob Herring pinctrl-0 = <&pinctrl_audmux>; 90*724ba675SRob Herring status = "okay"; 91*724ba675SRob Herring}; 92*724ba675SRob Herring 93*724ba675SRob Herring&hdmi { 94*724ba675SRob Herring ddc-i2c-bus = <&i2c1>; 95*724ba675SRob Herring status = "okay"; 96*724ba675SRob Herring}; 97*724ba675SRob Herring 98*724ba675SRob Herring&i2c1 { 99*724ba675SRob Herring clock-frequency = <100000>; 100*724ba675SRob Herring pinctrl-names = "default", "gpio"; 101*724ba675SRob Herring pinctrl-0 = <&pinctrl_i2c1>; 102*724ba675SRob Herring pinctrl-1 = <&pinctrl_i2c1_gpio>; 103*724ba675SRob Herring scl-gpios = <&gpio3 21 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>; 104*724ba675SRob Herring sda-gpios = <&gpio3 28 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>; 105*724ba675SRob Herring status = "okay"; 106*724ba675SRob Herring}; 107*724ba675SRob Herring 108*724ba675SRob Herring&i2c2 { 109*724ba675SRob Herring clock-frequency = <100000>; 110*724ba675SRob Herring pinctrl-names = "default", "gpio"; 111*724ba675SRob Herring pinctrl-0 = <&pinctrl_i2c2>; 112*724ba675SRob Herring pinctrl-1 = <&pinctrl_i2c2_gpio>; 113*724ba675SRob Herring scl-gpios = <&gpio4 12 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>; 114*724ba675SRob Herring sda-gpios = <&gpio4 13 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>; 115*724ba675SRob Herring status = "okay"; 116*724ba675SRob Herring 117*724ba675SRob Herring codec: sgtl5000@a { 118*724ba675SRob Herring pinctrl-names = "default"; 119*724ba675SRob Herring pinctrl-0 = <&pinctrl_mclk>; 120*724ba675SRob Herring compatible = "fsl,sgtl5000"; 121*724ba675SRob Herring reg = <0x0a>; 122*724ba675SRob Herring clocks = <&clks IMX6QDL_CLK_CKO>; 123*724ba675SRob Herring VDDA-supply = <®_2p5v>; 124*724ba675SRob Herring VDDIO-supply = <®_3p3v>; 125*724ba675SRob Herring lrclk-strength = <3>; 126*724ba675SRob Herring }; 127*724ba675SRob Herring 128*724ba675SRob Herring camera@3c { 129*724ba675SRob Herring compatible = "ovti,ov5645"; 130*724ba675SRob Herring pinctrl-names = "default"; 131*724ba675SRob Herring pinctrl-0 = <&pinctrl_ov5645>; 132*724ba675SRob Herring reg = <0x3c>; 133*724ba675SRob Herring clocks = <&clks IMX6QDL_CLK_CKO2>; 134*724ba675SRob Herring clock-frequency = <24000000>; 135*724ba675SRob Herring vdddo-supply = <®_1p8v>; 136*724ba675SRob Herring vdda-supply = <®_2p8v>; 137*724ba675SRob Herring vddd-supply = <®_1p5v>; 138*724ba675SRob Herring enable-gpios = <&gpio1 6 GPIO_ACTIVE_HIGH>; 139*724ba675SRob Herring reset-gpios = <&gpio4 14 GPIO_ACTIVE_LOW>; 140*724ba675SRob Herring 141*724ba675SRob Herring port { 142*724ba675SRob Herring ov5645_to_mipi_csi2: endpoint { 143*724ba675SRob Herring remote-endpoint = <&mipi_csi2_in>; 144*724ba675SRob Herring clock-lanes = <0>; 145*724ba675SRob Herring data-lanes = <1 2>; 146*724ba675SRob Herring }; 147*724ba675SRob Herring }; 148*724ba675SRob Herring }; 149*724ba675SRob Herring}; 150*724ba675SRob Herring 151*724ba675SRob Herring&iomuxc { 152*724ba675SRob Herring pinctrl-names = "default"; 153*724ba675SRob Herring 154*724ba675SRob Herring imx6qdl-wandboard { 155*724ba675SRob Herring 156*724ba675SRob Herring pinctrl_audmux: audmuxgrp { 157*724ba675SRob Herring fsl,pins = < 158*724ba675SRob Herring MX6QDL_PAD_CSI0_DAT7__AUD3_RXD 0x130b0 159*724ba675SRob Herring MX6QDL_PAD_CSI0_DAT4__AUD3_TXC 0x130b0 160*724ba675SRob Herring MX6QDL_PAD_CSI0_DAT5__AUD3_TXD 0x110b0 161*724ba675SRob Herring MX6QDL_PAD_CSI0_DAT6__AUD3_TXFS 0x130b0 162*724ba675SRob Herring >; 163*724ba675SRob Herring }; 164*724ba675SRob Herring 165*724ba675SRob Herring pinctrl_enet: enetgrp { 166*724ba675SRob Herring fsl,pins = < 167*724ba675SRob Herring MX6QDL_PAD_ENET_MDIO__ENET_MDIO 0x1b0b0 168*724ba675SRob Herring MX6QDL_PAD_ENET_MDC__ENET_MDC 0x1b0b0 169*724ba675SRob Herring MX6QDL_PAD_RGMII_TXC__RGMII_TXC 0x1b030 170*724ba675SRob Herring MX6QDL_PAD_RGMII_TD0__RGMII_TD0 0x1b030 171*724ba675SRob Herring MX6QDL_PAD_RGMII_TD1__RGMII_TD1 0x1b030 172*724ba675SRob Herring MX6QDL_PAD_RGMII_TD2__RGMII_TD2 0x1b030 173*724ba675SRob Herring MX6QDL_PAD_RGMII_TD3__RGMII_TD3 0x1b030 174*724ba675SRob Herring MX6QDL_PAD_RGMII_TX_CTL__RGMII_TX_CTL 0x1b030 175*724ba675SRob Herring MX6QDL_PAD_ENET_REF_CLK__ENET_TX_CLK 0x1b0b0 176*724ba675SRob Herring MX6QDL_PAD_RGMII_RXC__RGMII_RXC 0x1b030 177*724ba675SRob Herring MX6QDL_PAD_RGMII_RD0__RGMII_RD0 0x1b030 178*724ba675SRob Herring MX6QDL_PAD_RGMII_RD1__RGMII_RD1 0x1b030 179*724ba675SRob Herring MX6QDL_PAD_RGMII_RD2__RGMII_RD2 0x1b030 180*724ba675SRob Herring MX6QDL_PAD_RGMII_RD3__RGMII_RD3 0x1b030 181*724ba675SRob Herring MX6QDL_PAD_RGMII_RX_CTL__RGMII_RX_CTL 0x1b030 182*724ba675SRob Herring MX6QDL_PAD_GPIO_16__ENET_REF_CLK 0x4001b0a8 183*724ba675SRob Herring >; 184*724ba675SRob Herring }; 185*724ba675SRob Herring 186*724ba675SRob Herring pinctrl_i2c1: i2c1grp { 187*724ba675SRob Herring fsl,pins = < 188*724ba675SRob Herring MX6QDL_PAD_EIM_D21__I2C1_SCL 0x4001b8b1 189*724ba675SRob Herring MX6QDL_PAD_EIM_D28__I2C1_SDA 0x4001b8b1 190*724ba675SRob Herring >; 191*724ba675SRob Herring }; 192*724ba675SRob Herring 193*724ba675SRob Herring pinctrl_i2c1_gpio: i2c1gpiogrp { 194*724ba675SRob Herring fsl,pins = < 195*724ba675SRob Herring MX6QDL_PAD_EIM_D21__GPIO3_IO21 0x4001b8b0 196*724ba675SRob Herring MX6QDL_PAD_EIM_D28__GPIO3_IO28 0x4001b8b0 197*724ba675SRob Herring >; 198*724ba675SRob Herring }; 199*724ba675SRob Herring 200*724ba675SRob Herring pinctrl_i2c2: i2c2grp { 201*724ba675SRob Herring fsl,pins = < 202*724ba675SRob Herring MX6QDL_PAD_KEY_COL3__I2C2_SCL 0x4001b8b1 203*724ba675SRob Herring MX6QDL_PAD_KEY_ROW3__I2C2_SDA 0x4001b8b1 204*724ba675SRob Herring >; 205*724ba675SRob Herring }; 206*724ba675SRob Herring 207*724ba675SRob Herring pinctrl_i2c2_gpio: i2c2gpiogrp { 208*724ba675SRob Herring fsl,pins = < 209*724ba675SRob Herring MX6QDL_PAD_KEY_COL3__GPIO4_IO12 0x4001b8b0 210*724ba675SRob Herring MX6QDL_PAD_KEY_ROW3__GPIO4_IO13 0x4001b8b0 211*724ba675SRob Herring >; 212*724ba675SRob Herring }; 213*724ba675SRob Herring 214*724ba675SRob Herring pinctrl_mclk: mclkgrp { 215*724ba675SRob Herring fsl,pins = < 216*724ba675SRob Herring MX6QDL_PAD_GPIO_0__CCM_CLKO1 0x130b0 217*724ba675SRob Herring >; 218*724ba675SRob Herring }; 219*724ba675SRob Herring 220*724ba675SRob Herring pinctrl_ov5645: ov5645grp { 221*724ba675SRob Herring fsl,pins = < 222*724ba675SRob Herring MX6QDL_PAD_GPIO_3__CCM_CLKO2 0x000b0 223*724ba675SRob Herring MX6QDL_PAD_GPIO_6__GPIO1_IO06 0x1b0b0 224*724ba675SRob Herring MX6QDL_PAD_KEY_COL4__GPIO4_IO14 0x1b0b0 225*724ba675SRob Herring >; 226*724ba675SRob Herring }; 227*724ba675SRob Herring 228*724ba675SRob Herring pinctrl_spdif: spdifgrp { 229*724ba675SRob Herring fsl,pins = < 230*724ba675SRob Herring MX6QDL_PAD_ENET_RXD0__SPDIF_OUT 0x1b0b0 231*724ba675SRob Herring >; 232*724ba675SRob Herring }; 233*724ba675SRob Herring 234*724ba675SRob Herring pinctrl_uart1: uart1grp { 235*724ba675SRob Herring fsl,pins = < 236*724ba675SRob Herring MX6QDL_PAD_CSI0_DAT10__UART1_TX_DATA 0x1b0b1 237*724ba675SRob Herring MX6QDL_PAD_CSI0_DAT11__UART1_RX_DATA 0x1b0b1 238*724ba675SRob Herring >; 239*724ba675SRob Herring }; 240*724ba675SRob Herring 241*724ba675SRob Herring pinctrl_uart3: uart3grp { 242*724ba675SRob Herring fsl,pins = < 243*724ba675SRob Herring MX6QDL_PAD_EIM_D24__UART3_TX_DATA 0x1b0b1 244*724ba675SRob Herring MX6QDL_PAD_EIM_D25__UART3_RX_DATA 0x1b0b1 245*724ba675SRob Herring MX6QDL_PAD_EIM_D23__UART3_CTS_B 0x1b0b1 246*724ba675SRob Herring MX6QDL_PAD_EIM_EB3__UART3_RTS_B 0x1b0b1 247*724ba675SRob Herring >; 248*724ba675SRob Herring }; 249*724ba675SRob Herring 250*724ba675SRob Herring pinctrl_usbotg: usbotggrp { 251*724ba675SRob Herring fsl,pins = < 252*724ba675SRob Herring MX6QDL_PAD_GPIO_1__USB_OTG_ID 0x17059 253*724ba675SRob Herring >; 254*724ba675SRob Herring }; 255*724ba675SRob Herring 256*724ba675SRob Herring pinctrl_usbotgvbus: usbotgvbusgrp { 257*724ba675SRob Herring fsl,pins = < 258*724ba675SRob Herring MX6QDL_PAD_EIM_D22__GPIO3_IO22 0x130b0 259*724ba675SRob Herring >; 260*724ba675SRob Herring }; 261*724ba675SRob Herring 262*724ba675SRob Herring pinctrl_usdhc1: usdhc1grp { 263*724ba675SRob Herring fsl,pins = < 264*724ba675SRob Herring MX6QDL_PAD_SD1_CMD__SD1_CMD 0x17059 265*724ba675SRob Herring MX6QDL_PAD_SD1_CLK__SD1_CLK 0x10059 266*724ba675SRob Herring MX6QDL_PAD_SD1_DAT0__SD1_DATA0 0x17059 267*724ba675SRob Herring MX6QDL_PAD_SD1_DAT1__SD1_DATA1 0x17059 268*724ba675SRob Herring MX6QDL_PAD_SD1_DAT2__SD1_DATA2 0x17059 269*724ba675SRob Herring MX6QDL_PAD_SD1_DAT3__SD1_DATA3 0x17059 270*724ba675SRob Herring >; 271*724ba675SRob Herring }; 272*724ba675SRob Herring 273*724ba675SRob Herring pinctrl_usdhc2: usdhc2grp { 274*724ba675SRob Herring fsl,pins = < 275*724ba675SRob Herring MX6QDL_PAD_SD2_CMD__SD2_CMD 0x17059 276*724ba675SRob Herring MX6QDL_PAD_SD2_CLK__SD2_CLK 0x10059 277*724ba675SRob Herring MX6QDL_PAD_SD2_DAT0__SD2_DATA0 0x17059 278*724ba675SRob Herring MX6QDL_PAD_SD2_DAT1__SD2_DATA1 0x17059 279*724ba675SRob Herring MX6QDL_PAD_SD2_DAT2__SD2_DATA2 0x17059 280*724ba675SRob Herring MX6QDL_PAD_SD2_DAT3__SD2_DATA3 0x17059 281*724ba675SRob Herring >; 282*724ba675SRob Herring }; 283*724ba675SRob Herring 284*724ba675SRob Herring pinctrl_usdhc3: usdhc3grp { 285*724ba675SRob Herring fsl,pins = < 286*724ba675SRob Herring MX6QDL_PAD_SD3_CMD__SD3_CMD 0x17059 287*724ba675SRob Herring MX6QDL_PAD_SD3_CLK__SD3_CLK 0x10059 288*724ba675SRob Herring MX6QDL_PAD_SD3_DAT0__SD3_DATA0 0x17059 289*724ba675SRob Herring MX6QDL_PAD_SD3_DAT1__SD3_DATA1 0x17059 290*724ba675SRob Herring MX6QDL_PAD_SD3_DAT2__SD3_DATA2 0x17059 291*724ba675SRob Herring MX6QDL_PAD_SD3_DAT3__SD3_DATA3 0x17059 292*724ba675SRob Herring >; 293*724ba675SRob Herring }; 294*724ba675SRob Herring }; 295*724ba675SRob Herring}; 296*724ba675SRob Herring 297*724ba675SRob Herring&fec { 298*724ba675SRob Herring pinctrl-names = "default"; 299*724ba675SRob Herring pinctrl-0 = <&pinctrl_enet>; 300*724ba675SRob Herring phy-mode = "rgmii-id"; 301*724ba675SRob Herring phy-handle = <ðphy>; 302*724ba675SRob Herring phy-reset-gpios = <&gpio3 29 GPIO_ACTIVE_LOW>; 303*724ba675SRob Herring status = "okay"; 304*724ba675SRob Herring 305*724ba675SRob Herring mdio { 306*724ba675SRob Herring #address-cells = <1>; 307*724ba675SRob Herring #size-cells = <0>; 308*724ba675SRob Herring 309*724ba675SRob Herring ethphy: ethernet-phy@1 { 310*724ba675SRob Herring reg = <1>; 311*724ba675SRob Herring qca,clk-out-frequency = <125000000>; 312*724ba675SRob Herring }; 313*724ba675SRob Herring }; 314*724ba675SRob Herring}; 315*724ba675SRob Herring 316*724ba675SRob Herring&mipi_csi { 317*724ba675SRob Herring status = "okay"; 318*724ba675SRob Herring 319*724ba675SRob Herring port@0 { 320*724ba675SRob Herring reg = <0>; 321*724ba675SRob Herring 322*724ba675SRob Herring mipi_csi2_in: endpoint { 323*724ba675SRob Herring remote-endpoint = <&ov5645_to_mipi_csi2>; 324*724ba675SRob Herring clock-lanes = <0>; 325*724ba675SRob Herring data-lanes = <1 2>; 326*724ba675SRob Herring }; 327*724ba675SRob Herring }; 328*724ba675SRob Herring}; 329*724ba675SRob Herring 330*724ba675SRob Herring&spdif { 331*724ba675SRob Herring pinctrl-names = "default"; 332*724ba675SRob Herring pinctrl-0 = <&pinctrl_spdif>; 333*724ba675SRob Herring status = "okay"; 334*724ba675SRob Herring}; 335*724ba675SRob Herring 336*724ba675SRob Herring&ssi1 { 337*724ba675SRob Herring status = "okay"; 338*724ba675SRob Herring}; 339*724ba675SRob Herring 340*724ba675SRob Herring&uart1 { 341*724ba675SRob Herring pinctrl-names = "default"; 342*724ba675SRob Herring pinctrl-0 = <&pinctrl_uart1>; 343*724ba675SRob Herring status = "okay"; 344*724ba675SRob Herring}; 345*724ba675SRob Herring 346*724ba675SRob Herring&uart3 { 347*724ba675SRob Herring pinctrl-names = "default"; 348*724ba675SRob Herring pinctrl-0 = <&pinctrl_uart3>; 349*724ba675SRob Herring uart-has-rtscts; 350*724ba675SRob Herring status = "okay"; 351*724ba675SRob Herring}; 352*724ba675SRob Herring 353*724ba675SRob Herring&usbh1 { 354*724ba675SRob Herring status = "okay"; 355*724ba675SRob Herring}; 356*724ba675SRob Herring 357*724ba675SRob Herring&usbotg { 358*724ba675SRob Herring vbus-supply = <®_usb_otg_vbus>; 359*724ba675SRob Herring pinctrl-names = "default"; 360*724ba675SRob Herring pinctrl-0 = <&pinctrl_usbotg>; 361*724ba675SRob Herring disable-over-current; 362*724ba675SRob Herring dr_mode = "otg"; 363*724ba675SRob Herring status = "okay"; 364*724ba675SRob Herring}; 365*724ba675SRob Herring 366*724ba675SRob Herring&usdhc1 { 367*724ba675SRob Herring pinctrl-names = "default"; 368*724ba675SRob Herring pinctrl-0 = <&pinctrl_usdhc1>; 369*724ba675SRob Herring cd-gpios = <&gpio1 2 GPIO_ACTIVE_LOW>; 370*724ba675SRob Herring status = "okay"; 371*724ba675SRob Herring}; 372*724ba675SRob Herring 373*724ba675SRob Herring&usdhc3 { 374*724ba675SRob Herring pinctrl-names = "default"; 375*724ba675SRob Herring pinctrl-0 = <&pinctrl_usdhc3>; 376*724ba675SRob Herring cd-gpios = <&gpio3 9 GPIO_ACTIVE_LOW>; 377*724ba675SRob Herring status = "okay"; 378*724ba675SRob Herring}; 379