1// SPDX-License-Identifier: GPL-2.0+ 2/* 3 * Copyright 2018-2019 Purism SPC 4 */ 5 6/dts-v1/; 7 8#include "dt-bindings/input/input.h" 9#include <dt-bindings/interrupt-controller/irq.h> 10#include <dt-bindings/leds/common.h> 11#include "dt-bindings/pwm/pwm.h" 12#include "dt-bindings/usb/pd.h" 13#include "imx8mq.dtsi" 14 15/ { 16 model = "Purism Librem 5 devkit"; 17 compatible = "purism,librem5-devkit", "fsl,imx8mq"; 18 19 backlight_dsi: backlight-dsi { 20 compatible = "pwm-backlight"; 21 /* 200 Hz for the PAM2841 */ 22 pwms = <&pwm1 0 5000000 0>; 23 brightness-levels = <0 100>; 24 num-interpolated-steps = <100>; 25 /* Default brightness level (index into the array defined by */ 26 /* the "brightness-levels" property) */ 27 default-brightness-level = <0>; 28 power-supply = <®_22v4_p>; 29 }; 30 31 chosen { 32 stdout-path = &uart1; 33 }; 34 35 gpio-keys { 36 compatible = "gpio-keys"; 37 pinctrl-names = "default"; 38 pinctrl-0 = <&pinctrl_gpio_keys>; 39 40 button-1 { 41 label = "VOL_UP"; 42 gpios = <&gpio4 21 GPIO_ACTIVE_LOW>; 43 wakeup-source; 44 linux,code = <KEY_VOLUMEUP>; 45 }; 46 47 button-2 { 48 label = "VOL_DOWN"; 49 gpios = <&gpio4 22 GPIO_ACTIVE_LOW>; 50 wakeup-source; 51 linux,code = <KEY_VOLUMEDOWN>; 52 }; 53 54 button-3 { 55 label = "WWAN_WAKE"; 56 gpios = <&gpio3 8 GPIO_ACTIVE_LOW>; 57 interrupt-parent = <&gpio3>; 58 interrupts = <8 IRQ_TYPE_LEVEL_LOW>; 59 wakeup-source; 60 linux,code = <KEY_PHONE>; 61 }; 62 }; 63 64 leds { 65 compatible = "pwm-leds"; 66 67 led1 { 68 function = LED_FUNCTION_STATUS; 69 color = <LED_COLOR_ID_RED>; 70 max-brightness = <248>; 71 pwms = <&pwm2 0 50000 0>; 72 }; 73 }; 74 75 pmic_osc: clock-pmic { 76 compatible = "fixed-clock"; 77 #clock-cells = <0>; 78 clock-frequency = <32768>; 79 clock-output-names = "pmic_osc"; 80 }; 81 82 reg_1v8_p: regulator-1v8-p { 83 compatible = "regulator-fixed"; 84 regulator-name = "1v8_p"; 85 regulator-min-microvolt = <1800000>; 86 regulator-max-microvolt = <1800000>; 87 vin-supply = <®_pwr_en>; 88 }; 89 90 reg_2v8_p: regulator-2v8-p { 91 compatible = "regulator-fixed"; 92 regulator-name = "2v8_p"; 93 regulator-min-microvolt = <2800000>; 94 regulator-max-microvolt = <2800000>; 95 vin-supply = <®_pwr_en>; 96 }; 97 98 reg_3v3_p: regulator-3v3-p { 99 compatible = "regulator-fixed"; 100 regulator-name = "3v3_p"; 101 regulator-min-microvolt = <3300000>; 102 regulator-max-microvolt = <3300000>; 103 vin-supply = <®_pwr_en>; 104 105 regulator-state-mem { 106 regulator-on-in-suspend; 107 }; 108 }; 109 110 reg_5v_p: regulator-5v-p { 111 compatible = "regulator-fixed"; 112 regulator-name = "5v_p"; 113 regulator-min-microvolt = <5000000>; 114 regulator-max-microvolt = <5000000>; 115 vin-supply = <®_pwr_en>; 116 117 regulator-state-mem { 118 regulator-on-in-suspend; 119 }; 120 }; 121 122 reg_22v4_p: regulator-22v4-p { 123 compatible = "regulator-fixed"; 124 regulator-name = "22v4_P"; 125 regulator-min-microvolt = <22400000>; 126 regulator-max-microvolt = <22400000>; 127 vin-supply = <®_pwr_en>; 128 }; 129 130 reg_pwr_en: regulator-pwr-en { 131 compatible = "regulator-fixed"; 132 pinctrl-names = "default"; 133 pinctrl-0 = <&pinctrl_pwr_en>; 134 regulator-name = "PWR_EN"; 135 regulator-min-microvolt = <3300000>; 136 regulator-max-microvolt = <3300000>; 137 gpio = <&gpio1 8 GPIO_ACTIVE_HIGH>; 138 enable-active-high; 139 regulator-always-on; 140 }; 141 142 reg_usdhc2_vmmc: regulator-usdhc2-vmmc { 143 compatible = "regulator-fixed"; 144 pinctrl-names = "default"; 145 pinctrl-0 = <&pinctrl_usdhc2_pwr>; 146 regulator-name = "VSD_3V3"; 147 regulator-min-microvolt = <3300000>; 148 regulator-max-microvolt = <3300000>; 149 gpio = <&gpio2 19 GPIO_ACTIVE_HIGH>; 150 enable-active-high; 151 regulator-always-on; 152 }; 153 154 wwan_codec: sound-wwan-codec { 155 compatible = "option,gtm601"; 156 #sound-dai-cells = <0>; 157 }; 158 159 mic_mux: mic-mux { 160 compatible = "simple-audio-mux"; 161 pinctrl-names = "default"; 162 pinctrl-0 = <&pinctrl_micsel>; 163 mux-gpios = <&gpio5 5 GPIO_ACTIVE_LOW>; 164 sound-name-prefix = "Mic Mux"; 165 }; 166 167 sound { 168 compatible = "simple-audio-card"; 169 pinctrl-names = "default"; 170 pinctrl-0 = <&pinctrl_hpdet>; 171 simple-audio-card,aux-devs = <&speaker_amp>, <&mic_mux>; 172 simple-audio-card,name = "Librem 5 Devkit"; 173 simple-audio-card,format = "i2s"; 174 simple-audio-card,widgets = 175 "Microphone", "Builtin Microphone", 176 "Microphone", "Headset Microphone", 177 "Headphone", "Headphones", 178 "Speaker", "Builtin Speaker"; 179 simple-audio-card,routing = 180 "MIC_IN", "Mic Mux OUT", 181 "Mic Mux IN1", "Headset Microphone", 182 "Mic Mux IN2", "Builtin Microphone", 183 "Mic Mux OUT", "Mic Bias", 184 "Headphones", "HP_OUT", 185 "Builtin Speaker", "Speaker Amp OUTR", 186 "Speaker Amp INR", "LINE_OUT"; 187 simple-audio-card,hp-det-gpio = <&gpio3 20 GPIO_ACTIVE_HIGH>; 188 189 simple-audio-card,cpu { 190 sound-dai = <&sai2>; 191 }; 192 193 simple-audio-card,codec { 194 sound-dai = <&sgtl5000>; 195 clocks = <&clk IMX8MQ_CLK_SAI2_ROOT>; 196 frame-master; 197 bitclock-master; 198 }; 199 }; 200 201 sound-wwan { 202 compatible = "simple-audio-card"; 203 simple-audio-card,name = "SIMCom SIM7100"; 204 simple-audio-card,format = "dsp_a"; 205 206 simple-audio-card,cpu { 207 sound-dai = <&sai6>; 208 }; 209 210 telephony_link_master: simple-audio-card,codec { 211 sound-dai = <&wwan_codec>; 212 frame-master; 213 bitclock-master; 214 }; 215 }; 216 217 speaker_amp: speaker-amp { 218 compatible = "simple-audio-amplifier"; 219 pinctrl-names = "default"; 220 pinctrl-0 = <&pinctrl_spkamp>; 221 VCC-supply = <®_3v3_p>; 222 sound-name-prefix = "Speaker Amp"; 223 enable-gpios = <&gpio5 3 GPIO_ACTIVE_HIGH>; 224 }; 225 226 vibrator { 227 compatible = "gpio-vibrator"; 228 pinctrl-names = "default"; 229 pinctrl-0 = <&pinctrl_haptic>; 230 enable-gpios = <&gpio5 4 GPIO_ACTIVE_LOW>; 231 vcc-supply = <®_3v3_p>; 232 }; 233 234 wifi_pwr_en: regulator-wifi-en { 235 compatible = "regulator-fixed"; 236 pinctrl-names = "default"; 237 pinctrl-0 = <&pinctrl_wifi_pwr_en>; 238 regulator-name = "WIFI_EN"; 239 regulator-min-microvolt = <3300000>; 240 regulator-max-microvolt = <3300000>; 241 gpio = <&gpio3 5 GPIO_ACTIVE_HIGH>; 242 enable-active-high; 243 regulator-always-on; 244 }; 245}; 246 247&A53_0 { 248 cpu-supply = <&buck2_reg>; 249}; 250 251&A53_1 { 252 cpu-supply = <&buck2_reg>; 253}; 254 255&A53_2 { 256 cpu-supply = <&buck2_reg>; 257}; 258 259&A53_3 { 260 cpu-supply = <&buck2_reg>; 261}; 262 263&dphy { 264 status = "okay"; 265}; 266 267&fec1 { 268 pinctrl-names = "default"; 269 pinctrl-0 = <&pinctrl_fec1>; 270 phy-mode = "rgmii-id"; 271 phy-handle = <ðphy0>; 272 fsl,magic-packet; 273 phy-supply = <®_3v3_p>; 274 status = "okay"; 275 276 mdio { 277 #address-cells = <1>; 278 #size-cells = <0>; 279 280 ethphy0: ethernet-phy@1 { 281 compatible = "ethernet-phy-ieee802.3-c22"; 282 reg = <1>; 283 }; 284 }; 285}; 286 287&i2c1 { 288 clock-frequency = <100000>; 289 pinctrl-names = "default"; 290 pinctrl-0 = <&pinctrl_i2c1>; 291 status = "okay"; 292 293 pmic: pmic@4b { 294 compatible = "rohm,bd71837"; 295 reg = <0x4b>; 296 pinctrl-names = "default"; 297 pinctrl-0 = <&pinctrl_pmic>; 298 clocks = <&pmic_osc>; 299 clock-names = "osc"; 300 #clock-cells = <0>; 301 clock-output-names = "pmic_clk"; 302 interrupt-parent = <&gpio1>; 303 interrupts = <3 IRQ_TYPE_LEVEL_LOW>; 304 rohm,reset-snvs-powered; 305 306 regulators { 307 buck1_reg: BUCK1 { 308 regulator-name = "buck1"; 309 regulator-min-microvolt = <700000>; 310 regulator-max-microvolt = <1300000>; 311 regulator-boot-on; 312 regulator-always-on; 313 regulator-ramp-delay = <1250>; 314 rohm,dvs-run-voltage = <900000>; 315 rohm,dvs-idle-voltage = <850000>; 316 rohm,dvs-suspend-voltage = <800000>; 317 }; 318 319 buck2_reg: BUCK2 { 320 regulator-name = "buck2"; 321 regulator-min-microvolt = <700000>; 322 regulator-max-microvolt = <1300000>; 323 regulator-boot-on; 324 regulator-ramp-delay = <1250>; 325 rohm,dvs-run-voltage = <1000000>; 326 rohm,dvs-idle-voltage = <900000>; 327 }; 328 329 buck3_reg: BUCK3 { 330 regulator-name = "buck3"; 331 regulator-min-microvolt = <700000>; 332 regulator-max-microvolt = <1300000>; 333 regulator-boot-on; 334 rohm,dvs-run-voltage = <900000>; 335 }; 336 337 buck4_reg: BUCK4 { 338 regulator-name = "buck4"; 339 regulator-min-microvolt = <700000>; 340 regulator-max-microvolt = <1300000>; 341 rohm,dvs-run-voltage = <1000000>; 342 }; 343 344 buck5_reg: BUCK5 { 345 regulator-name = "buck5"; 346 regulator-min-microvolt = <700000>; 347 regulator-max-microvolt = <1350000>; 348 regulator-boot-on; 349 regulator-always-on; 350 }; 351 352 buck6_reg: BUCK6 { 353 regulator-name = "buck6"; 354 regulator-min-microvolt = <3000000>; 355 regulator-max-microvolt = <3300000>; 356 regulator-boot-on; 357 regulator-always-on; 358 }; 359 360 buck7_reg: BUCK7 { 361 regulator-name = "buck7"; 362 regulator-min-microvolt = <1605000>; 363 regulator-max-microvolt = <1995000>; 364 regulator-boot-on; 365 regulator-always-on; 366 }; 367 368 buck8_reg: BUCK8 { 369 regulator-name = "buck8"; 370 regulator-min-microvolt = <800000>; 371 regulator-max-microvolt = <1400000>; 372 regulator-boot-on; 373 regulator-always-on; 374 }; 375 376 ldo1_reg: LDO1 { 377 regulator-name = "ldo1"; 378 regulator-min-microvolt = <3000000>; 379 regulator-max-microvolt = <3300000>; 380 regulator-boot-on; 381 /* leave on for snvs power button */ 382 regulator-always-on; 383 }; 384 385 ldo2_reg: LDO2 { 386 regulator-name = "ldo2"; 387 regulator-min-microvolt = <900000>; 388 regulator-max-microvolt = <900000>; 389 regulator-boot-on; 390 /* leave on for snvs power button */ 391 regulator-always-on; 392 }; 393 394 ldo3_reg: LDO3 { 395 regulator-name = "ldo3"; 396 regulator-min-microvolt = <1800000>; 397 regulator-max-microvolt = <3300000>; 398 regulator-boot-on; 399 regulator-always-on; 400 }; 401 402 ldo4_reg: LDO4 { 403 regulator-name = "ldo4"; 404 regulator-min-microvolt = <900000>; 405 regulator-max-microvolt = <1800000>; 406 regulator-boot-on; 407 regulator-always-on; 408 }; 409 410 ldo5_reg: LDO5 { 411 regulator-name = "ldo5"; 412 regulator-min-microvolt = <1800000>; 413 regulator-max-microvolt = <3300000>; 414 regulator-always-on; 415 }; 416 417 ldo6_reg: LDO6 { 418 regulator-name = "ldo6"; 419 regulator-min-microvolt = <900000>; 420 regulator-max-microvolt = <1800000>; 421 regulator-boot-on; 422 regulator-always-on; 423 }; 424 425 ldo7_reg: LDO7 { 426 regulator-name = "ldo7"; 427 regulator-min-microvolt = <1800000>; 428 regulator-max-microvolt = <3300000>; 429 regulator-boot-on; 430 regulator-always-on; 431 }; 432 }; 433 }; 434 435 typec_ptn5100: usb-typec@52 { 436 compatible = "nxp,ptn5110"; 437 reg = <0x52>; 438 pinctrl-names = "default"; 439 pinctrl-0 = <&pinctrl_typec>; 440 interrupt-parent = <&gpio3>; 441 interrupts = <1 IRQ_TYPE_LEVEL_LOW>; 442 443 connector { 444 compatible = "usb-c-connector"; 445 label = "USB-C"; 446 data-role = "dual"; 447 power-role = "dual"; 448 try-power-role = "sink"; 449 source-pdos = <PDO_FIXED(5000, 2000, 450 PDO_FIXED_USB_COMM | 451 PDO_FIXED_DUAL_ROLE | 452 PDO_FIXED_DATA_SWAP )>; 453 sink-pdos = <PDO_FIXED(5000, 3500, PDO_FIXED_USB_COMM | 454 PDO_FIXED_DUAL_ROLE | 455 PDO_FIXED_DATA_SWAP ) 456 PDO_VAR(5000, 5000, 3500)>; 457 op-sink-microwatt = <10000000>; 458 459 ports { 460 #address-cells = <1>; 461 #size-cells = <0>; 462 463 port@0 { 464 reg = <0>; 465 466 usb_con_hs: endpoint { 467 remote-endpoint = <&typec_hs>; 468 }; 469 }; 470 471 port@1 { 472 reg = <1>; 473 474 usb_con_ss: endpoint { 475 remote-endpoint = <&typec_ss>; 476 }; 477 }; 478 }; 479 }; 480 }; 481 482 rtc@68 { 483 compatible = "microcrystal,rv4162"; 484 reg = <0x68>; 485 pinctrl-names = "default"; 486 pinctrl-0 = <&pinctrl_rtc>; 487 interrupt-parent = <&gpio4>; 488 interrupts = <29 IRQ_TYPE_LEVEL_LOW>; 489 }; 490 491 charger@6b { /* bq25896 */ 492 compatible = "ti,bq25890"; 493 reg = <0x6b>; 494 pinctrl-names = "default"; 495 pinctrl-0 = <&pinctrl_charger>; 496 interrupt-parent = <&gpio3>; 497 interrupts = <25 IRQ_TYPE_EDGE_FALLING>; 498 ti,battery-regulation-voltage = <4192000>; /* 4.192V */ 499 ti,charge-current = <1600000>; /* 1.6A */ 500 ti,termination-current = <66000>; /* 66mA */ 501 ti,precharge-current = <130000>; /* 130mA */ 502 ti,minimum-sys-voltage = <3000000>; /* 3V */ 503 ti,boost-voltage = <5000000>; /* 5V */ 504 ti,boost-max-current = <50000>; /* 50mA */ 505 }; 506}; 507 508&i2c3 { 509 clock-frequency = <100000>; 510 pinctrl-names = "default"; 511 pinctrl-0 = <&pinctrl_i2c3>; 512 status = "okay"; 513 514 magnetometer@1e { 515 compatible = "st,lsm9ds1-magn"; 516 reg = <0x1e>; 517 pinctrl-names = "default"; 518 pinctrl-0 = <&pinctrl_imu>; 519 interrupt-parent = <&gpio3>; 520 interrupts = <19 IRQ_TYPE_LEVEL_HIGH>; 521 vdd-supply = <®_3v3_p>; 522 vddio-supply = <®_3v3_p>; 523 }; 524 525 sgtl5000: audio-codec@a { 526 compatible = "fsl,sgtl5000"; 527 clocks = <&clk IMX8MQ_CLK_SAI2_ROOT>; 528 assigned-clocks = <&clk IMX8MQ_CLK_SAI2>; 529 assigned-clock-parents = <&clk IMX8MQ_AUDIO_PLL1_OUT>; 530 assigned-clock-rates = <24576000>; 531 #sound-dai-cells = <0>; 532 reg = <0x0a>; 533 VDDD-supply = <®_1v8_p>; 534 VDDIO-supply = <®_3v3_p>; 535 VDDA-supply = <®_3v3_p>; 536 }; 537 538 touchscreen@5d { 539 compatible = "goodix,gt5688"; 540 reg = <0x5d>; 541 pinctrl-names = "default"; 542 pinctrl-0 = <&pinctrl_ts>; 543 interrupt-parent = <&gpio3>; 544 interrupts = <0 IRQ_TYPE_LEVEL_LOW>; 545 reset-gpios = <&gpio1 5 GPIO_ACTIVE_HIGH>; 546 irq-gpios = <&gpio3 0 GPIO_ACTIVE_HIGH>; 547 touchscreen-size-x = <720>; 548 touchscreen-size-y = <1440>; 549 AVDD28-supply = <®_2v8_p>; 550 VDDIO-supply = <®_1v8_p>; 551 }; 552 553 proximity-sensor@60 { 554 compatible = "vishay,vcnl4040"; 555 reg = <0x60>; 556 pinctrl-0 = <&pinctrl_prox>; 557 }; 558 559 accel-gyro@6a { 560 compatible = "st,lsm9ds1-imu"; 561 reg = <0x6a>; 562 vdd-supply = <®_3v3_p>; 563 vddio-supply = <®_3v3_p>; 564 mount-matrix = "1", "0", "0", 565 "0", "1", "0", 566 "0", "0", "-1"; 567 }; 568}; 569 570&iomuxc { 571 pinctrl_bl: blgrp { 572 fsl,pins = < 573 MX8MQ_IOMUXC_GPIO1_IO01_PWM1_OUT 0x6 /* DSI_BL_PWM */ 574 >; 575 }; 576 577 pinctrl_bt: btgrp { 578 fsl,pins = < 579 MX8MQ_IOMUXC_NAND_DATA05_GPIO3_IO11 0x16 /* nBT_DISABLE */ 580 MX8MQ_IOMUXC_NAND_DATA01_GPIO3_IO7 0x10 /* BT_HOST_WAKE */ 581 >; 582 }; 583 584 pinctrl_charger: chargergrp { 585 fsl,pins = < 586 MX8MQ_IOMUXC_SAI5_MCLK_GPIO3_IO25 0x80 /* CHRG_nINT */ 587 >; 588 }; 589 590 pinctrl_fec1: fec1grp { 591 fsl,pins = < 592 MX8MQ_IOMUXC_ENET_MDC_ENET1_MDC 0x3 593 MX8MQ_IOMUXC_ENET_MDIO_ENET1_MDIO 0x3 594 MX8MQ_IOMUXC_ENET_TD3_ENET1_RGMII_TD3 0x1f 595 MX8MQ_IOMUXC_ENET_TD2_ENET1_RGMII_TD2 0x1f 596 MX8MQ_IOMUXC_ENET_TD1_ENET1_RGMII_TD1 0x1f 597 MX8MQ_IOMUXC_ENET_TD0_ENET1_RGMII_TD0 0x1f 598 MX8MQ_IOMUXC_ENET_RD3_ENET1_RGMII_RD3 0x91 599 MX8MQ_IOMUXC_ENET_RD2_ENET1_RGMII_RD2 0x91 600 MX8MQ_IOMUXC_ENET_RD1_ENET1_RGMII_RD1 0x91 601 MX8MQ_IOMUXC_ENET_RD0_ENET1_RGMII_RD0 0x91 602 MX8MQ_IOMUXC_ENET_TXC_ENET1_RGMII_TXC 0x1f 603 MX8MQ_IOMUXC_ENET_RXC_ENET1_RGMII_RXC 0x91 604 MX8MQ_IOMUXC_ENET_RX_CTL_ENET1_RGMII_RX_CTL 0x91 605 MX8MQ_IOMUXC_ENET_TX_CTL_ENET1_RGMII_TX_CTL 0x1f 606 MX8MQ_IOMUXC_GPIO1_IO09_GPIO1_IO9 0x19 607 MX8MQ_IOMUXC_GPIO1_IO15_CCMSRCGPCMIX_CLKO2 0x1f 608 >; 609 }; 610 611 pinctrl_ts: tsgrp { 612 fsl,pins = < 613 MX8MQ_IOMUXC_NAND_ALE_GPIO3_IO0 0x16 /* TOUCH INT */ 614 MX8MQ_IOMUXC_GPIO1_IO05_GPIO1_IO5 0x19 /* TOUCH RST */ 615 >; 616 }; 617 618 pinctrl_pwm_led: pwmledgrp { 619 fsl,pins = < 620 MX8MQ_IOMUXC_GPIO1_IO13_PWM2_OUT 0x16 621 >; 622 }; 623 624 pinctrl_gpio_keys: gpiokeygrp { 625 fsl,pins = < 626 MX8MQ_IOMUXC_SAI2_RXFS_GPIO4_IO21 0x16 627 MX8MQ_IOMUXC_SAI2_RXC_GPIO4_IO22 0x16 628 MX8MQ_IOMUXC_NAND_DATA02_GPIO3_IO8 0x80 /* nWoWWAN */ 629 >; 630 }; 631 632 pinctrl_haptic: hapticgrp { 633 fsl,pins = < 634 MX8MQ_IOMUXC_SPDIF_RX_GPIO5_IO4 0xc6 /* nHAPTIC */ 635 >; 636 }; 637 638 pinctrl_hpdet: hpdetgrp { 639 fsl,pins = < 640 MX8MQ_IOMUXC_SAI5_RXC_GPIO3_IO20 0xC0 /* HP_DET */ 641 >; 642 }; 643 644 pinctrl_i2c1: i2c1grp { 645 fsl,pins = < 646 MX8MQ_IOMUXC_I2C1_SCL_I2C1_SCL 0x4000001f 647 MX8MQ_IOMUXC_I2C1_SDA_I2C1_SDA 0x4000001f 648 >; 649 }; 650 651 pinctrl_i2c3: i2c3grp { 652 fsl,pins = < 653 MX8MQ_IOMUXC_I2C3_SCL_I2C3_SCL 0x4000001f 654 MX8MQ_IOMUXC_I2C3_SDA_I2C3_SDA 0x4000001f 655 >; 656 }; 657 658 pinctrl_imu: imugrp { 659 fsl,pins = < 660 MX8MQ_IOMUXC_SAI5_RXFS_GPIO3_IO19 0x8 /* IMU_INT */ 661 >; 662 }; 663 664 pinctrl_micsel: micselgrp { 665 fsl,pins = < 666 MX8MQ_IOMUXC_SPDIF_EXT_CLK_GPIO5_IO5 0xc6 /* MIC_SEL */ 667 >; 668 }; 669 670 pinctrl_spkamp: spkamp { 671 fsl,pins = < 672 MX8MQ_IOMUXC_SPDIF_TX_GPIO5_IO3 0x81 /* MUTE */ 673 >; 674 }; 675 676 pinctrl_pmic: pmicgrp { 677 fsl,pins = < 678 MX8MQ_IOMUXC_GPIO1_IO03_GPIO1_IO3 0x80 /* PMIC intr */ 679 >; 680 }; 681 682 pinctrl_prox: proxgrp { 683 fsl,pins = < 684 MX8MQ_IOMUXC_GPIO1_IO12_GPIO1_IO12 0x80 /* prox intr */ 685 >; 686 }; 687 688 pinctrl_pwr_en: pwrengrp { 689 fsl,pins = < 690 MX8MQ_IOMUXC_GPIO1_IO08_GPIO1_IO8 0x06 691 >; 692 }; 693 694 pinctrl_rtc: rtcgrp { 695 fsl,pins = < 696 MX8MQ_IOMUXC_SAI3_RXC_GPIO4_IO29 0x80 /* RTC intr */ 697 >; 698 }; 699 700 pinctrl_sai2: sai2grp { 701 fsl,pins = < 702 MX8MQ_IOMUXC_SAI2_TXFS_SAI2_TX_SYNC 0xd6 703 MX8MQ_IOMUXC_SAI2_TXC_SAI2_TX_BCLK 0xd6 704 MX8MQ_IOMUXC_SAI2_TXD0_SAI2_TX_DATA0 0xd6 705 MX8MQ_IOMUXC_SAI2_RXD0_SAI2_RX_DATA0 0xd6 706 MX8MQ_IOMUXC_SAI2_MCLK_SAI2_MCLK 0xd6 707 >; 708 }; 709 710 pinctrl_sai6: sai6grp { 711 fsl,pins = < 712 MX8MQ_IOMUXC_SAI1_RXD5_SAI6_RX_DATA0 0xd6 713 MX8MQ_IOMUXC_SAI1_RXD6_SAI6_RX_SYNC 0xd6 714 MX8MQ_IOMUXC_SAI1_TXD4_SAI6_RX_BCLK 0xd6 715 MX8MQ_IOMUXC_SAI1_TXD5_SAI6_TX_DATA0 0xd6 716 >; 717 }; 718 719 pinctrl_typec: typecgrp { 720 fsl,pins = < 721 MX8MQ_IOMUXC_NAND_DATA06_GPIO3_IO12 0x16 722 MX8MQ_IOMUXC_NAND_CE0_B_GPIO3_IO1 0x80 723 >; 724 }; 725 726 pinctrl_uart1: uart1grp { 727 fsl,pins = < 728 MX8MQ_IOMUXC_UART1_RXD_UART1_DCE_RX 0x49 729 MX8MQ_IOMUXC_UART1_TXD_UART1_DCE_TX 0x49 730 >; 731 }; 732 733 pinctrl_uart2: uart2grp { 734 fsl,pins = < 735 MX8MQ_IOMUXC_UART2_TXD_UART2_DCE_TX 0x49 736 MX8MQ_IOMUXC_UART2_RXD_UART2_DCE_RX 0x49 737 MX8MQ_IOMUXC_UART4_RXD_UART2_DCE_CTS_B 0x49 738 MX8MQ_IOMUXC_UART4_TXD_UART2_DCE_RTS_B 0x49 739 >; 740 }; 741 742 pinctrl_uart3: uart3grp { 743 fsl,pins = < 744 MX8MQ_IOMUXC_UART3_RXD_UART3_DCE_RX 0x49 745 MX8MQ_IOMUXC_UART3_TXD_UART3_DCE_TX 0x49 746 >; 747 }; 748 749 pinctrl_uart4: uart4grp { 750 fsl,pins = < 751 MX8MQ_IOMUXC_ECSPI2_SCLK_UART4_DCE_RX 0x49 752 MX8MQ_IOMUXC_ECSPI2_MOSI_UART4_DCE_TX 0x49 753 MX8MQ_IOMUXC_ECSPI2_MISO_UART4_DCE_CTS_B 0x49 754 MX8MQ_IOMUXC_ECSPI2_SS0_UART4_DCE_RTS_B 0x49 755 MX8MQ_IOMUXC_GPIO1_IO00_ANAMIX_REF_CLK_32K 0x49 756 >; 757 }; 758 759 pinctrl_usdhc1: usdhc1grp { 760 fsl,pins = < 761 MX8MQ_IOMUXC_SD1_CLK_USDHC1_CLK 0x83 762 MX8MQ_IOMUXC_SD1_CMD_USDHC1_CMD 0xc3 763 MX8MQ_IOMUXC_SD1_DATA0_USDHC1_DATA0 0xc3 764 MX8MQ_IOMUXC_SD1_DATA1_USDHC1_DATA1 0xc3 765 MX8MQ_IOMUXC_SD1_DATA2_USDHC1_DATA2 0xc3 766 MX8MQ_IOMUXC_SD1_DATA3_USDHC1_DATA3 0xc3 767 MX8MQ_IOMUXC_SD1_DATA4_USDHC1_DATA4 0xc3 768 MX8MQ_IOMUXC_SD1_DATA5_USDHC1_DATA5 0xc3 769 MX8MQ_IOMUXC_SD1_DATA6_USDHC1_DATA6 0xc3 770 MX8MQ_IOMUXC_SD1_DATA7_USDHC1_DATA7 0xc3 771 MX8MQ_IOMUXC_SD1_STROBE_USDHC1_STROBE 0x83 772 MX8MQ_IOMUXC_SD1_RESET_B_USDHC1_RESET_B 0xc1 773 >; 774 }; 775 776 pinctrl_usdhc1_100mhz: usdhc1-100mhzgrp { 777 fsl,pins = < 778 MX8MQ_IOMUXC_SD1_CLK_USDHC1_CLK 0x8d 779 MX8MQ_IOMUXC_SD1_CMD_USDHC1_CMD 0xcd 780 MX8MQ_IOMUXC_SD1_DATA0_USDHC1_DATA0 0xcd 781 MX8MQ_IOMUXC_SD1_DATA1_USDHC1_DATA1 0xcd 782 MX8MQ_IOMUXC_SD1_DATA2_USDHC1_DATA2 0xcd 783 MX8MQ_IOMUXC_SD1_DATA3_USDHC1_DATA3 0xcd 784 MX8MQ_IOMUXC_SD1_DATA4_USDHC1_DATA4 0xcd 785 MX8MQ_IOMUXC_SD1_DATA5_USDHC1_DATA5 0xcd 786 MX8MQ_IOMUXC_SD1_DATA6_USDHC1_DATA6 0xcd 787 MX8MQ_IOMUXC_SD1_DATA7_USDHC1_DATA7 0xcd 788 MX8MQ_IOMUXC_SD1_STROBE_USDHC1_STROBE 0x8d 789 MX8MQ_IOMUXC_SD1_RESET_B_USDHC1_RESET_B 0xc1 790 >; 791 }; 792 793 pinctrl_usdhc1_200mhz: usdhc1-200mhzgrp { 794 fsl,pins = < 795 MX8MQ_IOMUXC_SD1_CLK_USDHC1_CLK 0x9f 796 MX8MQ_IOMUXC_SD1_CMD_USDHC1_CMD 0xdf 797 MX8MQ_IOMUXC_SD1_DATA0_USDHC1_DATA0 0xdf 798 MX8MQ_IOMUXC_SD1_DATA1_USDHC1_DATA1 0xdf 799 MX8MQ_IOMUXC_SD1_DATA2_USDHC1_DATA2 0xdf 800 MX8MQ_IOMUXC_SD1_DATA3_USDHC1_DATA3 0xdf 801 MX8MQ_IOMUXC_SD1_DATA4_USDHC1_DATA4 0xdf 802 MX8MQ_IOMUXC_SD1_DATA5_USDHC1_DATA5 0xdf 803 MX8MQ_IOMUXC_SD1_DATA6_USDHC1_DATA6 0xdf 804 MX8MQ_IOMUXC_SD1_DATA7_USDHC1_DATA7 0xdf 805 MX8MQ_IOMUXC_SD1_STROBE_USDHC1_STROBE 0x9f 806 MX8MQ_IOMUXC_SD1_RESET_B_USDHC1_RESET_B 0xc1 807 >; 808 }; 809 810 pinctrl_usdhc2_pwr: usdhc2pwrgrp { 811 fsl,pins = < 812 MX8MQ_IOMUXC_SD2_RESET_B_GPIO2_IO19 0x41 813 >; 814 }; 815 816 pinctrl_usdhc2_gpio: usdhc2gpiogrp { 817 fsl,pins = < 818 MX8MQ_IOMUXC_SD2_WP_GPIO2_IO20 0x80 /* WIFI_WAKE */ 819 >; 820 }; 821 822 pinctrl_usdhc2: usdhc2grp { 823 fsl,pins = < 824 MX8MQ_IOMUXC_SD2_CLK_USDHC2_CLK 0x83 825 MX8MQ_IOMUXC_SD2_CMD_USDHC2_CMD 0xc3 826 MX8MQ_IOMUXC_SD2_DATA0_USDHC2_DATA0 0xc3 827 MX8MQ_IOMUXC_SD2_DATA1_USDHC2_DATA1 0xc3 828 MX8MQ_IOMUXC_SD2_DATA2_USDHC2_DATA2 0xc3 829 MX8MQ_IOMUXC_SD2_DATA3_USDHC2_DATA3 0xc3 830 >; 831 }; 832 833 pinctrl_usdhc2_100mhz: usdhc2-100mhzgrp { 834 fsl,pins = < 835 MX8MQ_IOMUXC_SD2_CLK_USDHC2_CLK 0x8d 836 MX8MQ_IOMUXC_SD2_CMD_USDHC2_CMD 0xcd 837 MX8MQ_IOMUXC_SD2_DATA0_USDHC2_DATA0 0xcd 838 MX8MQ_IOMUXC_SD2_DATA1_USDHC2_DATA1 0xcd 839 MX8MQ_IOMUXC_SD2_DATA2_USDHC2_DATA2 0xcd 840 MX8MQ_IOMUXC_SD2_DATA3_USDHC2_DATA3 0xcd 841 >; 842 }; 843 844 pinctrl_usdhc2_200mhz: usdhc2-200mhzgrp { 845 fsl,pins = < 846 MX8MQ_IOMUXC_SD2_CLK_USDHC2_CLK 0x9f 847 MX8MQ_IOMUXC_SD2_CMD_USDHC2_CMD 0xcf 848 MX8MQ_IOMUXC_SD2_DATA0_USDHC2_DATA0 0xcf 849 MX8MQ_IOMUXC_SD2_DATA1_USDHC2_DATA1 0xcf 850 MX8MQ_IOMUXC_SD2_DATA2_USDHC2_DATA2 0xcf 851 MX8MQ_IOMUXC_SD2_DATA3_USDHC2_DATA3 0xcf 852 >; 853 }; 854 855 pinctrl_wdog: wdoggrp { 856 fsl,pins = < 857 MX8MQ_IOMUXC_GPIO1_IO02_WDOG1_WDOG_B 0xc6 858 >; 859 }; 860 861 pinctrl_wifi_pwr_en: wifipwrengrp { 862 fsl,pins = < 863 MX8MQ_IOMUXC_NAND_CLE_GPIO3_IO5 0x06 864 >; 865 }; 866 867 pinctrl_wwan: wwangrp { 868 fsl,pins = < 869 MX8MQ_IOMUXC_NAND_CE3_B_GPIO3_IO4 0x09 /* nWWAN_DISABLE */ 870 MX8MQ_IOMUXC_NAND_DATA02_GPIO3_IO8 0x80 /* nWoWWAN */ 871 MX8MQ_IOMUXC_NAND_DATA03_GPIO3_IO9 0x19 /* WWAN_RESET */ 872 >; 873 }; 874}; 875 876&lcdif { 877 status = "okay"; 878}; 879 880&mipi_dsi { 881 status = "okay"; 882 #address-cells = <1>; 883 #size-cells = <0>; 884 885 panel@0 { 886 compatible = "rocktech,jh057n00900"; 887 reg = <0>; 888 backlight = <&backlight_dsi>; 889 reset-gpios = <&gpio3 13 GPIO_ACTIVE_LOW>; 890 iovcc-supply = <®_1v8_p>; 891 vcc-supply = <®_2v8_p>; 892 port { 893 panel_in: endpoint { 894 remote-endpoint = <&mipi_dsi_out>; 895 }; 896 }; 897 }; 898 899 ports { 900 port@1 { 901 reg = <1>; 902 mipi_dsi_out: endpoint { 903 remote-endpoint = <&panel_in>; 904 }; 905 }; 906 }; 907}; 908 909&pgc_gpu { 910 power-supply = <&buck3_reg>; 911}; 912 913&pgc_vpu { 914 power-supply = <&buck4_reg>; 915}; 916 917&pwm1 { 918 pinctrl-names = "default"; 919 pinctrl-0 = <&pinctrl_bl>; 920 status = "okay"; 921}; 922 923&pwm2 { 924 pinctrl-names = "default"; 925 pinctrl-0 = <&pinctrl_pwm_led>; 926 status = "okay"; 927}; 928 929&snvs_pwrkey { 930 status = "okay"; 931}; 932 933&snvs_rtc { 934 status = "disabled"; 935}; 936 937&sai2 { 938 pinctrl-names = "default"; 939 pinctrl-0 = <&pinctrl_sai2>; 940 assigned-clocks = <&clk IMX8MQ_CLK_SAI2>; 941 assigned-clock-parents = <&clk IMX8MQ_AUDIO_PLL1_OUT>; 942 assigned-clock-rates = <24576000>; 943 status = "okay"; 944}; 945 946&sai6 { 947 pinctrl-names = "default"; 948 pinctrl-0 = <&pinctrl_sai6>; 949 assigned-clocks = <&clk IMX8MQ_CLK_SAI6>; 950 assigned-clock-parents = <&clk IMX8MQ_AUDIO_PLL1_OUT>; 951 assigned-clock-rates = <24576000>; 952 fsl,sai-synchronous-rx; 953 status = "okay"; 954}; 955 956&uart1 { /* console */ 957 pinctrl-names = "default"; 958 pinctrl-0 = <&pinctrl_uart1>; 959 status = "okay"; 960}; 961 962&uart3 { /* GNSS */ 963 pinctrl-names = "default"; 964 pinctrl-0 = <&pinctrl_uart3>; 965 status = "okay"; 966}; 967 968&uart4 { /* BT */ 969 pinctrl-names = "default"; 970 pinctrl-0 = <&pinctrl_uart4>, <&pinctrl_bt>; 971 uart-has-rtscts; 972 status = "okay"; 973}; 974 975&usb3_phy0 { 976 vbus-supply = <®_5v_p>; 977 status = "okay"; 978}; 979 980&usb3_phy1 { 981 vbus-supply = <®_5v_p>; 982 status = "okay"; 983}; 984 985&usb_dwc3_0 { 986 #address-cells = <1>; 987 #size-cells = <0>; 988 dr_mode = "otg"; 989 status = "okay"; 990 991 port@0 { 992 reg = <0>; 993 994 typec_hs: endpoint { 995 remote-endpoint = <&usb_con_hs>; 996 }; 997 }; 998 999 port@1 { 1000 reg = <1>; 1001 1002 typec_ss: endpoint { 1003 remote-endpoint = <&usb_con_ss>; 1004 }; 1005 }; 1006}; 1007 1008&usb_dwc3_1 { 1009 dr_mode = "host"; 1010 status = "okay"; 1011}; 1012 1013&usdhc1 { 1014 assigned-clocks = <&clk IMX8MQ_CLK_USDHC1>; 1015 assigned-clock-rates = <400000000>; 1016 pinctrl-names = "default", "state_100mhz", "state_200mhz"; 1017 pinctrl-0 = <&pinctrl_usdhc1>; 1018 pinctrl-1 = <&pinctrl_usdhc1_100mhz>; 1019 pinctrl-2 = <&pinctrl_usdhc1_200mhz>; 1020 bus-width = <8>; 1021 non-removable; 1022 status = "okay"; 1023}; 1024 1025&usdhc2 { 1026 assigned-clocks = <&clk IMX8MQ_CLK_USDHC2>; 1027 assigned-clock-rates = <200000000>; 1028 pinctrl-names = "default", "state_100mhz", "state_200mhz"; 1029 pinctrl-0 = <&pinctrl_usdhc2>; 1030 pinctrl-1 = <&pinctrl_usdhc2_100mhz>; 1031 pinctrl-2 = <&pinctrl_usdhc2_200mhz>; 1032 bus-width = <4>; 1033 vmmc-supply = <®_usdhc2_vmmc>; 1034 power-supply = <&wifi_pwr_en>; 1035 broken-cd; 1036 disable-wp; 1037 cap-sdio-irq; 1038 keep-power-in-suspend; 1039 wakeup-source; 1040 status = "okay"; 1041}; 1042 1043&wdog1 { 1044 pinctrl-names = "default"; 1045 pinctrl-0 = <&pinctrl_wdog>; 1046 fsl,ext-reset-output; 1047 status = "okay"; 1048}; 1049