1724ba675SRob Herring// SPDX-License-Identifier: GPL-2.0 2724ba675SRob Herring/* 3724ba675SRob Herring * Copyright 2013 Freescale Semiconductor, Inc. 4724ba675SRob Herring * 5724ba675SRob Herring * Author: Fabio Estevam <fabio.estevam@freescale.com> 6724ba675SRob Herring */ 7724ba675SRob Herring 8724ba675SRob Herring#include <dt-bindings/gpio/gpio.h> 9724ba675SRob Herring 10724ba675SRob Herring/ { 11724ba675SRob Herring aliases { 12724ba675SRob Herring backlight = &backlight; 13724ba675SRob Herring panelchan = &panelchan; 14724ba675SRob Herring panel7 = &panel7; 15724ba675SRob Herring touchscreenp7 = &touchscreenp7; 16724ba675SRob Herring }; 17724ba675SRob Herring 18724ba675SRob Herring chosen { 19724ba675SRob Herring stdout-path = &uart2; 20724ba675SRob Herring }; 21724ba675SRob Herring 22724ba675SRob Herring backlight: backlight { 23724ba675SRob Herring compatible = "gpio-backlight"; 24724ba675SRob Herring gpios = <&gpio1 4 0>; 25724ba675SRob Herring default-on; 26724ba675SRob Herring status = "disabled"; 27724ba675SRob Herring }; 28724ba675SRob Herring 29724ba675SRob Herring gpio-poweroff { 30724ba675SRob Herring compatible = "gpio-poweroff"; 31724ba675SRob Herring gpios = <&gpio2 4 0>; 32724ba675SRob Herring pinctrl-0 = <&pinctrl_power_off>; 33724ba675SRob Herring pinctrl-names = "default"; 34724ba675SRob Herring }; 35724ba675SRob Herring 36724ba675SRob Herring memory@10000000 { 37724ba675SRob Herring device_type = "memory"; 38724ba675SRob Herring reg = <0x10000000 0x40000000>; 39724ba675SRob Herring }; 40724ba675SRob Herring 41724ba675SRob Herring panel7: panel7 { 42724ba675SRob Herring /* 43724ba675SRob Herring * in reality it is a -20t (parallel) model, 44724ba675SRob Herring * but with LVDS bridge chip attached, 45724ba675SRob Herring * so it is equivalent to -19t model in drive 46724ba675SRob Herring * characteristics 47724ba675SRob Herring */ 48724ba675SRob Herring compatible = "urt,umsh-8596md-19t"; 49724ba675SRob Herring pinctrl-names = "default"; 50724ba675SRob Herring pinctrl-0 = <&pinctrl_panel>; 51724ba675SRob Herring power-supply = <®_panel>; 52724ba675SRob Herring backlight = <&backlight>; 53724ba675SRob Herring status = "disabled"; 54724ba675SRob Herring 55724ba675SRob Herring port { 56724ba675SRob Herring panel_in: endpoint { 57724ba675SRob Herring remote-endpoint = <&lvds0_out>; 58724ba675SRob Herring }; 59724ba675SRob Herring }; 60724ba675SRob Herring }; 61724ba675SRob Herring 62*ec20d468SFabio Estevam reg_usb_h1_vbus: regulator-usb-h1-vbus { 63724ba675SRob Herring compatible = "regulator-fixed"; 64724ba675SRob Herring regulator-name = "usb_h1_vbus"; 65724ba675SRob Herring regulator-min-microvolt = <5000000>; 66724ba675SRob Herring regulator-max-microvolt = <5000000>; 67724ba675SRob Herring enable-active-high; 68724ba675SRob Herring startup-delay-us = <2>; /* USB2415 requires a POR of 1 us minimum */ 69724ba675SRob Herring gpio = <&gpio7 12 0>; 70724ba675SRob Herring }; 71724ba675SRob Herring 72*ec20d468SFabio Estevam reg_panel: regulator-panel { 73724ba675SRob Herring compatible = "regulator-fixed"; 74724ba675SRob Herring regulator-name = "lcd_panel"; 75724ba675SRob Herring enable-active-high; 76724ba675SRob Herring gpio = <&gpio1 2 0>; 77724ba675SRob Herring }; 78724ba675SRob Herring 79724ba675SRob Herring sound { 80724ba675SRob Herring compatible = "fsl,imx6q-udoo-ac97", 81724ba675SRob Herring "fsl,imx-audio-ac97"; 82724ba675SRob Herring model = "fsl,imx6q-udoo-ac97"; 83724ba675SRob Herring audio-cpu = <&ssi1>; 84724ba675SRob Herring audio-routing = 85724ba675SRob Herring "RX", "Mic Jack", 86724ba675SRob Herring "Headphone Jack", "TX"; 87724ba675SRob Herring mux-int-port = <1>; 88724ba675SRob Herring mux-ext-port = <6>; 89724ba675SRob Herring }; 90724ba675SRob Herring}; 91724ba675SRob Herring 92724ba675SRob Herring&fec { 93724ba675SRob Herring pinctrl-names = "default"; 94724ba675SRob Herring pinctrl-0 = <&pinctrl_enet>; 95724ba675SRob Herring phy-mode = "rgmii-id"; 96724ba675SRob Herring status = "okay"; 97724ba675SRob Herring}; 98724ba675SRob Herring 99724ba675SRob Herring&hdmi { 100724ba675SRob Herring ddc-i2c-bus = <&i2c2>; 101724ba675SRob Herring status = "okay"; 102724ba675SRob Herring}; 103724ba675SRob Herring 104724ba675SRob Herring&i2c2 { 105724ba675SRob Herring clock-frequency = <100000>; 106724ba675SRob Herring pinctrl-names = "default"; 107724ba675SRob Herring pinctrl-0 = <&pinctrl_i2c2>; 108724ba675SRob Herring status = "okay"; 109724ba675SRob Herring}; 110724ba675SRob Herring 111724ba675SRob Herring&i2c3 { 112724ba675SRob Herring clock-frequency = <100000>; 113724ba675SRob Herring pinctrl-names = "default"; 114724ba675SRob Herring pinctrl-0 = <&pinctrl_i2c3>; 115724ba675SRob Herring status = "okay"; 116724ba675SRob Herring 117724ba675SRob Herring touchscreenp7: touchscreenp7@55 { 118724ba675SRob Herring compatible = "sitronix,st1232"; 119724ba675SRob Herring pinctrl-names = "default"; 120724ba675SRob Herring pinctrl-0 = <&pinctrl_touchscreenp7>; 121724ba675SRob Herring reg = <0x55>; 122724ba675SRob Herring interrupt-parent = <&gpio1>; 123724ba675SRob Herring interrupts = <13 8>; 124724ba675SRob Herring gpios = <&gpio1 15 0>; 125724ba675SRob Herring status = "disabled"; 126724ba675SRob Herring }; 127724ba675SRob Herring}; 128724ba675SRob Herring 129724ba675SRob Herring&iomuxc { 130724ba675SRob Herring imx6q-udoo { 131724ba675SRob Herring pinctrl_enet: enetgrp { 132724ba675SRob Herring fsl,pins = < 133724ba675SRob Herring MX6QDL_PAD_RGMII_RXC__RGMII_RXC 0x1b030 134724ba675SRob Herring MX6QDL_PAD_RGMII_RD0__RGMII_RD0 0x1b030 135724ba675SRob Herring MX6QDL_PAD_RGMII_RD1__RGMII_RD1 0x1b030 136724ba675SRob Herring MX6QDL_PAD_RGMII_RD2__RGMII_RD2 0x1b030 137724ba675SRob Herring MX6QDL_PAD_RGMII_RD3__RGMII_RD3 0x1b030 138724ba675SRob Herring MX6QDL_PAD_RGMII_RX_CTL__RGMII_RX_CTL 0x1b030 139724ba675SRob Herring MX6QDL_PAD_RGMII_TXC__RGMII_TXC 0x1b030 140724ba675SRob Herring MX6QDL_PAD_RGMII_TD0__RGMII_TD0 0x1b030 141724ba675SRob Herring MX6QDL_PAD_RGMII_TD1__RGMII_TD1 0x1b030 142724ba675SRob Herring MX6QDL_PAD_RGMII_TD2__RGMII_TD2 0x1b030 143724ba675SRob Herring MX6QDL_PAD_RGMII_TD3__RGMII_TD3 0x1b030 144724ba675SRob Herring MX6QDL_PAD_RGMII_TX_CTL__RGMII_TX_CTL 0x1b030 145724ba675SRob Herring MX6QDL_PAD_ENET_REF_CLK__ENET_TX_CLK 0x1b0b0 146724ba675SRob Herring MX6QDL_PAD_ENET_MDIO__ENET_MDIO 0x1b0b0 147724ba675SRob Herring MX6QDL_PAD_ENET_MDC__ENET_MDC 0x1b0b0 148724ba675SRob Herring MX6QDL_PAD_GPIO_16__ENET_REF_CLK 0x4001b0a8 149724ba675SRob Herring >; 150724ba675SRob Herring }; 151724ba675SRob Herring 152724ba675SRob Herring pinctrl_i2c2: i2c2grp { 153724ba675SRob Herring fsl,pins = < 154724ba675SRob Herring MX6QDL_PAD_KEY_COL3__I2C2_SCL 0x4001b8b1 155724ba675SRob Herring MX6QDL_PAD_KEY_ROW3__I2C2_SDA 0x4001b8b1 156724ba675SRob Herring >; 157724ba675SRob Herring }; 158724ba675SRob Herring 159724ba675SRob Herring pinctrl_i2c3: i2c3grp { 160724ba675SRob Herring fsl,pins = < 161724ba675SRob Herring MX6QDL_PAD_GPIO_5__I2C3_SCL 0x4001f8b1 162724ba675SRob Herring MX6QDL_PAD_GPIO_6__I2C3_SDA 0x4001f8b1 163724ba675SRob Herring >; 164724ba675SRob Herring }; 165724ba675SRob Herring 166724ba675SRob Herring pinctrl_panel: panelgrp { 167724ba675SRob Herring fsl,pins = < 168724ba675SRob Herring MX6QDL_PAD_GPIO_2__GPIO1_IO02 0x70 169724ba675SRob Herring MX6QDL_PAD_GPIO_4__GPIO1_IO04 0x70 170724ba675SRob Herring >; 171724ba675SRob Herring }; 172724ba675SRob Herring 173724ba675SRob Herring pinctrl_power_off: poweroffgrp { 174724ba675SRob Herring fsl,pins = < 175724ba675SRob Herring MX6QDL_PAD_NANDF_D4__GPIO2_IO04 0x30 176724ba675SRob Herring >; 177724ba675SRob Herring }; 178724ba675SRob Herring 179724ba675SRob Herring pinctrl_touchscreenp7: touchscreenp7grp { 180724ba675SRob Herring fsl,pins = < 181724ba675SRob Herring MX6QDL_PAD_SD2_DAT0__GPIO1_IO15 0x70 182724ba675SRob Herring MX6QDL_PAD_SD2_DAT2__GPIO1_IO13 0x1b0b0 183724ba675SRob Herring >; 184724ba675SRob Herring }; 185724ba675SRob Herring 186724ba675SRob Herring pinctrl_uart2: uart2grp { 187724ba675SRob Herring fsl,pins = < 188724ba675SRob Herring MX6QDL_PAD_EIM_D26__UART2_TX_DATA 0x1b0b1 189724ba675SRob Herring MX6QDL_PAD_EIM_D27__UART2_RX_DATA 0x1b0b1 190724ba675SRob Herring >; 191724ba675SRob Herring }; 192724ba675SRob Herring 193724ba675SRob Herring pinctrl_uart4: uart4grp { 194724ba675SRob Herring fsl,pins = < 195724ba675SRob Herring MX6QDL_PAD_KEY_COL0__UART4_TX_DATA 0x1b0b1 196724ba675SRob Herring MX6QDL_PAD_KEY_ROW0__UART4_RX_DATA 0x1b0b1 197724ba675SRob Herring >; 198724ba675SRob Herring }; 199724ba675SRob Herring 200724ba675SRob Herring pinctrl_usbh: usbhgrp { 201724ba675SRob Herring fsl,pins = < 202724ba675SRob Herring MX6QDL_PAD_GPIO_17__GPIO7_IO12 0x80000000 203724ba675SRob Herring MX6QDL_PAD_NANDF_CS2__CCM_CLKO2 0x130b0 204724ba675SRob Herring >; 205724ba675SRob Herring }; 206724ba675SRob Herring 207724ba675SRob Herring pinctrl_usbotg: usbotg { 208724ba675SRob Herring fsl,pins = < 209724ba675SRob Herring MX6QDL_PAD_GPIO_1__USB_OTG_ID 0x17059 210724ba675SRob Herring MX6QDL_PAD_EIM_D22__USB_OTG_PWR 0x17059 211724ba675SRob Herring MX6QDL_PAD_EIM_D21__USB_OTG_OC 0x17059 212724ba675SRob Herring >; 213724ba675SRob Herring }; 214724ba675SRob Herring 215724ba675SRob Herring pinctrl_usdhc3: usdhc3grp { 216724ba675SRob Herring fsl,pins = < 217724ba675SRob Herring MX6QDL_PAD_SD3_CMD__SD3_CMD 0x17059 218724ba675SRob Herring MX6QDL_PAD_SD3_CLK__SD3_CLK 0x10059 219724ba675SRob Herring MX6QDL_PAD_SD3_DAT0__SD3_DATA0 0x17059 220724ba675SRob Herring MX6QDL_PAD_SD3_DAT1__SD3_DATA1 0x17059 221724ba675SRob Herring MX6QDL_PAD_SD3_DAT2__SD3_DATA2 0x17059 222724ba675SRob Herring MX6QDL_PAD_SD3_DAT3__SD3_DATA3 0x17059 223724ba675SRob Herring MX6QDL_PAD_SD3_DAT5__GPIO7_IO00 0x1b0b0 224724ba675SRob Herring >; 225724ba675SRob Herring }; 226724ba675SRob Herring 227724ba675SRob Herring pinctrl_ac97_running: ac97running { 228724ba675SRob Herring fsl,pins = < 229724ba675SRob Herring MX6QDL_PAD_DI0_PIN2__AUD6_TXD 0x1b0b0 230724ba675SRob Herring MX6QDL_PAD_DI0_PIN3__AUD6_TXFS 0x1b0b0 231724ba675SRob Herring MX6QDL_PAD_DI0_PIN4__AUD6_RXD 0x13080 232724ba675SRob Herring MX6QDL_PAD_DI0_PIN15__AUD6_TXC 0x13080 233724ba675SRob Herring MX6QDL_PAD_EIM_EB2__GPIO2_IO30 0x1b0b0 234724ba675SRob Herring >; 235724ba675SRob Herring }; 236724ba675SRob Herring 237724ba675SRob Herring pinctrl_ac97_warm_reset: ac97warmreset { 238724ba675SRob Herring fsl,pins = < 239724ba675SRob Herring MX6QDL_PAD_DI0_PIN2__AUD6_TXD 0x1b0b0 240724ba675SRob Herring MX6QDL_PAD_DI0_PIN3__GPIO4_IO19 0x1b0b0 241724ba675SRob Herring MX6QDL_PAD_DI0_PIN4__AUD6_RXD 0x13080 242724ba675SRob Herring MX6QDL_PAD_DI0_PIN15__AUD6_TXC 0x13080 243724ba675SRob Herring MX6QDL_PAD_EIM_EB2__GPIO2_IO30 0x1b0b0 244724ba675SRob Herring >; 245724ba675SRob Herring }; 246724ba675SRob Herring 247724ba675SRob Herring pinctrl_ac97_reset: ac97reset { 248724ba675SRob Herring fsl,pins = < 249724ba675SRob Herring MX6QDL_PAD_DI0_PIN2__GPIO4_IO18 0x1b0b0 250724ba675SRob Herring MX6QDL_PAD_DI0_PIN3__GPIO4_IO19 0x1b0b0 251724ba675SRob Herring MX6QDL_PAD_DI0_PIN4__AUD6_RXD 0x13080 252724ba675SRob Herring MX6QDL_PAD_DI0_PIN15__AUD6_TXC 0x13080 253724ba675SRob Herring MX6QDL_PAD_EIM_EB2__GPIO2_IO30 0x1b0b0 254724ba675SRob Herring >; 255724ba675SRob Herring }; 256724ba675SRob Herring }; 257724ba675SRob Herring}; 258724ba675SRob Herring 259724ba675SRob Herring&ldb { 260724ba675SRob Herring status = "okay"; 261724ba675SRob Herring 262724ba675SRob Herring panelchan: lvds-channel@0 { 263724ba675SRob Herring port@4 { 264724ba675SRob Herring reg = <4>; 265724ba675SRob Herring 266724ba675SRob Herring lvds0_out: endpoint { 267724ba675SRob Herring remote-endpoint = <&panel_in>; 268724ba675SRob Herring }; 269724ba675SRob Herring }; 270724ba675SRob Herring }; 271724ba675SRob Herring}; 272724ba675SRob Herring 273724ba675SRob Herring&uart2 { 274724ba675SRob Herring pinctrl-names = "default"; 275724ba675SRob Herring pinctrl-0 = <&pinctrl_uart2>; 276724ba675SRob Herring status = "okay"; 277724ba675SRob Herring}; 278724ba675SRob Herring 279724ba675SRob Herring&uart4 { 280724ba675SRob Herring pinctrl-names = "default"; 281724ba675SRob Herring pinctrl-0 = <&pinctrl_uart4>; 282724ba675SRob Herring status = "okay"; 283724ba675SRob Herring}; 284724ba675SRob Herring 285724ba675SRob Herring&usbh1 { 286724ba675SRob Herring pinctrl-names = "default"; 287724ba675SRob Herring pinctrl-0 = <&pinctrl_usbh>; 288724ba675SRob Herring vbus-supply = <®_usb_h1_vbus>; 289724ba675SRob Herring clocks = <&clks IMX6QDL_CLK_CKO>; 290724ba675SRob Herring status = "disabled"; 291724ba675SRob Herring}; 292724ba675SRob Herring 293724ba675SRob Herring&usbotg { 294724ba675SRob Herring pinctrl-names = "default"; 295724ba675SRob Herring pinctrl-0 = <&pinctrl_usbotg>; 296724ba675SRob Herring status = "okay"; 297724ba675SRob Herring}; 298724ba675SRob Herring 299724ba675SRob Herring&usdhc3 { 300724ba675SRob Herring pinctrl-names = "default"; 301724ba675SRob Herring pinctrl-0 = <&pinctrl_usdhc3>; 302724ba675SRob Herring cd-gpios = <&gpio7 0 GPIO_ACTIVE_LOW>; 303724ba675SRob Herring status = "okay"; 304724ba675SRob Herring}; 305724ba675SRob Herring 306724ba675SRob Herring&audmux { 307724ba675SRob Herring status = "okay"; 308724ba675SRob Herring}; 309724ba675SRob Herring 310724ba675SRob Herring&ssi1 { 311724ba675SRob Herring cell-index = <0>; 312724ba675SRob Herring fsl,mode = "ac97-slave"; 313724ba675SRob Herring pinctrl-names = "ac97-running", "ac97-reset", "ac97-warm-reset"; 314724ba675SRob Herring pinctrl-0 = <&pinctrl_ac97_running>; 315724ba675SRob Herring pinctrl-1 = <&pinctrl_ac97_reset>; 316724ba675SRob Herring pinctrl-2 = <&pinctrl_ac97_warm_reset>; 317724ba675SRob Herring ac97-gpios = <&gpio4 19 0 &gpio4 18 0 &gpio2 30 0>; 318724ba675SRob Herring status = "okay"; 319724ba675SRob Herring}; 320