1 // SPDX-License-Identifier: GPL-2.0+
3 * Copyright 2018-2020 Purism SPC
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"
16 model = "Purism Librem 5";
17 compatible = "purism,librem5", "fsl,imx8mq";
18 chassis-type = "handset";
20 backlight_dsi: backlight-dsi {
21 compatible = "led-backlight";
22 leds = <&led_backlight>;
23 brightness-levels = <255>;
24 default-brightness-level = <190>;
27 pmic_osc: clock-pmic {
28 compatible = "fixed-clock";
30 clock-frequency = <32768>;
31 clock-output-names = "pmic_osc";
39 compatible = "gpio-keys";
40 pinctrl-names = "default";
41 pinctrl-0 = <&pinctrl_keys>;
45 gpios = <&gpio1 17 GPIO_ACTIVE_LOW>;
46 linux,code = <KEY_VOLUMEDOWN>;
47 debounce-interval = <50>;
53 gpios = <&gpio1 16 GPIO_ACTIVE_LOW>;
54 linux,code = <KEY_VOLUMEUP>;
55 debounce-interval = <50>;
61 compatible = "pwm-leds-multicolor";
64 color = <LED_COLOR_ID_RGB>;
65 function = LED_FUNCTION_STATUS;
66 max-brightness = <248>;
69 color = <LED_COLOR_ID_BLUE>;
70 pwms = <&pwm2 0 50000 0>;
74 color = <LED_COLOR_ID_GREEN>;
75 pwms = <&pwm4 0 50000 0>;
79 color = <LED_COLOR_ID_RED>;
80 pwms = <&pwm3 0 50000 0>;
85 reg_aud_1v8: regulator-audio-1v8 {
86 compatible = "regulator-fixed";
87 pinctrl-names = "default";
88 pinctrl-0 = <&pinctrl_audiopwr>;
89 regulator-name = "AUD_1V8";
90 regulator-min-microvolt = <1800000>;
91 regulator-max-microvolt = <1800000>;
92 gpio = <&gpio1 4 GPIO_ACTIVE_HIGH>;
97 reg_mic_2v4: regulator-mic-2v4 {
98 compatible = "regulator-fixed";
99 regulator-name = "MIC_2V4";
100 regulator-min-microvolt = <2400000>;
101 regulator-max-microvolt = <2400000>;
102 vin-supply = <®_aud_1v8>;
106 * the pinctrl for reg_csi_1v8 and reg_vcam_1v8 is added to the PMIC
107 * since we can't have it twice in the 2 different regulator nodes.
109 reg_csi_1v8: regulator-csi-1v8 {
110 compatible = "regulator-fixed";
111 regulator-name = "CAMERA_VDDIO_1V8";
112 regulator-min-microvolt = <1800000>;
113 regulator-max-microvolt = <1800000>;
114 vin-supply = <®_vdd_3v3>;
115 gpio = <&gpio1 0 GPIO_ACTIVE_HIGH>;
119 /* controlled by the CAMERA_POWER_KEY HKS */
120 reg_vcam_1v2: regulator-vcam-1v2 {
121 compatible = "regulator-fixed";
122 regulator-name = "CAMERA_VDDD_1V2";
123 regulator-min-microvolt = <1200000>;
124 regulator-max-microvolt = <1200000>;
125 vin-supply = <®_vdd_1v8>;
129 reg_vcam_2v8: regulator-vcam-2v8 {
130 compatible = "regulator-fixed";
131 regulator-name = "CAMERA_VDDA_2V8";
132 regulator-min-microvolt = <2800000>;
133 regulator-max-microvolt = <2800000>;
134 vin-supply = <®_vdd_3v3>;
135 gpio = <&gpio1 0 GPIO_ACTIVE_HIGH>;
139 reg_gnss: regulator-gnss {
140 compatible = "regulator-fixed";
141 pinctrl-names = "default";
142 pinctrl-0 = <&pinctrl_gnsspwr>;
143 regulator-name = "GNSS";
144 regulator-min-microvolt = <3300000>;
145 regulator-max-microvolt = <3300000>;
146 gpio = <&gpio3 12 GPIO_ACTIVE_HIGH>;
150 reg_hub: regulator-hub {
151 compatible = "regulator-fixed";
152 pinctrl-names = "default";
153 pinctrl-0 = <&pinctrl_hub_pwr>;
154 regulator-name = "HUB";
155 regulator-min-microvolt = <3300000>;
156 regulator-max-microvolt = <3300000>;
157 gpio = <&gpio1 14 GPIO_ACTIVE_HIGH>;
161 reg_lcd_1v8: regulator-lcd-1v8 {
162 compatible = "regulator-fixed";
163 pinctrl-names = "default";
164 pinctrl-0 = <&pinctrl_dsien>;
165 regulator-name = "LCD_1V8";
166 regulator-min-microvolt = <1800000>;
167 regulator-max-microvolt = <1800000>;
168 vin-supply = <®_vdd_1v8>;
169 gpio = <&gpio1 5 GPIO_ACTIVE_HIGH>;
171 /* Otherwise i2c3 is not functional */
175 reg_lcd_3v4: regulator-lcd-3v4 {
176 compatible = "regulator-fixed";
177 regulator-name = "LCD_3V4";
178 pinctrl-names = "default";
179 pinctrl-0 = <&pinctrl_dsibiasen>;
180 vin-supply = <®_vsys_3v4>;
181 gpio = <&gpio1 20 GPIO_ACTIVE_HIGH>;
185 reg_vdd_sen: regulator-vdd-sen {
186 compatible = "regulator-fixed";
187 regulator-name = "VDD_SEN";
188 regulator-min-microvolt = <3300000>;
189 regulator-max-microvolt = <3300000>;
192 reg_vdd_1v8: regulator-vdd-1v8 {
193 compatible = "regulator-fixed";
194 regulator-name = "VDD_1V8";
195 regulator-min-microvolt = <1800000>;
196 regulator-max-microvolt = <1800000>;
197 vin-supply = <&buck7_reg>;
200 reg_vdd_3v3: regulator-vdd-3v3 {
201 compatible = "regulator-fixed";
202 regulator-name = "VDD_3V3";
203 regulator-min-microvolt = <3300000>;
204 regulator-max-microvolt = <3300000>;
207 reg_vsys_3v4: regulator-vsys-3v4 {
208 compatible = "regulator-fixed";
209 regulator-name = "VSYS_3V4";
210 regulator-min-microvolt = <3400000>;
211 regulator-max-microvolt = <3400000>;
215 reg_wifi_3v3: regulator-wifi-3v3 {
216 compatible = "regulator-fixed";
217 pinctrl-names = "default";
218 pinctrl-0 = <&pinctrl_wifi_pwr>;
219 regulator-name = "3V3_WIFI";
220 regulator-min-microvolt = <3300000>;
221 regulator-max-microvolt = <3300000>;
222 gpio = <&gpio3 10 GPIO_ACTIVE_HIGH>;
224 vin-supply = <®_vdd_3v3>;
228 compatible = "simple-audio-card";
229 pinctrl-names = "default";
230 pinctrl-0 = <&pinctrl_hp>;
231 simple-audio-card,name = "Librem 5";
232 simple-audio-card,format = "i2s";
233 simple-audio-card,widgets =
234 "Headphone", "Headphones",
235 "Microphone", "Headset Mic",
236 "Microphone", "Digital Mic",
237 "Speaker", "Speaker";
238 simple-audio-card,routing =
239 "Headphones", "HPOUTL",
240 "Headphones", "HPOUTR",
241 "Speaker", "SPKOUTL",
242 "Speaker", "SPKOUTR",
243 "Headset Mic", "MICBIAS",
244 "IN3R", "Headset Mic",
245 "DMICDAT", "Digital Mic";
246 simple-audio-card,hp-det-gpio = <&gpio3 9 GPIO_ACTIVE_HIGH>;
248 simple-audio-card,cpu {
252 simple-audio-card,codec {
253 sound-dai = <&codec>;
254 clocks = <&clk IMX8MQ_CLK_SAI2_ROOT>;
261 compatible = "simple-audio-card";
262 simple-audio-card,name = "Modem";
263 simple-audio-card,format = "i2s";
265 simple-audio-card,cpu {
270 simple-audio-card,codec {
271 sound-dai = <&bm818_codec>;
277 usdhc2_pwrseq: pwrseq {
278 pinctrl-names = "default";
279 pinctrl-0 = <&pinctrl_bt>, <&pinctrl_wifi_disable>;
280 compatible = "mmc-pwrseq-simple";
281 reset-gpios = <&gpio3 25 GPIO_ACTIVE_HIGH>,
282 <&gpio4 29 GPIO_ACTIVE_HIGH>;
285 bm818_codec: sound-wwan-codec {
286 compatible = "broadmobi,bm818", "option,gtm601";
287 #sound-dai-cells = <0>;
291 compatible = "pwm-vibrator";
292 pwms = <&pwm1 0 1000000000 0>;
293 pwm-names = "enable";
294 vcc-supply = <®_vdd_3v3>;
299 cpu-supply = <&buck2_reg>;
303 cpu-supply = <&buck2_reg>;
307 cpu-supply = <&buck2_reg>;
311 cpu-supply = <&buck2_reg>;
319 operating-points-v2 = <&ddrc_opp_table>;
322 ddrc_opp_table: opp-table {
323 compatible = "operating-points-v2";
326 opp-hz = /bits/ 64 <25000000>;
330 opp-hz = /bits/ 64 <100000000>;
334 opp-hz = /bits/ 64 <166935483>;
338 opp-hz = /bits/ 64 <800000000>;
348 pinctrl-names = "default";
349 pinctrl-0 = <&pinctrl_ecspi1>;
350 cs-gpios = <&gpio5 9 GPIO_ACTIVE_LOW>;
351 #address-cells = <1>;
356 compatible = "jedec,spi-nor";
358 spi-max-frequency = <1000000>;
359 #address-cells = <1>;
363 label = "protected0";
370 reg = <0x30000 0x1d0000>;
377 pinctrl-names = "default";
378 pinctrl-0 = <&pinctrl_pmic_5v>;
382 gpios = <1 GPIO_ACTIVE_HIGH>;
384 line-name = "pmic-5v";
389 pinctrl-names = "default";
390 pinctrl-0 = <&pinctrl_hog>;
392 pinctrl_hog: hoggrp {
394 /* CLKO2 for cameras on both CSI1 and CSI2 */
395 MX8MQ_IOMUXC_GPIO1_IO15_CCMSRCGPCMIX_CLKO2 0x1f
399 pinctrl_audiopwr: audiopwrgrp {
401 /* AUDIO_POWER_EN_3V3 */
402 MX8MQ_IOMUXC_GPIO1_IO04_GPIO1_IO4 0x83
409 MX8MQ_IOMUXC_NAND_DQS_GPIO3_IO14 0x83
416 MX8MQ_IOMUXC_SAI5_MCLK_GPIO3_IO25 0x83
420 pinctrl_camera_pwr: camerapwrgrp {
422 /* CAMERA_PWR_EN_3V3 */
423 MX8MQ_IOMUXC_GPIO1_IO00_GPIO1_IO0 0x83
427 pinctrl_csi1: csi1grp {
430 MX8MQ_IOMUXC_ENET_RXC_GPIO1_IO25 0x83
434 pinctrl_charger_in: chargeringrp {
437 MX8MQ_IOMUXC_NAND_CE2_B_GPIO3_IO3 0x80
441 pinctrl_dsibiasen: dsibiasengrp {
444 MX8MQ_IOMUXC_ENET_TD1_GPIO1_IO20 0x83
448 pinctrl_dsien: dsiengrp {
451 MX8MQ_IOMUXC_GPIO1_IO05_GPIO1_IO5 0x83
455 pinctrl_dsirst: dsirstgrp {
458 MX8MQ_IOMUXC_ENET_RD3_GPIO1_IO29 0x83
460 MX8MQ_IOMUXC_ENET_RD2_GPIO1_IO28 0x83
462 MX8MQ_IOMUXC_ENET_RX_CTL_GPIO1_IO24 0x83
466 pinctrl_ecspi1: ecspigrp {
468 MX8MQ_IOMUXC_ECSPI1_MOSI_ECSPI1_MOSI 0x83
469 MX8MQ_IOMUXC_ECSPI1_MISO_ECSPI1_MISO 0x83
470 MX8MQ_IOMUXC_ECSPI1_SS0_GPIO5_IO9 0x19
471 MX8MQ_IOMUXC_ECSPI1_SCLK_ECSPI1_SCLK 0x83
475 pinctrl_gauge: gaugegrp {
478 MX8MQ_IOMUXC_SAI5_RXC_GPIO3_IO20 0x80
482 pinctrl_gnsspwr: gnsspwrgrp {
485 MX8MQ_IOMUXC_NAND_DATA06_GPIO3_IO12 0x83
489 pinctrl_haptic: hapticgrp {
492 MX8MQ_IOMUXC_SPDIF_EXT_CLK_PWM1_OUT 0x83
498 /* HEADPHONE_DET_1V8 */
499 MX8MQ_IOMUXC_NAND_DATA03_GPIO3_IO9 0x180
503 pinctrl_hub_pwr: hubpwrgrp {
506 MX8MQ_IOMUXC_GPIO1_IO14_GPIO1_IO14 0x83
510 pinctrl_i2c1: i2c1grp {
512 MX8MQ_IOMUXC_I2C1_SCL_I2C1_SCL 0x40000026
513 MX8MQ_IOMUXC_I2C1_SDA_I2C1_SDA 0x40000026
517 pinctrl_i2c2: i2c2grp {
519 MX8MQ_IOMUXC_I2C2_SCL_I2C2_SCL 0x40000026
520 MX8MQ_IOMUXC_I2C2_SDA_I2C2_SDA 0x40000026
524 pinctrl_i2c3: i2c3grp {
526 MX8MQ_IOMUXC_I2C3_SCL_I2C3_SCL 0x40000026
527 MX8MQ_IOMUXC_I2C3_SDA_I2C3_SDA 0x40000026
531 pinctrl_i2c4: i2c4grp {
533 MX8MQ_IOMUXC_I2C4_SCL_I2C4_SCL 0x40000026
534 MX8MQ_IOMUXC_I2C4_SDA_I2C4_SDA 0x40000026
538 pinctrl_keys: keysgrp {
541 MX8MQ_IOMUXC_ENET_MDIO_GPIO1_IO17 0x01C0
543 MX8MQ_IOMUXC_ENET_MDC_GPIO1_IO16 0x01C0
547 pinctrl_led_b: ledbgrp {
550 MX8MQ_IOMUXC_GPIO1_IO13_PWM2_OUT 0x06
554 pinctrl_led_g: ledggrp {
557 MX8MQ_IOMUXC_SAI3_MCLK_PWM4_OUT 0x06
561 pinctrl_led_r: ledrgrp {
564 MX8MQ_IOMUXC_SPDIF_TX_PWM3_OUT 0x06
568 pinctrl_mag: maggrp {
571 MX8MQ_IOMUXC_SAI5_RXD1_GPIO3_IO22 0x80
575 pinctrl_pmic: pmicgrp {
578 MX8MQ_IOMUXC_GPIO1_IO07_GPIO1_IO7 0x80
582 pinctrl_pmic_5v: pmic5vgrp {
585 MX8MQ_IOMUXC_GPIO1_IO01_GPIO1_IO1 0x80
589 pinctrl_prox: proxgrp {
592 MX8MQ_IOMUXC_NAND_DATA01_GPIO3_IO7 0x80
596 pinctrl_rtc: rtcgrp {
599 MX8MQ_IOMUXC_GPIO1_IO09_GPIO1_IO9 0x80
603 pinctrl_sai2: sai2grp {
605 MX8MQ_IOMUXC_SAI2_TXD0_SAI2_TX_DATA0 0xd6
606 MX8MQ_IOMUXC_SAI2_TXFS_SAI2_TX_SYNC 0xd6
607 MX8MQ_IOMUXC_SAI2_MCLK_SAI2_MCLK 0xd6
608 MX8MQ_IOMUXC_SAI2_RXD0_SAI2_RX_DATA0 0xd6
609 MX8MQ_IOMUXC_SAI2_TXC_SAI2_TX_BCLK 0xd6
613 pinctrl_sai6: sai6grp {
615 MX8MQ_IOMUXC_SAI1_RXD5_SAI6_RX_DATA0 0xd6
616 MX8MQ_IOMUXC_SAI1_RXD6_SAI6_RX_SYNC 0xd6
617 MX8MQ_IOMUXC_SAI1_TXD4_SAI6_RX_BCLK 0xd6
618 MX8MQ_IOMUXC_SAI1_TXD5_SAI6_TX_DATA0 0xd6
622 pinctrl_tcpc: tcpcgrp {
625 MX8MQ_IOMUXC_GPIO1_IO10_GPIO1_IO10 0x01C0
629 pinctrl_touch: touchgrp {
632 MX8MQ_IOMUXC_ENET_RD1_GPIO1_IO27 0x80
636 pinctrl_typec: typecgrp {
639 MX8MQ_IOMUXC_GPIO1_IO11_GPIO1_IO11 0x83
643 pinctrl_uart1: uart1grp {
645 MX8MQ_IOMUXC_UART1_RXD_UART1_DCE_RX 0x49
646 MX8MQ_IOMUXC_UART1_TXD_UART1_DCE_TX 0x49
650 pinctrl_uart2: uart2grp {
652 MX8MQ_IOMUXC_UART2_TXD_UART2_DCE_TX 0x49
653 MX8MQ_IOMUXC_UART2_RXD_UART2_DCE_RX 0x49
657 pinctrl_uart3: uart3grp {
659 MX8MQ_IOMUXC_UART3_RXD_UART3_DCE_RX 0x49
660 MX8MQ_IOMUXC_UART3_TXD_UART3_DCE_TX 0x49
664 pinctrl_uart4: uart4grp {
666 MX8MQ_IOMUXC_ECSPI2_SCLK_UART4_DCE_RX 0x49
667 MX8MQ_IOMUXC_ECSPI2_MOSI_UART4_DCE_TX 0x49
668 MX8MQ_IOMUXC_ECSPI2_MISO_UART4_DCE_CTS_B 0x49
669 MX8MQ_IOMUXC_ECSPI2_SS0_UART4_DCE_RTS_B 0x49
673 pinctrl_usdhc1: usdhc1grp {
675 MX8MQ_IOMUXC_SD1_CLK_USDHC1_CLK 0x83
676 MX8MQ_IOMUXC_SD1_CMD_USDHC1_CMD 0xc3
677 MX8MQ_IOMUXC_SD1_DATA0_USDHC1_DATA0 0xc3
678 MX8MQ_IOMUXC_SD1_DATA1_USDHC1_DATA1 0xc3
679 MX8MQ_IOMUXC_SD1_DATA2_USDHC1_DATA2 0xc3
680 MX8MQ_IOMUXC_SD1_DATA3_USDHC1_DATA3 0xc3
681 MX8MQ_IOMUXC_SD1_DATA4_USDHC1_DATA4 0xc3
682 MX8MQ_IOMUXC_SD1_DATA5_USDHC1_DATA5 0xc3
683 MX8MQ_IOMUXC_SD1_DATA6_USDHC1_DATA6 0xc3
684 MX8MQ_IOMUXC_SD1_DATA7_USDHC1_DATA7 0xc3
685 MX8MQ_IOMUXC_SD1_STROBE_USDHC1_STROBE 0x83
686 MX8MQ_IOMUXC_SD1_RESET_B_USDHC1_RESET_B 0xc1
690 pinctrl_usdhc1_100mhz: usdhc1-100mhzgrp {
692 MX8MQ_IOMUXC_SD1_CLK_USDHC1_CLK 0x8d
693 MX8MQ_IOMUXC_SD1_CMD_USDHC1_CMD 0xcd
694 MX8MQ_IOMUXC_SD1_DATA0_USDHC1_DATA0 0xcd
695 MX8MQ_IOMUXC_SD1_DATA1_USDHC1_DATA1 0xcd
696 MX8MQ_IOMUXC_SD1_DATA2_USDHC1_DATA2 0xcd
697 MX8MQ_IOMUXC_SD1_DATA3_USDHC1_DATA3 0xcd
698 MX8MQ_IOMUXC_SD1_DATA4_USDHC1_DATA4 0xcd
699 MX8MQ_IOMUXC_SD1_DATA5_USDHC1_DATA5 0xcd
700 MX8MQ_IOMUXC_SD1_DATA6_USDHC1_DATA6 0xcd
701 MX8MQ_IOMUXC_SD1_DATA7_USDHC1_DATA7 0xcd
702 MX8MQ_IOMUXC_SD1_STROBE_USDHC1_STROBE 0x8d
703 MX8MQ_IOMUXC_SD1_RESET_B_USDHC1_RESET_B 0xc1
707 pinctrl_usdhc1_200mhz: usdhc1-200mhzgrp {
709 MX8MQ_IOMUXC_SD1_CLK_USDHC1_CLK 0x9f
710 MX8MQ_IOMUXC_SD1_CMD_USDHC1_CMD 0xdf
711 MX8MQ_IOMUXC_SD1_DATA0_USDHC1_DATA0 0xdf
712 MX8MQ_IOMUXC_SD1_DATA1_USDHC1_DATA1 0xdf
713 MX8MQ_IOMUXC_SD1_DATA2_USDHC1_DATA2 0xdf
714 MX8MQ_IOMUXC_SD1_DATA3_USDHC1_DATA3 0xdf
715 MX8MQ_IOMUXC_SD1_DATA4_USDHC1_DATA4 0xdf
716 MX8MQ_IOMUXC_SD1_DATA5_USDHC1_DATA5 0xdf
717 MX8MQ_IOMUXC_SD1_DATA6_USDHC1_DATA6 0xdf
718 MX8MQ_IOMUXC_SD1_DATA7_USDHC1_DATA7 0xdf
719 MX8MQ_IOMUXC_SD1_STROBE_USDHC1_STROBE 0x9f
720 MX8MQ_IOMUXC_SD1_RESET_B_USDHC1_RESET_B 0xc1
724 pinctrl_usdhc2: usdhc2grp {
726 MX8MQ_IOMUXC_SD2_CD_B_GPIO2_IO12 0x80
727 MX8MQ_IOMUXC_SD2_CLK_USDHC2_CLK 0x83
728 MX8MQ_IOMUXC_SD2_CMD_USDHC2_CMD 0xc3
729 MX8MQ_IOMUXC_SD2_DATA0_USDHC2_DATA0 0xc3
730 MX8MQ_IOMUXC_SD2_DATA1_USDHC2_DATA1 0xc3
731 MX8MQ_IOMUXC_SD2_DATA2_USDHC2_DATA2 0xc3
732 MX8MQ_IOMUXC_SD2_DATA3_USDHC2_DATA3 0xc3
733 MX8MQ_IOMUXC_SD2_RESET_B_USDHC2_RESET_B 0xc1
737 pinctrl_usdhc2_100mhz: usdhc2-100mhzgrp {
739 MX8MQ_IOMUXC_SD2_CD_B_GPIO2_IO12 0x80
740 MX8MQ_IOMUXC_SD2_CLK_USDHC2_CLK 0x8d
741 MX8MQ_IOMUXC_SD2_CMD_USDHC2_CMD 0xcd
742 MX8MQ_IOMUXC_SD2_DATA0_USDHC2_DATA0 0xcd
743 MX8MQ_IOMUXC_SD2_DATA1_USDHC2_DATA1 0xcd
744 MX8MQ_IOMUXC_SD2_DATA2_USDHC2_DATA2 0xcd
745 MX8MQ_IOMUXC_SD2_DATA3_USDHC2_DATA3 0xcd
746 MX8MQ_IOMUXC_SD2_RESET_B_USDHC2_RESET_B 0xc1
750 pinctrl_usdhc2_200mhz: usdhc2-200mhzgrp {
752 MX8MQ_IOMUXC_SD2_CD_B_GPIO2_IO12 0x80
753 MX8MQ_IOMUXC_SD2_CLK_USDHC2_CLK 0x9f
754 MX8MQ_IOMUXC_SD2_CMD_USDHC2_CMD 0xcf
755 MX8MQ_IOMUXC_SD2_DATA0_USDHC2_DATA0 0xcf
756 MX8MQ_IOMUXC_SD2_DATA1_USDHC2_DATA1 0xcf
757 MX8MQ_IOMUXC_SD2_DATA2_USDHC2_DATA2 0xcf
758 MX8MQ_IOMUXC_SD2_DATA3_USDHC2_DATA3 0xcf
759 MX8MQ_IOMUXC_SD2_RESET_B_USDHC2_RESET_B 0xc1
763 pinctrl_wifi_disable: wifidisablegrp {
766 MX8MQ_IOMUXC_SAI3_RXC_GPIO4_IO29 0x83
770 pinctrl_wifi_pwr: wifipwrgrp {
773 MX8MQ_IOMUXC_NAND_DATA04_GPIO3_IO10 0x83
777 pinctrl_wdog: wdoggrp {
780 MX8MQ_IOMUXC_GPIO1_IO02_WDOG1_WDOG_B 0x1f
786 clock-frequency = <384000>;
787 pinctrl-names = "default";
788 pinctrl-0 = <&pinctrl_i2c1>;
791 typec_pd: usb-pd@3f {
792 compatible = "ti,tps6598x";
794 pinctrl-names = "default";
795 pinctrl-0 = <&pinctrl_typec>, <&pinctrl_tcpc>;
796 interrupt-parent = <&gpio1>;
797 interrupts = <10 IRQ_TYPE_LEVEL_LOW>;
798 interrupt-names = "irq";
799 extcon = <&usb3_phy0>;
803 compatible = "usb-c-connector";
808 #address-cells = <1>;
814 usb_con_hs: endpoint {
815 remote-endpoint = <&typec_hs>;
822 usb_con_ss: endpoint {
823 remote-endpoint = <&typec_ss>;
831 compatible = "rohm,bd71837";
833 pinctrl-names = "default";
834 pinctrl-0 = <&pinctrl_pmic>, <&pinctrl_camera_pwr>;
835 clocks = <&pmic_osc>;
838 clock-output-names = "pmic_clk";
839 interrupt-parent = <&gpio1>;
840 interrupts = <7 IRQ_TYPE_LEVEL_LOW>;
841 rohm,reset-snvs-powered;
845 regulator-name = "buck1";
846 regulator-min-microvolt = <700000>;
847 regulator-max-microvolt = <1300000>;
849 regulator-ramp-delay = <1250>;
850 rohm,dvs-run-voltage = <880000>;
851 rohm,dvs-idle-voltage = <820000>;
852 rohm,dvs-suspend-voltage = <810000>;
857 regulator-name = "buck2";
858 regulator-min-microvolt = <700000>;
859 regulator-max-microvolt = <1300000>;
861 regulator-ramp-delay = <1250>;
862 rohm,dvs-run-voltage = <950000>;
863 rohm,dvs-idle-voltage = <850000>;
868 regulator-name = "buck3";
869 regulator-min-microvolt = <700000>;
870 regulator-max-microvolt = <1300000>;
872 rohm,dvs-run-voltage = <850000>;
876 regulator-name = "buck4";
877 regulator-min-microvolt = <700000>;
878 regulator-max-microvolt = <1300000>;
879 rohm,dvs-run-voltage = <930000>;
883 regulator-name = "buck5";
884 regulator-min-microvolt = <700000>;
885 regulator-max-microvolt = <1350000>;
891 regulator-name = "buck6";
892 regulator-min-microvolt = <3000000>;
893 regulator-max-microvolt = <3300000>;
899 regulator-name = "buck7";
900 regulator-min-microvolt = <1605000>;
901 regulator-max-microvolt = <1995000>;
907 regulator-name = "buck8";
908 regulator-min-microvolt = <800000>;
909 regulator-max-microvolt = <1400000>;
915 regulator-name = "ldo1";
916 regulator-min-microvolt = <3000000>;
917 regulator-max-microvolt = <3300000>;
919 /* leave on for snvs power button */
924 regulator-name = "ldo2";
925 regulator-min-microvolt = <900000>;
926 regulator-max-microvolt = <900000>;
928 /* leave on for snvs power button */
933 regulator-name = "ldo3";
934 regulator-min-microvolt = <1800000>;
935 regulator-max-microvolt = <3300000>;
941 regulator-name = "ldo4";
942 regulator-min-microvolt = <900000>;
943 regulator-max-microvolt = <1800000>;
949 /* VDD_PHY_0V9 - MIPI and HDMI domains */
950 regulator-name = "ldo5";
951 regulator-min-microvolt = <1800000>;
952 regulator-max-microvolt = <3300000>;
957 /* VDD_PHY_0V9 - MIPI, HDMI and USB domains */
958 regulator-name = "ldo6";
959 regulator-min-microvolt = <900000>;
960 regulator-max-microvolt = <1800000>;
966 /* VDD_PHY_3V3 - USB domain */
967 regulator-name = "ldo7";
968 regulator-min-microvolt = <1800000>;
969 regulator-max-microvolt = <3300000>;
977 compatible = "microcrystal,rv4162";
979 pinctrl-names = "default";
980 pinctrl-0 = <&pinctrl_rtc>;
981 interrupt-parent = <&gpio1>;
982 interrupts = <9 IRQ_TYPE_LEVEL_LOW>;
987 clock-frequency = <384000>;
988 pinctrl-names = "default";
989 pinctrl-0 = <&pinctrl_i2c2>;
992 magnetometer: magnetometer@1e {
993 compatible = "st,lsm9ds1-magn";
995 pinctrl-names = "default";
996 pinctrl-0 = <&pinctrl_mag>;
997 interrupt-parent = <&gpio3>;
998 interrupts = <22 IRQ_TYPE_LEVEL_HIGH>;
999 vdd-supply = <®_vdd_sen>;
1000 vddio-supply = <®_vdd_1v8>;
1004 compatible = "ti,tps65132";
1007 reg_lcd_avdd: outp {
1008 regulator-name = "LCD_AVDD";
1009 vin-supply = <®_lcd_3v4>;
1012 reg_lcd_avee: outn {
1013 regulator-name = "LCD_AVEE";
1014 vin-supply = <®_lcd_3v4>;
1018 proximity: prox@60 {
1019 compatible = "vishay,vcnl4040";
1021 pinctrl-names = "default";
1022 pinctrl-0 = <&pinctrl_prox>;
1023 interrupt-parent = <&gpio3>;
1024 interrupts = <7 IRQ_TYPE_LEVEL_LOW>;
1027 accel_gyro: accel-gyro@6a {
1028 compatible = "st,lsm9ds1-imu";
1030 vdd-supply = <®_vdd_sen>;
1031 vddio-supply = <®_vdd_1v8>;
1036 clock-frequency = <384000>;
1037 pinctrl-names = "default";
1038 pinctrl-0 = <&pinctrl_i2c3>;
1041 codec: audio-codec@1a {
1042 compatible = "wlf,wm8962";
1044 clocks = <&clk IMX8MQ_CLK_SAI2_ROOT>;
1045 assigned-clocks = <&clk IMX8MQ_CLK_SAI2>;
1046 assigned-clock-parents = <&clk IMX8MQ_AUDIO_PLL1_OUT>;
1047 assigned-clock-rates = <24576000>;
1048 #sound-dai-cells = <0>;
1050 DCVDD-supply = <®_aud_1v8>;
1051 DBVDD-supply = <®_aud_1v8>;
1052 AVDD-supply = <®_aud_1v8>;
1053 CPVDD-supply = <®_aud_1v8>;
1054 MICVDD-supply = <®_mic_2v4>;
1055 PLLVDD-supply = <®_aud_1v8>;
1056 SPKVDD1-supply = <®_vsys_3v4>;
1057 SPKVDD2-supply = <®_vsys_3v4>;
1060 0x0001 /* gpio2, 1: default */
1061 0x0013 /* gpio3, 2: dmicclk */
1062 0x0000 /* n/c, 3: default */
1063 0x8014 /* gpio5, 4: dmic_dat */
1064 0x0000 /* gpio6, 5: default */
1068 camera_front: camera@20 {
1069 compatible = "hynix,hi846";
1071 pinctrl-names = "default";
1072 pinctrl-0 = <&pinctrl_csi1>;
1073 clocks = <&clk IMX8MQ_CLK_CLKO2>;
1074 assigned-clocks = <&clk IMX8MQ_CLK_CLKO2>;
1075 assigned-clock-rates = <25000000>;
1076 reset-gpios = <&gpio1 25 GPIO_ACTIVE_LOW>;
1077 vdda-supply = <®_vcam_2v8>;
1078 vddd-supply = <®_vcam_1v2>;
1079 vddio-supply = <®_csi_1v8>;
1084 camera1_ep: endpoint {
1086 link-frequencies = /bits/ 64
1087 <80000000 200000000 300000000>;
1088 remote-endpoint = <&mipi1_sensor_ep>;
1094 compatible = "ti,lm36922";
1096 pinctrl-names = "default";
1097 pinctrl-0 = <&pinctrl_bl>;
1098 #address-cells = <1>;
1100 enable-gpios = <&gpio3 14 GPIO_ACTIVE_HIGH>;
1101 vled-supply = <®_vsys_3v4>;
1102 ti,ovp-microvolt = <25000000>;
1104 led_backlight: led@0 {
1106 label = ":backlight";
1107 linux,default-trigger = "backlight";
1108 led-max-microamp = <20000>;
1113 compatible = "edt,edt-ft5506";
1115 pinctrl-names = "default";
1116 pinctrl-0 = <&pinctrl_touch>;
1117 interrupt-parent = <&gpio1>;
1118 interrupts = <27 IRQ_TYPE_EDGE_FALLING>;
1119 touchscreen-size-x = <720>;
1120 touchscreen-size-y = <1440>;
1121 vcc-supply = <®_lcd_1v8>;
1126 clock-frequency = <384000>;
1127 pinctrl-names = "default";
1128 pinctrl-0 = <&pinctrl_i2c4>;
1132 compatible = "dongwoon,dw9714";
1134 vcc-supply = <®_csi_1v8>;
1137 bat: fuel-gauge@36 {
1138 compatible = "maxim,max17055";
1140 interrupt-parent = <&gpio3>;
1141 interrupts = <20 IRQ_TYPE_LEVEL_LOW>;
1142 pinctrl-names = "default";
1143 pinctrl-0 = <&pinctrl_gauge>;
1144 power-supplies = <&bq25895>;
1145 maxim,over-heat-temp = <700>;
1146 maxim,over-volt = <4500>;
1147 maxim,rsns-microohm = <5000>;
1150 bq25895: charger@6a {
1151 compatible = "ti,bq25895", "ti,bq25890";
1153 pinctrl-names = "default";
1154 pinctrl-0 = <&pinctrl_charger_in>;
1155 interrupt-parent = <&gpio3>;
1156 interrupts = <3 IRQ_TYPE_EDGE_FALLING>;
1157 ti,battery-regulation-voltage = <4208000>; /* uV */
1158 ti,termination-current = <128000>; /* uA */
1159 ti,precharge-current = <128000>; /* uA */
1160 ti,minimum-sys-voltage = <3700000>; /* uV */
1161 ti,boost-voltage = <5000000>; /* uV */
1162 ti,boost-max-current = <1500000>; /* uA */
1163 monitored-battery = <&bat>;
1164 power-supplies = <&typec_pd>;
1173 assigned-clock-rates = <266000000>, <200000000>, <66000000>;
1180 mipi1_sensor_ep: endpoint {
1181 remote-endpoint = <&camera1_ep>;
1189 #address-cells = <1>;
1193 lcd_panel: panel@0 {
1194 compatible = "mantix,mlaf057we51-x";
1196 pinctrl-names = "default";
1197 pinctrl-0 = <&pinctrl_dsirst>;
1198 avdd-supply = <®_lcd_avdd>;
1199 avee-supply = <®_lcd_avee>;
1200 vddi-supply = <®_lcd_1v8>;
1201 backlight = <&backlight_dsi>;
1202 reset-gpios = <&gpio1 29 GPIO_ACTIVE_LOW>;
1203 mantix,tp-rstn-gpios = <&gpio1 24 GPIO_ACTIVE_LOW>;
1206 panel_in: endpoint {
1207 remote-endpoint = <&mipi_dsi_out>;
1216 mipi_dsi_out: endpoint {
1217 remote-endpoint = <&panel_in>;
1224 power-supply = <&buck3_reg>;
1228 power-supply = <&ldo5_reg>;
1232 power-supply = <&buck4_reg>;
1236 pinctrl-names = "default";
1237 pinctrl-0 = <&pinctrl_haptic>;
1242 pinctrl-names = "default";
1243 pinctrl-0 = <&pinctrl_led_b>;
1248 pinctrl-names = "default";
1249 pinctrl-0 = <&pinctrl_led_r>;
1254 pinctrl-names = "default";
1255 pinctrl-0 = <&pinctrl_led_g>;
1260 pinctrl-names = "default";
1261 pinctrl-0 = <&pinctrl_sai2>;
1262 assigned-clocks = <&clk IMX8MQ_CLK_SAI2>;
1263 assigned-clock-parents = <&clk IMX8MQ_AUDIO_PLL1_OUT>;
1264 assigned-clock-rates = <24576000>;
1269 pinctrl-names = "default";
1270 pinctrl-0 = <&pinctrl_sai6>;
1271 assigned-clocks = <&clk IMX8MQ_CLK_SAI6>;
1272 assigned-clock-parents = <&clk IMX8MQ_AUDIO_PLL1_OUT>;
1273 assigned-clock-rates = <24576000>;
1274 fsl,sai-synchronous-rx;
1283 status = "disabled";
1286 &uart1 { /* console */
1287 pinctrl-names = "default";
1288 pinctrl-0 = <&pinctrl_uart1>;
1292 &uart2 { /* TPS - GPS - DEBUG */
1293 pinctrl-names = "default";
1294 pinctrl-0 = <&pinctrl_uart2>;
1298 compatible = "globaltop,pa6h";
1299 vcc-supply = <®_gnss>;
1300 current-speed = <9600>;
1305 pinctrl-names = "default";
1306 pinctrl-0 = <&pinctrl_uart3>;
1311 pinctrl-names = "default";
1312 pinctrl-0 = <&pinctrl_uart4>;
1322 vbus-supply = <®_hub>;
1327 #address-cells = <1>;
1336 typec_hs: endpoint {
1337 remote-endpoint = <&usb_con_hs>;
1344 typec_ss: endpoint {
1345 remote-endpoint = <&usb_con_ss>;
1353 #address-cells = <1>;
1356 /* Microchip USB2642 */
1358 compatible = "usb424,2640";
1360 #address-cells = <1>;
1364 compatible = "usb424,4041";
1371 assigned-clocks = <&clk IMX8MQ_CLK_USDHC1>;
1372 assigned-clock-rates = <400000000>;
1373 pinctrl-names = "default", "state_100mhz", "state_200mhz";
1374 pinctrl-0 = <&pinctrl_usdhc1>;
1375 pinctrl-1 = <&pinctrl_usdhc1_100mhz>;
1376 pinctrl-2 = <&pinctrl_usdhc1_200mhz>;
1378 vmmc-supply = <®_vdd_3v3>;
1379 vqmmc-supply = <®_vdd_1v8>;
1385 assigned-clocks = <&clk IMX8MQ_CLK_USDHC2>;
1386 assigned-clock-rates = <200000000>;
1387 pinctrl-names = "default", "state_100mhz", "state_200mhz";
1388 pinctrl-0 = <&pinctrl_usdhc2>;
1389 pinctrl-1 = <&pinctrl_usdhc2_100mhz>;
1390 pinctrl-2 = <&pinctrl_usdhc2_200mhz>;
1392 vmmc-supply = <®_wifi_3v3>;
1393 mmc-pwrseq = <&usdhc2_pwrseq>;
1394 post-power-on-delay-ms = <20>;
1395 cd-gpios = <&gpio2 12 GPIO_ACTIVE_LOW>;
1396 max-frequency = <100000000>;
1399 keep-power-in-suspend;
1405 pinctrl-names = "default";
1406 pinctrl-0 = <&pinctrl_wdog>;
1407 fsl,ext-reset-output;
1413 opp-microvolt = <850000>;
1417 opp-microvolt = <950000>;