2 * Copyright (C) 2017 NutsBoard.Org
4 * Author: Wig Cheng <onlywig@gmail.com>
6 * This file is dual-licensed: you can use it either under the terms
7 * of the GPL or the X11 license, at your option. Note that this dual
8 * licensing only applies to this file, and not this project as a
11 * a) This file is free software; you can redistribute it and/or
12 * modify it under the terms of the GNU General Public License as
13 * published by the Free Software Foundation; either version 2 of the
14 * License, or (at your option) any later version.
16 * This file is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * GNU General Public License for more details.
23 * b) Permission is hereby granted, free of charge, to any person
24 * obtaining a copy of this software and associated documentation
25 * files (the "Software"), to deal in the Software without
26 * restriction, including without limitation the rights to use,
27 * copy, modify, merge, publish, distribute, sublicense, and/or
28 * sell copies of the Software, and to permit persons to whom the
29 * Software is furnished to do so, subject to the following
32 * The above copyright notice and this permission notice shall be
33 * included in all copies or substantial portions of the Software.
35 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
36 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
37 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
38 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
39 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
40 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
41 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
42 * OTHER DEALINGS IN THE SOFTWARE.
47 #include <dt-bindings/gpio/gpio.h>
48 #include <dt-bindings/input/input.h>
52 model = "NutsBoard i.MX6 Quad Pistachio board";
53 compatible = "nutsboard,imx6q-pistachio", "fsl,imx6q";
60 device_type = "memory";
61 reg = <0x10000000 0x80000000>;
64 reg_3p3v: regulator-3p3v {
65 compatible = "regulator-fixed";
66 regulator-name = "3P3V";
67 regulator-min-microvolt = <3300000>;
68 regulator-max-microvolt = <3300000>;
71 reg_1p8v: regulator-1p8v {
72 compatible = "regulator-fixed";
73 regulator-name = "1P8V";
74 regulator-min-microvolt = <1800000>;
75 regulator-max-microvolt = <1800000>;
78 wlan_en_reg: regulator-wlan_en {
79 compatible = "regulator-fixed";
80 regulator-name = "wlan-en-regulator";
81 regulator-min-microvolt = <1800000>;
82 regulator-max-microvolt = <1800000>;
83 gpio = <&gpio2 24 GPIO_ACTIVE_HIGH>;
84 startup-delay-us = <70000>;
88 reg_usb_otg_vbus: regulator-usb_vbus {
89 compatible = "regulator-fixed";
90 regulator-name = "usb_otg_vbus";
91 regulator-min-microvolt = <5000000>;
92 regulator-max-microvolt = <5000000>;
93 gpio = <&gpio3 22 GPIO_ACTIVE_HIGH>;
95 vin-supply = <&swbst_reg>;
99 compatible = "gpio-keys";
100 pinctrl-names = "default";
101 pinctrl-0 = <&pinctrl_gpio_keys>;
104 label = "Power Button";
105 gpios = <&gpio2 12 GPIO_ACTIVE_LOW>;
107 linux,code = <KEY_POWER>;
112 compatible = "fsl,imx-sgtl5000",
113 "fsl,imx-audio-sgtl5000";
114 model = "audio-sgtl5000";
115 ssi-controller = <&ssi1>;
116 audio-codec = <&codec>;
118 "MIC_IN", "Mic Jack",
119 "Mic Jack", "Mic Bias",
120 "Headphone Jack", "HP_OUT";
125 backlight_lvds: backlight-lvds {
126 compatible = "pwm-backlight";
127 pwms = <&pwm1 0 50000>;
128 brightness-levels = <
129 0 /*1 2 3 4 5 6*/ 7 8 9
130 10 11 12 13 14 15 16 17 18 19
131 20 21 22 23 24 25 26 27 28 29
132 30 31 32 33 34 35 36 37 38 39
133 40 41 42 43 44 45 46 47 48 49
134 50 51 52 53 54 55 56 57 58 59
135 60 61 62 63 64 65 66 67 68 69
136 70 71 72 73 74 75 76 77 78 79
137 80 81 82 83 84 85 86 87 88 89
138 90 91 92 93 94 95 96 97 98 99
141 default-brightness-level = <94>;
146 compatible = "hannstar,hsd100pxn1";
147 backlight = <&backlight_lvds>;
151 remote-endpoint = <&lvds0_out>;
158 pinctrl-names = "default";
159 pinctrl-0 = <&pinctrl_audmux>;
164 pinctrl-names = "default";
165 pinctrl-0 = <&pinctrl_flexcan2>;
170 assigned-clocks = <&clks IMX6QDL_CLK_LDB_DI0_SEL>,
171 <&clks IMX6QDL_CLK_LDB_DI1_SEL>;
172 assigned-clock-parents = <&clks IMX6QDL_CLK_PLL3_USB_OTG>,
173 <&clks IMX6QDL_CLK_PLL3_USB_OTG>;
177 pinctrl-names = "default";
178 pinctrl-0 = <&pinctrl_enet>;
184 ddc-i2c-bus = <&i2c2>;
189 clock-frequency = <100000>;
190 pinctrl-names = "default";
191 pinctrl-0 = <&pinctrl_i2c1>;
195 compatible = "fsl,sgtl5000";
196 pinctrl-names = "default";
197 pinctrl-0 = <&pinctrl_i2c1_sgtl5000>;
199 clocks = <&clks IMX6QDL_CLK_CKO>;
200 VDDA-supply = <®_1p8v>;
201 VDDIO-supply = <®_1p8v>;
206 clock-frequency = <100000>;
207 pinctrl-names = "default";
208 pinctrl-0 = <&pinctrl_i2c2>;
212 compatible = "fsl,pfuze100";
217 regulator-min-microvolt = <300000>;
218 regulator-max-microvolt = <1875000>;
221 regulator-ramp-delay = <6250>;
225 regulator-min-microvolt = <300000>;
226 regulator-max-microvolt = <1875000>;
229 regulator-ramp-delay = <6250>;
233 regulator-min-microvolt = <800000>;
234 regulator-max-microvolt = <3300000>;
237 regulator-ramp-delay = <6250>;
241 regulator-min-microvolt = <400000>;
242 regulator-max-microvolt = <1975000>;
248 regulator-min-microvolt = <400000>;
249 regulator-max-microvolt = <1975000>;
255 regulator-min-microvolt = <800000>;
256 regulator-max-microvolt = <3300000>;
260 regulator-min-microvolt = <5000000>;
261 regulator-max-microvolt = <5150000>;
265 regulator-min-microvolt = <1000000>;
266 regulator-max-microvolt = <3000000>;
277 regulator-min-microvolt = <800000>;
278 regulator-max-microvolt = <1550000>;
282 regulator-min-microvolt = <800000>;
283 regulator-max-microvolt = <1550000>;
287 regulator-min-microvolt = <1800000>;
288 regulator-max-microvolt = <3300000>;
292 regulator-min-microvolt = <1800000>;
293 regulator-max-microvolt = <3300000>;
298 regulator-min-microvolt = <1800000>;
299 regulator-max-microvolt = <3300000>;
303 regulator-min-microvolt = <1800000>;
304 regulator-max-microvolt = <3300000>;
311 compatible = "microchip,ar1021-i2c";
313 interrupt-parent = <&gpio6>;
314 interrupts = <8 IRQ_TYPE_EDGE_FALLING>;
319 clock-frequency = <100000>;
320 pinctrl-names = "default";
321 pinctrl-0 = <&pinctrl_i2c3>;
326 pinctrl-names = "default";
328 pinctrl_hog: hoggrp {
330 MX6QDL_PAD_EIM_D22__GPIO3_IO22 0x1b0b0 /*pcie power*/
331 MX6QDL_PAD_EIM_A25__GPIO5_IO02 0x1b0b0 /*LCD power*/
332 MX6QDL_PAD_EIM_D16__GPIO3_IO16 0x1b0b0 /*backlight power*/
333 MX6QDL_PAD_GPIO_2__GPIO1_IO02 0x1b0b1 /*SD3 CD pin*/
334 MX6QDL_PAD_KEY_COL2__GPIO4_IO10 0x1b0b0 /*codec power*/
335 MX6QDL_PAD_EIM_A16__GPIO2_IO22 0x1b0b0 /*touch reset*/
336 MX6QDL_PAD_NANDF_ALE__GPIO6_IO08 0x1b0b01 /*touch irq*/
337 MX6QDL_PAD_GPIO_7__GPIO1_IO07 0x1b0b0/*backlight pwr*/
338 MX6QDL_PAD_GPIO_16__GPIO7_IO11 0x1b0b0 /*gpio 5V_1*/
339 MX6QDL_PAD_EIM_A19__GPIO2_IO19 0x1b0b0 /*gpio 5V_2*/
340 MX6QDL_PAD_EIM_A24__GPIO5_IO04 0x1b0b0 /*gpio 5V_3*/
341 MX6QDL_PAD_GPIO_17__GPIO7_IO12 0x1b0b0 /*gpio 5V_4*/
342 MX6QDL_PAD_NANDF_CLE__GPIO6_IO07 0x1b0b0 /*AUX_5V_EN*/
343 MX6QDL_PAD_NANDF_WP_B__GPIO6_IO09 0x1b0b0 /*AUX_5VB_EN*/
344 MX6QDL_PAD_NANDF_RB0__GPIO6_IO10 0x1b0b0 /*AUX_3V3_EN*/
345 MX6QDL_PAD_EIM_D21__GPIO3_IO21 0x1b0b0 /*I2C expander pwr*/
349 pinctrl_audmux: audmuxgrp {
351 MX6QDL_PAD_CSI0_DAT7__AUD3_RXD 0x130b0
352 MX6QDL_PAD_CSI0_DAT4__AUD3_TXC 0x130b0
353 MX6QDL_PAD_CSI0_DAT5__AUD3_TXD 0x110b0
354 MX6QDL_PAD_CSI0_DAT6__AUD3_TXFS 0x130b0
358 pinctrl_ecspi1: ecspi1grp {
360 MX6QDL_PAD_KEY_COL1__ECSPI1_MISO 0x100b1
361 MX6QDL_PAD_KEY_ROW0__ECSPI1_MOSI 0x100b1
362 MX6QDL_PAD_KEY_COL0__ECSPI1_SCLK 0x100b1
363 MX6QDL_PAD_KEY_ROW1__GPIO4_IO09 0x1b0b0
367 pinctrl_enet: enetgrp {
369 MX6QDL_PAD_ENET_MDIO__ENET_MDIO 0x1b8b0
370 MX6QDL_PAD_ENET_MDC__ENET_MDC 0x1b0b0
372 MX6QDL_PAD_EIM_A20__GPIO2_IO18 0x130b0
373 /* AR8035 interrupt */
374 MX6QDL_PAD_EIM_CS0__GPIO2_IO23 0x1b0b1
375 MX6QDL_PAD_RGMII_TXC__RGMII_TXC 0x1b030
376 MX6QDL_PAD_RGMII_TD0__RGMII_TD0 0x1b030
377 MX6QDL_PAD_RGMII_TD1__RGMII_TD1 0x1b030
378 MX6QDL_PAD_RGMII_TD2__RGMII_TD2 0x1b030
379 MX6QDL_PAD_RGMII_TD3__RGMII_TD3 0x1b030
380 MX6QDL_PAD_RGMII_TX_CTL__RGMII_TX_CTL 0x1b030
381 /* AR8035 CLK_25M --> ENET_REF_CLK (V22) */
382 MX6QDL_PAD_ENET_REF_CLK__ENET_TX_CLK 0x0a0b1
383 /* AR8035 pin strapping: IO voltage: pull up */
384 MX6QDL_PAD_RGMII_RXC__RGMII_RXC 0x1b030
385 /* AR8035 pin strapping: PHYADDR#0: pull down */
386 MX6QDL_PAD_RGMII_RD0__RGMII_RD0 0x13030
387 /* AR8035 pin strapping: PHYADDR#1: pull down */
388 MX6QDL_PAD_RGMII_RD1__RGMII_RD1 0x13030
389 /* AR8035 pin strapping: MODE#1: pull up */
390 MX6QDL_PAD_RGMII_RD2__RGMII_RD2 0x1b030
391 /* AR8035 pin strapping: MODE#3: pull up */
392 MX6QDL_PAD_RGMII_RD3__RGMII_RD3 0x1b030
393 /* AR8035 pin strapping: MODE#0: pull down */
394 MX6QDL_PAD_RGMII_RX_CTL__RGMII_RX_CTL 0x13030
398 pinctrl_flexcan2: flexcan2grp {
400 MX6QDL_PAD_KEY_COL4__FLEXCAN2_TX 0x1b0b0
401 MX6QDL_PAD_KEY_ROW4__FLEXCAN2_RX 0x1b0b0
405 pinctrl_gpio_keys: gpio_keysgrp {
407 MX6QDL_PAD_SD4_DAT4__GPIO2_IO12 0x1b0b0
411 pinctrl_hdmi_cec: hdmicecgrp {
413 MX6QDL_PAD_KEY_ROW2__HDMI_TX_CEC_LINE 0x108b0
417 pinctrl_i2c1: i2c1grp {
419 MX6QDL_PAD_CSI0_DAT8__I2C1_SDA 0x4001b8b1
420 MX6QDL_PAD_CSI0_DAT9__I2C1_SCL 0x4001b8b1
424 pinctrl_i2c2: i2c2grp {
426 MX6QDL_PAD_KEY_COL3__I2C2_SCL 0x4001b8b1
427 MX6QDL_PAD_KEY_ROW3__I2C2_SDA 0x4001b8b1
431 pinctrl_i2c3: i2c3grp {
433 MX6QDL_PAD_GPIO_3__I2C3_SCL 0x4001b8b1
434 MX6QDL_PAD_GPIO_6__I2C3_SDA 0x4001b8b1
438 pinctrl_i2c1_sgtl5000: i2c1-sgtl5000grp {
440 MX6QDL_PAD_GPIO_0__CCM_CLKO1 0x000b0 /* sys_mclk */
441 MX6QDL_PAD_SD3_RST__GPIO7_IO08 0x130b0 /*headphone det*/
442 MX6QDL_PAD_GPIO_8__GPIO1_IO08 0x130b0 /*microphone det*/
446 pinctrl_pwm1: pwm1grp {
448 MX6QDL_PAD_GPIO_9__PWM1_OUT 0x1b0b1
452 pinctrl_uart1: uart1grp {
454 MX6QDL_PAD_CSI0_DAT10__UART1_RX_DATA 0x1b0b1
455 MX6QDL_PAD_CSI0_DAT11__UART1_TX_DATA 0x1b0b1
456 MX6QDL_PAD_EIM_D20__UART1_CTS_B 0x1b0b1
457 MX6QDL_PAD_EIM_D19__UART1_RTS_B 0x1b0b1
458 MX6QDL_PAD_EIM_D23__UART1_DCD_B 0x1b0b0
459 MX6QDL_PAD_EIM_D24__UART1_DTR_B 0x1b0b0
460 MX6QDL_PAD_EIM_D25__UART1_DSR_B 0x1b0b0
464 pinctrl_uart2: uart2grp {
466 MX6QDL_PAD_EIM_D26__UART2_TX_DATA 0x1b0b1
467 MX6QDL_PAD_EIM_D27__UART2_RX_DATA 0x1b0b1
468 MX6QDL_PAD_EIM_D28__UART2_CTS_B 0x1b0b1
469 MX6QDL_PAD_EIM_D29__UART2_RTS_B 0x1b0b1
473 pinctrl_uart3: uart3grp {
475 MX6QDL_PAD_SD4_CLK__UART3_RX_DATA 0x1b0b1
476 MX6QDL_PAD_SD4_CMD__UART3_TX_DATA 0x1b0b1
477 MX6QDL_PAD_EIM_D30__UART3_CTS_B 0x1b0b1
478 MX6QDL_PAD_EIM_D31__UART3_RTS_B 0x1b0b1
482 pinctrl_uart4: uart4grp {
484 MX6QDL_PAD_CSI0_DAT12__UART4_TX_DATA 0x1b0b1
485 MX6QDL_PAD_CSI0_DAT13__UART4_RX_DATA 0x1b0b1
486 MX6QDL_PAD_CSI0_DAT16__UART4_RTS_B 0x1b0b1
487 MX6QDL_PAD_CSI0_DAT17__UART4_CTS_B 0x1b0b1
491 pinctrl_uart5: uart5grp {
493 MX6QDL_PAD_CSI0_DAT14__UART5_TX_DATA 0x1b0b1
494 MX6QDL_PAD_CSI0_DAT15__UART5_RX_DATA 0x1b0b1
495 MX6QDL_PAD_CSI0_DAT18__UART5_RTS_B 0x1b0b1
496 MX6QDL_PAD_CSI0_DAT19__UART5_CTS_B 0x1b0b1
497 MX6QDL_PAD_EIM_A21__GPIO2_IO17 0x15059 /*BT_EN*/
501 pinctrl_usbotg: usbotggrp {
503 MX6QDL_PAD_ENET_RX_ER__USB_OTG_ID 0x17059
507 pinctrl_usdhc1: usdhc1grp {
509 MX6QDL_PAD_SD1_CMD__SD1_CMD 0x17059
510 MX6QDL_PAD_SD1_CLK__SD1_CLK 0x10059
511 MX6QDL_PAD_SD1_DAT0__SD1_DATA0 0x17059
512 MX6QDL_PAD_SD1_DAT1__SD1_DATA1 0x17059
513 MX6QDL_PAD_SD1_DAT2__SD1_DATA2 0x17059
514 MX6QDL_PAD_SD1_DAT3__SD1_DATA3 0x17059
515 MX6QDL_PAD_NANDF_D0__SD1_DATA4 0x17059
516 MX6QDL_PAD_NANDF_D1__SD1_DATA5 0x17059
517 MX6QDL_PAD_NANDF_D2__SD1_DATA6 0x17059
518 MX6QDL_PAD_NANDF_D3__SD1_DATA7 0x17059
522 pinctrl_usdhc2: usdhc2grp {
524 MX6QDL_PAD_SD2_CMD__SD2_CMD 0x17059
525 MX6QDL_PAD_SD2_CLK__SD2_CLK 0x10059
526 MX6QDL_PAD_SD2_DAT0__SD2_DATA0 0x17059
527 MX6QDL_PAD_SD2_DAT1__SD2_DATA1 0x17059
528 MX6QDL_PAD_SD2_DAT2__SD2_DATA2 0x17059
529 MX6QDL_PAD_SD2_DAT3__SD2_DATA3 0x17059
530 MX6QDL_PAD_EIM_RW__GPIO2_IO26 0x15059 /*WL_EN_LDO*/
531 MX6QDL_PAD_EIM_CS1__GPIO2_IO24 0x15059 /*WL_EN*/
532 MX6QDL_PAD_CSI0_PIXCLK__GPIO5_IO18 0x15059 /*WL_IRQ*/
536 pinctrl_usdhc3: usdhc3grp {
538 MX6QDL_PAD_SD3_CMD__SD3_CMD 0x17071
539 MX6QDL_PAD_SD3_CLK__SD3_CLK 0x10071
540 MX6QDL_PAD_SD3_DAT0__SD3_DATA0 0x17071
541 MX6QDL_PAD_SD3_DAT1__SD3_DATA1 0x17071
542 MX6QDL_PAD_SD3_DAT2__SD3_DATA2 0x17071
543 MX6QDL_PAD_SD3_DAT3__SD3_DATA3 0x17071
547 pinctrl_wdog: wdoggrp {
549 MX6QDL_PAD_GPIO_1__WDOG2_B 0x1b0b00
558 fsl,data-mapping = "spwg";
559 fsl,data-width = <18>;
565 lvds0_out: endpoint {
566 remote-endpoint = <&panel_in>;
573 pinctrl-names = "default";
574 pinctrl-0 = <&pinctrl_pwm1>;
587 pinctrl-names = "default";
588 pinctrl-0 = <&pinctrl_uart1>;
595 pinctrl-names = "default";
596 pinctrl-0 = <&pinctrl_uart2>;
602 pinctrl-names = "default";
603 pinctrl-0 = <&pinctrl_uart3>;
609 pinctrl-names = "default";
610 pinctrl-0 = <&pinctrl_uart4>;
616 pinctrl-names = "default";
617 pinctrl-0 = <&pinctrl_uart5>;
623 vbus-supply = <®_usb_otg_vbus>;
624 pinctrl-names = "default";
625 pinctrl-0 = <&pinctrl_usbotg>;
626 disable-over-current;
638 fsl,tx-d-cal = <0x5>;
642 fsl,tx-d-cal = <0x5>;
646 pinctrl-names = "default";
647 pinctrl-0 = <&pinctrl_usdhc1>;
649 keep-power-in-suspend;
650 vmmc-supply = <®_3p3v>;
655 pinctrl-names = "default";
656 pinctrl-0 = <&pinctrl_usdhc2>;
658 vmmc-supply = <&wlan_en_reg>;
660 keep-power-in-suspend;
665 #address-cells = <1>;
668 compatible = "ti,wl1835";
670 interrupt-parent = <&gpio5>;
671 interrupts = <18 IRQ_TYPE_LEVEL_HIGH>;
672 ref-clock-frequency = <38400000>;
673 tcxo-clock-frequency = <26000000>;
678 pinctrl-names = "default";
679 pinctrl-0 = <&pinctrl_usdhc3>;
681 cd-gpios = <&gpio1 2 GPIO_ACTIVE_LOW>;
683 keep-power-in-suspend;