Back to home page

OSCL-LXR

 
 

    


0001 // SPDX-License-Identifier: GPL-2.0+
0002 /*
0003  * Copyright (C) 2015-2021 DH electronics GmbH
0004  * Copyright (C) 2018 Marek Vasut <marex@denx.de>
0005  */
0006 
0007 #include <dt-bindings/gpio/gpio.h>
0008 #include <dt-bindings/input/input.h>
0009 #include <dt-bindings/leds/common.h>
0010 #include <dt-bindings/pwm/pwm.h>
0011 
0012 / {
0013         chosen {
0014                 stdout-path = "serial0:115200n8";
0015         };
0016 
0017         clk_ext_audio_codec: clock-codec {
0018                 #clock-cells = <0>;
0019                 clock-frequency = <24000000>;
0020                 compatible = "fixed-clock";
0021         };
0022 
0023         display_bl: display-bl {
0024                 brightness-levels = <0 16 22 30 40 55 75 102 138 188 255>;
0025                 compatible = "pwm-backlight";
0026                 default-brightness-level = <8>;
0027                 enable-gpios = <&gpio3 27 GPIO_ACTIVE_HIGH>; /* GPIO G */
0028                 pwms = <&pwm1 0 50000 PWM_POLARITY_INVERTED>;
0029                 status = "okay";
0030         };
0031 
0032         lcd_display: disp0 {
0033                 #address-cells = <1>;
0034                 #size-cells = <0>;
0035                 compatible = "fsl,imx-parallel-display";
0036                 interface-pix-fmt = "rgb24";
0037                 pinctrl-0 = <&pinctrl_ipu1_lcdif &pinctrl_dhcom_g>;
0038                 pinctrl-names = "default";
0039                 status = "okay";
0040 
0041                 port@0 {
0042                         reg = <0>;
0043 
0044                         lcd_display_in: endpoint {
0045                                 remote-endpoint = <&ipu1_di0_disp0>;
0046                         };
0047                 };
0048 
0049                 port@1 {
0050                         reg = <1>;
0051 
0052                         lcd_display_out: endpoint {
0053                                 remote-endpoint = <&lcd_panel_in>;
0054                         };
0055                 };
0056         };
0057 
0058         gpio-keys {
0059                 #size-cells = <0>;
0060                 compatible = "gpio-keys";
0061 
0062                 button-0 {
0063                         gpios = <&gpio1 2 GPIO_ACTIVE_LOW>; /* GPIO A */
0064                         label = "TA1-GPIO-A";
0065                         linux,code = <KEY_A>;
0066                         pinctrl-0 = <&pinctrl_dhcom_a>;
0067                         pinctrl-names = "default";
0068                         wakeup-source;
0069                 };
0070 
0071                 button-1 {
0072                         gpios = <&gpio1 4 GPIO_ACTIVE_LOW>; /* GPIO B */
0073                         label = "TA2-GPIO-B";
0074                         linux,code = <KEY_B>;
0075                         pinctrl-0 = <&pinctrl_dhcom_b>;
0076                         pinctrl-names = "default";
0077                         wakeup-source;
0078                 };
0079 
0080                 button-2 {
0081                         gpios = <&gpio1 5 GPIO_ACTIVE_LOW>; /* GPIO C */
0082                         label = "TA3-GPIO-C";
0083                         linux,code = <KEY_C>;
0084                         pinctrl-0 = <&pinctrl_dhcom_c>;
0085                         pinctrl-names = "default";
0086                         wakeup-source;
0087                 };
0088 
0089                 button-3 {
0090                         gpios = <&gpio6 3 GPIO_ACTIVE_LOW>; /* GPIO D */
0091                         label = "TA4-GPIO-D";
0092                         linux,code = <KEY_D>;
0093                         pinctrl-0 = <&pinctrl_dhcom_d>;
0094                         pinctrl-names = "default";
0095                         wakeup-source;
0096                 };
0097         };
0098 
0099         led {
0100                 compatible = "gpio-leds";
0101 
0102                 /*
0103                  * Disable led-5, because GPIO E is
0104                  * already used as touch interrupt.
0105                  */
0106                 led-5 {
0107                         color = <LED_COLOR_ID_GREEN>;
0108                         default-state = "off";
0109                         function = LED_FUNCTION_INDICATOR;
0110                         gpios = <&gpio4 5 GPIO_ACTIVE_HIGH>; /* GPIO E */
0111                         pinctrl-0 = <&pinctrl_dhcom_e>;
0112                         pinctrl-names = "default";
0113                         status = "disabled";
0114                 };
0115 
0116                 led-6 {
0117                         color = <LED_COLOR_ID_GREEN>;
0118                         default-state = "off";
0119                         function = LED_FUNCTION_INDICATOR;
0120                         gpios = <&gpio4 20 GPIO_ACTIVE_HIGH>; /* GPIO F */
0121                         pinctrl-0 = <&pinctrl_dhcom_f>;
0122                         pinctrl-names = "default";
0123                 };
0124 
0125                 led-7 {
0126                         color = <LED_COLOR_ID_GREEN>;
0127                         default-state = "off";
0128                         function = LED_FUNCTION_INDICATOR;
0129                         gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>; /* GPIO H */
0130                         pinctrl-0 = <&pinctrl_dhcom_h>;
0131                         pinctrl-names = "default";
0132                 };
0133 
0134                 led-8 {
0135                         color = <LED_COLOR_ID_GREEN>;
0136                         default-state = "off";
0137                         function = LED_FUNCTION_INDICATOR;
0138                         gpios = <&gpio4 8 GPIO_ACTIVE_HIGH>; /* GPIO I */
0139                         pinctrl-0 = <&pinctrl_dhcom_i>;
0140                         pinctrl-names = "default";
0141                 };
0142         };
0143 
0144         panel {
0145                 backlight = <&display_bl>;
0146                 compatible = "edt,etm0700g0edh6";
0147 
0148                 port {
0149                         lcd_panel_in: endpoint {
0150                                 remote-endpoint = <&lcd_display_out>;
0151                         };
0152                 };
0153         };
0154 
0155         sound {
0156                 audio-codec = <&sgtl5000>;
0157                 audio-routing =
0158                         "MIC_IN", "Mic Jack",
0159                         "Mic Jack", "Mic Bias",
0160                         "LINE_IN", "Line In Jack",
0161                         "Headphone Jack", "HP_OUT";
0162                 compatible = "fsl,imx-audio-sgtl5000";
0163                 model = "imx-sgtl5000";
0164                 mux-ext-port = <3>;
0165                 mux-int-port = <1>;
0166                 ssi-controller = <&ssi1>;
0167         };
0168 };
0169 
0170 &audmux {
0171         pinctrl-0 = <&pinctrl_audmux_ext>;
0172         pinctrl-names = "default";
0173         status = "okay";
0174 };
0175 
0176 &can1 {
0177         status = "okay";
0178 };
0179 
0180 &can2 {
0181         status = "disabled";
0182 };
0183 
0184 /* 1G ethernet */
0185 /delete-node/ &ethphy0;
0186 &fec {
0187         phy-mode = "rgmii";
0188         phy-handle = <&ethphy7>;
0189         pinctrl-0 = <&pinctrl_enet_1G>;
0190         pinctrl-names = "default";
0191         status = "okay";
0192 
0193         mdio {
0194                 #address-cells = <1>;
0195                 #size-cells = <0>;
0196 
0197                 ethphy7: ethernet-phy@7 { /* KSZ 9021 */
0198                         compatible = "ethernet-phy-ieee802.3-c22";
0199                         interrupt-parent = <&gpio1>;
0200                         interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
0201                         pinctrl-0 = <&pinctrl_ethphy7>;
0202                         pinctrl-names = "default";
0203                         reg = <7>;
0204                         reset-assert-us = <1000>;
0205                         reset-deassert-us = <1000>;
0206                         reset-gpios = <&gpio3 29 GPIO_ACTIVE_LOW>;
0207                         rxc-skew-ps = <3000>;
0208                         rxd0-skew-ps = <0>;
0209                         rxd1-skew-ps = <0>;
0210                         rxd2-skew-ps = <0>;
0211                         rxd3-skew-ps = <0>;
0212                         rxdv-skew-ps = <0>;
0213                         txc-skew-ps = <3000>;
0214                         txd0-skew-ps = <0>;
0215                         txd1-skew-ps = <0>;
0216                         txd2-skew-ps = <0>;
0217                         txd3-skew-ps = <0>;
0218                         txen-skew-ps = <0>;
0219                 };
0220         };
0221 };
0222 
0223 &hdmi {
0224         ddc-i2c-bus = <&i2c2>;
0225         status = "okay";
0226 };
0227 
0228 &i2c2 {
0229         sgtl5000: codec@a {
0230                 #sound-dai-cells = <0>;
0231                 clocks = <&clk_ext_audio_codec>;
0232                 compatible = "fsl,sgtl5000";
0233                 reg = <0x0a>;
0234                 VDDA-supply = <&reg_3p3v>;
0235                 VDDIO-supply = <&sw2_reg>;
0236         };
0237 
0238         touchscreen@38 {
0239                 compatible = "edt,edt-ft5406";
0240                 interrupt-parent = <&gpio4>;
0241                 interrupts = <5 IRQ_TYPE_EDGE_FALLING>; /* GPIO E */
0242                 pinctrl-0 = <&pinctrl_dhcom_e>;
0243                 pinctrl-names = "default";
0244                 reg = <0x38>;
0245         };
0246 };
0247 
0248 &ipu1_di0_disp0 {
0249         remote-endpoint = <&lcd_display_in>;
0250 };
0251 
0252 &pcie {
0253         pinctrl-0 = <&pinctrl_pcie &pinctrl_dhcom_j>;
0254         reset-gpio = <&gpio6 14 GPIO_ACTIVE_LOW>; /* GPIO J */
0255         status = "okay";
0256 };
0257 
0258 &pwm1 {
0259         status = "okay";
0260 };
0261 
0262 &ssi1 {
0263         status = "okay";
0264 };
0265 
0266 &usbh1 {
0267         disable-over-current;
0268 };
0269 
0270 &usdhc2 { /* SD card */
0271         status = "okay";
0272 };
0273 
0274 &iomuxc {
0275         pinctrl-0 = <
0276                         /*
0277                          * The following DHCOM GPIOs are used on this board.
0278                          * Therefore, they have been removed from the list below.
0279                          * A: key TA1
0280                          * B: key TA2
0281                          * C: key TA3
0282                          * D: key TA4
0283                          * E: touchscreen
0284                          * F: led6
0285                          * G: backlight enable
0286                          * H: led7
0287                          * I: led8
0288                          * J: PCIe reset
0289                          */
0290                         &pinctrl_hog_base
0291                         &pinctrl_dhcom_k &pinctrl_dhcom_l
0292                         &pinctrl_dhcom_m &pinctrl_dhcom_n &pinctrl_dhcom_o
0293                         &pinctrl_dhcom_p &pinctrl_dhcom_q &pinctrl_dhcom_r
0294                         &pinctrl_dhcom_s &pinctrl_dhcom_t &pinctrl_dhcom_u
0295                         &pinctrl_dhcom_v &pinctrl_dhcom_w &pinctrl_dhcom_int
0296                 >;
0297         pinctrl-names = "default";
0298 
0299         pinctrl_audmux_ext: audmux-ext-grp {
0300                 fsl,pins = <
0301                         MX6QDL_PAD_CSI0_DAT4__AUD3_TXC          0x130b0
0302                         MX6QDL_PAD_CSI0_DAT5__AUD3_TXD          0x110b0
0303                         MX6QDL_PAD_CSI0_DAT6__AUD3_TXFS         0x130b0
0304                         MX6QDL_PAD_CSI0_DAT7__AUD3_RXD          0x130b0
0305                 >;
0306         };
0307 
0308         pinctrl_enet_1G: enet-1G-grp {
0309                 fsl,pins = <
0310                         MX6QDL_PAD_ENET_MDC__ENET_MDC           0x100b0
0311                         MX6QDL_PAD_ENET_MDIO__ENET_MDIO         0x100b0
0312                         MX6QDL_PAD_ENET_REF_CLK__ENET_TX_CLK    0x100b0
0313                         MX6QDL_PAD_RGMII_RD0__RGMII_RD0         0x1b0b0
0314                         MX6QDL_PAD_RGMII_RD1__RGMII_RD1         0x1b0b0
0315                         MX6QDL_PAD_RGMII_RD2__RGMII_RD2         0x1b0b0
0316                         MX6QDL_PAD_RGMII_RD3__RGMII_RD3         0x1b0b0
0317                         MX6QDL_PAD_RGMII_RX_CTL__RGMII_RX_CTL   0x1b0b0
0318                         MX6QDL_PAD_RGMII_RXC__RGMII_RXC         0x1b0b0
0319                         MX6QDL_PAD_RGMII_TD0__RGMII_TD0         0x100b0
0320                         MX6QDL_PAD_RGMII_TD1__RGMII_TD1         0x100b0
0321                         MX6QDL_PAD_RGMII_TD2__RGMII_TD2         0x100b0
0322                         MX6QDL_PAD_RGMII_TD3__RGMII_TD3         0x100b0
0323                         MX6QDL_PAD_RGMII_TX_CTL__RGMII_TX_CTL   0x100b0
0324                         MX6QDL_PAD_RGMII_TXC__RGMII_TXC         0x100b0
0325                 >;
0326         };
0327 
0328         pinctrl_ethphy7: ethphy7-grp {
0329                 fsl,pins = <
0330                         MX6QDL_PAD_EIM_D26__GPIO3_IO26          0xb1 /* WOL */
0331                         MX6QDL_PAD_EIM_D29__GPIO3_IO29          0xb0 /* Reset */
0332                         MX6QDL_PAD_GPIO_0__GPIO1_IO00           0xb1 /* Int */
0333                 >;
0334         };
0335 
0336         pinctrl_ipu1_lcdif: ipu1-lcdif-grp {
0337                 fsl,pins = <
0338                         MX6QDL_PAD_DI0_DISP_CLK__IPU1_DI0_DISP_CLK      0x38
0339                         MX6QDL_PAD_DI0_PIN2__IPU1_DI0_PIN02             0x38
0340                         MX6QDL_PAD_DI0_PIN3__IPU1_DI0_PIN03             0x38
0341                         MX6QDL_PAD_DI0_PIN15__IPU1_DI0_PIN15            0x38
0342                         MX6QDL_PAD_DISP0_DAT0__IPU1_DISP0_DATA00        0x38
0343                         MX6QDL_PAD_DISP0_DAT1__IPU1_DISP0_DATA01        0x38
0344                         MX6QDL_PAD_DISP0_DAT2__IPU1_DISP0_DATA02        0x38
0345                         MX6QDL_PAD_DISP0_DAT3__IPU1_DISP0_DATA03        0x38
0346                         MX6QDL_PAD_DISP0_DAT4__IPU1_DISP0_DATA04        0x38
0347                         MX6QDL_PAD_DISP0_DAT5__IPU1_DISP0_DATA05        0x38
0348                         MX6QDL_PAD_DISP0_DAT6__IPU1_DISP0_DATA06        0x38
0349                         MX6QDL_PAD_DISP0_DAT7__IPU1_DISP0_DATA07        0x38
0350                         MX6QDL_PAD_DISP0_DAT8__IPU1_DISP0_DATA08        0x38
0351                         MX6QDL_PAD_DISP0_DAT9__IPU1_DISP0_DATA09        0x38
0352                         MX6QDL_PAD_DISP0_DAT10__IPU1_DISP0_DATA10       0x38
0353                         MX6QDL_PAD_DISP0_DAT11__IPU1_DISP0_DATA11       0x38
0354                         MX6QDL_PAD_DISP0_DAT12__IPU1_DISP0_DATA12       0x38
0355                         MX6QDL_PAD_DISP0_DAT13__IPU1_DISP0_DATA13       0x38
0356                         MX6QDL_PAD_DISP0_DAT14__IPU1_DISP0_DATA14       0x38
0357                         MX6QDL_PAD_DISP0_DAT15__IPU1_DISP0_DATA15       0x38
0358                         MX6QDL_PAD_DISP0_DAT16__IPU1_DISP0_DATA16       0x38
0359                         MX6QDL_PAD_DISP0_DAT17__IPU1_DISP0_DATA17       0x38
0360                         MX6QDL_PAD_DISP0_DAT18__IPU1_DISP0_DATA18       0x38
0361                         MX6QDL_PAD_DISP0_DAT19__IPU1_DISP0_DATA19       0x38
0362                         MX6QDL_PAD_DISP0_DAT20__IPU1_DISP0_DATA20       0x38
0363                         MX6QDL_PAD_DISP0_DAT21__IPU1_DISP0_DATA21       0x38
0364                         MX6QDL_PAD_DISP0_DAT22__IPU1_DISP0_DATA22       0x38
0365                         MX6QDL_PAD_DISP0_DAT23__IPU1_DISP0_DATA23       0x38
0366                 >;
0367         };
0368 };