Loading...
Note: File does not exist in v4.6.
1// SPDX-License-Identifier: (GPL-2.0 OR MIT)
2/*
3 * Copyright (C) 2022 MediaTek Inc.
4 */
5/dts-v1/;
6#include "mt8186.dtsi"
7#include <dt-bindings/pinctrl/mt8186-pinfunc.h>
8#include <dt-bindings/gpio/gpio.h>
9#include <dt-bindings/input/input.h>
10#include <dt-bindings/input/gpio-keys.h>
11#include <dt-bindings/regulator/mediatek,mt6397-regulator.h>
12
13/ {
14 aliases {
15 i2c0 = &i2c0;
16 i2c1 = &i2c1;
17 i2c2 = &i2c2;
18 i2c3 = &i2c3;
19 i2c5 = &i2c5;
20 mmc0 = &mmc0;
21 mmc1 = &mmc1;
22 serial0 = &uart0;
23 };
24
25 chosen {
26 stdout-path = "serial0:115200n8";
27 };
28
29 memory@40000000 {
30 device_type = "memory";
31 /* The size should be filled in by the bootloader. */
32 reg = <0 0x40000000 0 0>;
33 };
34
35 backlight_lcd0: backlight-lcd0 {
36 compatible = "pwm-backlight";
37 pwms = <&pwm0 0 500000>;
38 power-supply = <&ppvar_sys>;
39 enable-gpios = <&pio 152 0>;
40 brightness-levels = <0 1023>;
41 num-interpolated-steps = <1023>;
42 default-brightness-level = <576>;
43 };
44
45 bt-sco {
46 compatible = "linux,bt-sco";
47 #sound-dai-cells = <0>;
48 };
49
50 dmic-codec {
51 compatible = "dmic-codec";
52 #sound-dai-cells = <0>;
53 num-channels = <2>;
54 wakeup-delay-ms = <50>;
55 };
56
57 gpio_keys: gpio-keys {
58 compatible = "gpio-keys";
59 pinctrl-names = "default";
60 pinctrl-0 = <&pen_eject>;
61
62 pen_insert: pen-insert-switch {
63 label = "Pen Insert";
64 /* Insert = low, eject = high */
65 gpios = <&pio 18 GPIO_ACTIVE_LOW>;
66 wakeup-event-action = <EV_ACT_DEASSERTED>;
67 wakeup-source;
68 linux,code = <SW_PEN_INSERTED>;
69 linux,input-type = <EV_SW>;
70 };
71 };
72
73 pp1800_dpbrdg_dx: regulator-pp1800-dpbrdg-dx {
74 compatible = "regulator-fixed";
75 pinctrl-names = "default";
76 pinctrl-0 = <&en_pp1800_dpbrdg>;
77 gpios = <&pio 39 GPIO_ACTIVE_HIGH>;
78 regulator-name = "pp1800_dpbrdg_dx";
79 enable-active-high;
80 vin-supply = <&mt6366_vio18_reg>;
81 };
82
83 pp3300_disp_x: regulator-pp3300-disp-x {
84 compatible = "regulator-fixed";
85 pinctrl-names = "default";
86 pinctrl-0 = <&edp_panel_fixed_pins>;
87 gpios = <&pio 153 GPIO_ACTIVE_HIGH>;
88 regulator-name = "pp3300_disp_x";
89 enable-active-high;
90 regulator-boot-on;
91 vin-supply = <&pp3300_z2>;
92 };
93
94 /* system wide LDO 3.3V power rail */
95 pp3300_z5: regulator-pp3300-ldo-z5 {
96 compatible = "regulator-fixed";
97 regulator-name = "pp3300_ldo_z5";
98 regulator-always-on;
99 regulator-boot-on;
100 regulator-min-microvolt = <3300000>;
101 regulator-max-microvolt = <3300000>;
102 vin-supply = <&ppvar_sys>;
103 };
104
105 /* separately switched 3.3V power rail */
106 pp3300_s3: regulator-pp3300-s3 {
107 compatible = "regulator-fixed";
108 regulator-name = "pp3300_s3";
109 /* automatically sequenced by PMIC EXT_PMIC_EN2 */
110 regulator-always-on;
111 regulator-boot-on;
112 vin-supply = <&pp3300_z2>;
113 };
114
115 /* system wide 3.3V power rail */
116 pp3300_z2: regulator-pp3300-z2 {
117 compatible = "regulator-fixed";
118 regulator-name = "pp3300_z2";
119 /* EN pin tied to pp4200_z2, which is controlled by EC */
120 regulator-always-on;
121 regulator-boot-on;
122 regulator-min-microvolt = <3300000>;
123 regulator-max-microvolt = <3300000>;
124 vin-supply = <&ppvar_sys>;
125 };
126
127 /* system wide 4.2V power rail */
128 pp4200_z2: regulator-pp4200-z2 {
129 compatible = "regulator-fixed";
130 regulator-name = "pp4200_z2";
131 /* controlled by EC */
132 regulator-always-on;
133 regulator-boot-on;
134 regulator-min-microvolt = <4200000>;
135 regulator-max-microvolt = <4200000>;
136 vin-supply = <&ppvar_sys>;
137 };
138
139 /* system wide switching 5.0V power rail */
140 pp5000_z2: regulator-pp5000-z2 {
141 compatible = "regulator-fixed";
142 regulator-name = "pp5000_z2";
143 /* controlled by EC */
144 regulator-always-on;
145 regulator-boot-on;
146 regulator-min-microvolt = <5000000>;
147 regulator-max-microvolt = <5000000>;
148 vin-supply = <&ppvar_sys>;
149 };
150
151 /* system wide semi-regulated power rail from battery or USB */
152 ppvar_sys: regulator-ppvar-sys {
153 compatible = "regulator-fixed";
154 regulator-name = "ppvar_sys";
155 regulator-always-on;
156 regulator-boot-on;
157 };
158
159 reserved_memory: reserved-memory {
160 #address-cells = <2>;
161 #size-cells = <2>;
162 ranges;
163
164 adsp_dma_mem: memory@61000000 {
165 compatible = "shared-dma-pool";
166 reg = <0 0x61000000 0 0x100000>;
167 no-map;
168 };
169
170 adsp_mem: memory@60000000 {
171 compatible = "shared-dma-pool";
172 reg = <0 0x60000000 0 0x1000000>;
173 no-map;
174 };
175
176 scp_mem: memory@50000000 {
177 compatible = "shared-dma-pool";
178 reg = <0 0x50000000 0 0x10a0000>;
179 no-map;
180 };
181 };
182
183 sound: sound {
184 compatible = "mediatek,mt8186-mt6366-rt1019-rt5682s-sound";
185 pinctrl-names = "aud_clk_mosi_off",
186 "aud_clk_mosi_on",
187 "aud_clk_miso_off",
188 "aud_clk_miso_on",
189 "aud_dat_miso_off",
190 "aud_dat_miso_on",
191 "aud_dat_mosi_off",
192 "aud_dat_mosi_on",
193 "aud_gpio_i2s0_off",
194 "aud_gpio_i2s0_on",
195 "aud_gpio_i2s1_off",
196 "aud_gpio_i2s1_on",
197 "aud_gpio_i2s2_off",
198 "aud_gpio_i2s2_on",
199 "aud_gpio_i2s3_off",
200 "aud_gpio_i2s3_on",
201 "aud_gpio_pcm_off",
202 "aud_gpio_pcm_on",
203 "aud_gpio_dmic_sec";
204 pinctrl-0 = <&aud_clk_mosi_off>;
205 pinctrl-1 = <&aud_clk_mosi_on>;
206 pinctrl-2 = <&aud_clk_miso_off>;
207 pinctrl-3 = <&aud_clk_miso_on>;
208 pinctrl-4 = <&aud_dat_miso_off>;
209 pinctrl-5 = <&aud_dat_miso_on>;
210 pinctrl-6 = <&aud_dat_mosi_off>;
211 pinctrl-7 = <&aud_dat_mosi_on>;
212 pinctrl-8 = <&aud_gpio_i2s0_off>;
213 pinctrl-9 = <&aud_gpio_i2s0_on>;
214 pinctrl-10 = <&aud_gpio_i2s1_off>;
215 pinctrl-11 = <&aud_gpio_i2s1_on>;
216 pinctrl-12 = <&aud_gpio_i2s2_off>;
217 pinctrl-13 = <&aud_gpio_i2s2_on>;
218 pinctrl-14 = <&aud_gpio_i2s3_off>;
219 pinctrl-15 = <&aud_gpio_i2s3_on>;
220 pinctrl-16 = <&aud_gpio_pcm_off>;
221 pinctrl-17 = <&aud_gpio_pcm_on>;
222 pinctrl-18 = <&aud_gpio_dmic_sec>;
223 mediatek,adsp = <&adsp>;
224 mediatek,platform = <&afe>;
225
226 audio-routing =
227 "Headphone", "HPOL",
228 "Headphone", "HPOR",
229 "IN1P", "Headset Mic",
230 "Speakers", "Speaker",
231 "HDMI1", "TX";
232
233 hs-playback-dai-link {
234 link-name = "I2S0";
235 dai-format = "i2s";
236 mediatek,clk-provider = "cpu";
237 codec {
238 sound-dai = <&rt5682s 0>;
239 };
240 };
241
242 hs-capture-dai-link {
243 link-name = "I2S1";
244 dai-format = "i2s";
245 mediatek,clk-provider = "cpu";
246 codec {
247 sound-dai = <&rt5682s 0>;
248 };
249 };
250
251 spk-share-dai-link {
252 link-name = "I2S2";
253 mediatek,clk-provider = "cpu";
254 };
255
256 spk-hdmi-playback-dai-link {
257 link-name = "I2S3";
258 dai-format = "i2s";
259 mediatek,clk-provider = "cpu";
260 /* RT1019P and IT6505 connected to the same I2S line */
261 codec {
262 sound-dai = <&it6505dptx>, <&speaker_codec>;
263 };
264 };
265 };
266
267 speaker_codec: speaker-codec {
268 compatible = "realtek,rt1019p";
269 pinctrl-names = "default";
270 pinctrl-0 = <&speaker_codec_pins_default>;
271 #sound-dai-cells = <0>;
272 sdb-gpios = <&pio 150 GPIO_ACTIVE_HIGH>;
273 };
274
275 usb_p1_vbus: regulator-usb-p1-vbus {
276 compatible = "regulator-fixed";
277 gpio = <&pio 148 GPIO_ACTIVE_HIGH>;
278 regulator-name = "vbus1";
279 regulator-min-microvolt = <5000000>;
280 regulator-max-microvolt = <5000000>;
281 enable-active-high;
282 vin-supply = <&pp5000_z2>;
283 };
284
285 wifi_pwrseq: wifi-pwrseq {
286 compatible = "mmc-pwrseq-simple";
287 pinctrl-names = "default";
288 pinctrl-0 = <&wifi_enable_pin>;
289 post-power-on-delay-ms = <50>;
290 reset-gpios = <&pio 54 GPIO_ACTIVE_LOW>;
291 };
292
293 wifi_wakeup: wifi-wakeup {
294 compatible = "gpio-keys";
295 pinctrl-names = "default";
296 pinctrl-0 = <&wifi_wakeup_pin>;
297
298 wowlan-event {
299 label = "Wake on WiFi";
300 gpios = <&pio 7 GPIO_ACTIVE_LOW>;
301 linux,code = <KEY_WAKEUP>;
302 wakeup-source;
303 };
304 };
305};
306
307&adsp {
308 memory-region = <&adsp_dma_mem>, <&adsp_mem>;
309 status = "okay";
310};
311
312&afe {
313 status = "okay";
314};
315
316&cci {
317 proc-supply = <&mt6366_vproc12_reg>;
318};
319
320&cpu0 {
321 proc-supply = <&mt6366_vproc12_reg>;
322};
323
324&cpu1 {
325 proc-supply = <&mt6366_vproc12_reg>;
326};
327
328&cpu2 {
329 proc-supply = <&mt6366_vproc12_reg>;
330};
331
332&cpu3 {
333 proc-supply = <&mt6366_vproc12_reg>;
334};
335
336&cpu4 {
337 proc-supply = <&mt6366_vproc12_reg>;
338};
339
340&cpu5 {
341 proc-supply = <&mt6366_vproc12_reg>;
342};
343
344&cpu6 {
345 proc-supply = <&mt6366_vproc11_reg>;
346};
347
348&cpu7 {
349 proc-supply = <&mt6366_vproc11_reg>;
350};
351
352&dpi {
353 pinctrl-names = "default", "sleep";
354 pinctrl-0 = <&dpi_pins_default>;
355 pinctrl-1 = <&dpi_pins_sleep>;
356 /* TODO Re-enable after DP to Type-C port muxing can be described */
357 status = "disabled";
358};
359
360&dpi_out {
361 remote-endpoint = <&it6505_in>;
362};
363
364&dsi0 {
365 status = "okay";
366};
367
368&gic {
369 mediatek,broken-save-restore-fw;
370};
371
372&gpu {
373 mali-supply = <&mt6366_vgpu_reg>;
374 status = "okay";
375};
376
377&i2c0 {
378 pinctrl-names = "default";
379 pinctrl-0 = <&i2c0_pins>;
380 status = "okay";
381};
382
383&i2c1 {
384 pinctrl-names = "default";
385 pinctrl-0 = <&i2c1_pins>;
386 clock-frequency = <400000>;
387 i2c-scl-internal-delay-ns = <8000>;
388 status = "okay";
389};
390
391&i2c2 {
392 pinctrl-names = "default";
393 /*
394 * Trackpad pin put here to work around second source components
395 * sharing the pinmux in steelix designs.
396 */
397 pinctrl-0 = <&i2c2_pins>, <&trackpad_pin>;
398 clock-frequency = <400000>;
399 i2c-scl-internal-delay-ns = <10000>;
400 status = "okay";
401
402 trackpad@15 {
403 compatible = "elan,ekth3000";
404 reg = <0x15>;
405 interrupts-extended = <&pio 11 IRQ_TYPE_LEVEL_LOW>;
406 vcc-supply = <&pp3300_s3>;
407 wakeup-source;
408 };
409};
410
411&i2c3 {
412 pinctrl-names = "default";
413 pinctrl-0 = <&i2c3_pins>;
414 clock-frequency = <100000>;
415 status = "okay";
416
417 it6505dptx: dp-bridge@5c {
418 compatible = "ite,it6505";
419 reg = <0x5c>;
420 interrupts-extended = <&pio 8 IRQ_TYPE_LEVEL_LOW>;
421 pinctrl-names = "default";
422 pinctrl-0 = <&it6505_pins>;
423 #sound-dai-cells = <0>;
424 ovdd-supply = <&mt6366_vsim2_reg>;
425 pwr18-supply = <&pp1800_dpbrdg_dx>;
426 reset-gpios = <&pio 177 GPIO_ACTIVE_LOW>;
427
428 ports {
429 #address-cells = <1>;
430 #size-cells = <0>;
431
432 port@0 {
433 reg = <0>;
434
435 it6505_in: endpoint {
436 link-frequencies = /bits/ 64 <150000000>;
437 remote-endpoint = <&dpi_out>;
438 };
439 };
440
441 port@1 {
442 reg = <1>;
443 };
444 };
445 };
446};
447
448&i2c5 {
449 pinctrl-names = "default";
450 pinctrl-0 = <&i2c5_pins>;
451 status = "okay";
452
453 rt5682s: codec@1a {
454 compatible = "realtek,rt5682s";
455 reg = <0x1a>;
456 interrupts-extended = <&pio 17 IRQ_TYPE_EDGE_BOTH>;
457 #sound-dai-cells = <1>;
458 AVDD-supply = <&mt6366_vio18_reg>;
459 DBVDD-supply = <&mt6366_vio18_reg>;
460 LDO1-IN-supply = <&mt6366_vio18_reg>;
461 MICVDD-supply = <&pp3300_z2>;
462 realtek,jd-src = <1>;
463 };
464};
465
466&mfg0 {
467 domain-supply = <&mt6366_vsram_gpu_reg>;
468};
469
470&mfg1 {
471 domain-supply = <&mt6366_vgpu_reg>;
472};
473
474&mipi_tx0 {
475 status = "okay";
476};
477
478&mmc0 {
479 pinctrl-names = "default", "state_uhs";
480 pinctrl-0 = <&mmc0_pins_default>;
481 pinctrl-1 = <&mmc0_pins_uhs>;
482 bus-width = <8>;
483 max-frequency = <200000000>;
484 non-removable;
485 cap-mmc-highspeed;
486 mmc-hs200-1_8v;
487 mmc-hs400-1_8v;
488 supports-cqe;
489 no-sd;
490 no-sdio;
491 cap-mmc-hw-reset;
492 hs400-ds-delay = <0x11814>;
493 mediatek,hs400-ds-dly3 = <0x14>;
494 vmmc-supply = <&mt6366_vemc_reg>;
495 vqmmc-supply = <&mt6366_vio18_reg>;
496 status = "okay";
497};
498
499&mmc1 {
500 pinctrl-names = "default", "state_uhs", "state_eint";
501 pinctrl-0 = <&mmc1_pins_default>;
502 pinctrl-1 = <&mmc1_pins_uhs>;
503 pinctrl-2 = <&mmc1_pins_eint>;
504 /delete-property/ interrupts;
505 interrupt-names = "msdc", "sdio_wakeup";
506 interrupts-extended = <&gic GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH 0>,
507 <&pio 87 IRQ_TYPE_LEVEL_LOW>;
508 #address-cells = <1>;
509 #size-cells = <0>;
510 bus-width = <4>;
511 max-frequency = <200000000>;
512 cap-sd-highspeed;
513 sd-uhs-sdr104;
514 sd-uhs-sdr50;
515 keep-power-in-suspend;
516 wakeup-source;
517 cap-sdio-irq;
518 no-mmc;
519 no-sd;
520 non-removable;
521 vmmc-supply = <&pp3300_s3>;
522 vqmmc-supply = <&mt6366_vio18_reg>;
523 mmc-pwrseq = <&wifi_pwrseq>;
524 status = "okay";
525
526 bluetooth@2 {
527 compatible = "mediatek,mt7921s-bluetooth";
528 reg = <2>;
529 pinctrl-names = "default";
530 pinctrl-0 = <&bt_pins_reset>;
531 reset-gpios = <&pio 155 GPIO_ACTIVE_LOW>;
532 };
533};
534
535&nor_flash {
536 assigned-clock-parents = <&topckgen CLK_TOP_MAINPLL_D7_D4>;
537 pinctrl-names = "default";
538 pinctrl-0 = <&nor_pins_default>;
539 #address-cells = <1>;
540 #size-cells = <0>;
541 status = "okay";
542
543 flash@0 {
544 compatible = "jedec,spi-nor";
545 reg = <0>;
546 spi-max-frequency = <39000000>;
547 };
548};
549
550&pio {
551 /* 185 lines */
552 gpio-line-names = "TP",
553 "TP",
554 "TP",
555 "I2S0_HP_DI",
556 "I2S3_DP_SPKR_DO",
557 "SAR_INT_ODL",
558 "BT_WAKE_AP_ODL",
559 "WIFI_INT_ODL",
560 "DPBRDG_INT_ODL",
561 "EDPBRDG_INT_ODL",
562 "EC_AP_HPD_OD",
563 "TCHPAD_INT_ODL",
564 "TCHSCR_INT_1V8_ODL",
565 "EC_AP_INT_ODL",
566 "EC_IN_RW_ODL",
567 "GSC_AP_INT_ODL",
568 /* AP_FLASH_WP_L is crossystem ABI. Rev1 schematics call it AP_WP_ODL. */
569 "AP_FLASH_WP_L",
570 "HP_INT_ODL",
571 "PEN_EJECT_OD",
572 "WCAM_PWDN_L",
573 "WCAM_RST_L",
574 "UCAM_SEN_EN",
575 "UCAM_RST_L",
576 "LTE_RESET_L",
577 "LTE_SAR_DETECT_L",
578 "I2S2_DP_SPK_MCK",
579 "I2S2_DP_SPKR_BCK",
580 "I2S2_DP_SPKR_LRCK",
581 "I2S2_DP_SPKR_DI (TP)",
582 "EN_PP1000_EDPBRDG",
583 "EN_PP1800_EDPBRDG",
584 "EN_PP3300_EDPBRDG",
585 "UART_GSC_TX_AP_RX",
586 "UART_AP_TX_GSC_RX",
587 "UART_DBGCON_TX_ADSP_RX",
588 "UART_ADSP_TX_DBGCON_RX",
589 "EN_PP1000_DPBRDG",
590 "TCHSCR_REPORT_DISABLE",
591 "EN_PP3300_DPBRDG",
592 "EN_PP1800_DPBRDG",
593 "SPI_AP_CLK_EC",
594 "SPI_AP_CS_EC_L",
595 "SPI_AP_DO_EC_DI",
596 "SPI_AP_DI_EC_DO",
597 "SPI_AP_CLK_GSC",
598 "SPI_AP_CS_GSC_L",
599 "SPI_AP_DO_GSC_DI",
600 "SPI_AP_DI_GSC_DO",
601 "UART_DBGCON_TX_SCP_RX",
602 "UART_SCP_TX_DBGCON_RX",
603 "EN_PP1200_CAM_X",
604 "EN_PP2800A_VCM_X",
605 "EN_PP2800A_UCAM_X",
606 "EN_PP2800A_WCAM_X",
607 "WLAN_MODULE_RST_L",
608 "EN_PP1200_UCAM_X",
609 "I2S1_HP_DO",
610 "I2S1_HP_BCK",
611 "I2S1_HP_LRCK",
612 "I2S1_HP_MCK",
613 "TCHSCR_RST_1V8_L",
614 "SPI_AP_CLK_ROM",
615 "SPI_AP_CS_ROM_L",
616 "SPI_AP_DO_ROM_DI",
617 "SPI_AP_DI_ROM_DO",
618 "NC",
619 "NC",
620 "EMMC_STRB",
621 "EMMC_CLK",
622 "EMMC_CMD",
623 "EMMC_RST_L",
624 "EMMC_DATA0",
625 "EMMC_DATA1",
626 "EMMC_DATA2",
627 "EMMC_DATA3",
628 "EMMC_DATA4",
629 "EMMC_DATA5",
630 "EMMC_DATA6",
631 "EMMC_DATA7",
632 "AP_KPCOL0",
633 "NC",
634 "NC",
635 "NC",
636 "TP",
637 "SDIO_CLK",
638 "SDIO_CMD",
639 "SDIO_DATA0",
640 "SDIO_DATA1",
641 "SDIO_DATA2",
642 "SDIO_DATA3",
643 "NC",
644 "NC",
645 "NC",
646 "NC",
647 "NC",
648 "NC",
649 "EDPBRDG_PWREN",
650 "BL_PWM_1V8",
651 "EDPBRDG_RST_L",
652 "MIPI_DPI_CLK",
653 "MIPI_DPI_VSYNC",
654 "MIPI_DPI_HSYNC",
655 "MIPI_DPI_DE",
656 "MIPI_DPI_D0",
657 "MIPI_DPI_D1",
658 "MIPI_DPI_D2",
659 "MIPI_DPI_D3",
660 "MIPI_DPI_D4",
661 "MIPI_DPI_D5",
662 "MIPI_DPI_D6",
663 "MIPI_DPI_DA7",
664 "MIPI_DPI_D8",
665 "MIPI_DPI_D9",
666 "MIPI_DPI_D10",
667 "MIPI_DPI_D11",
668 "PCM_BT_CLK",
669 "PCM_BT_SYNC",
670 "PCM_BT_DI",
671 "PCM_BT_DO",
672 "JTAG_TMS_TP",
673 "JTAG_TCK_TP",
674 "JTAG_TDI_TP",
675 "JTAG_TDO_TP",
676 "JTAG_TRSTN_TP",
677 "CLK_24M_WCAM",
678 "CLK_24M_UCAM",
679 "UCAM_DET_ODL",
680 "AP_I2C_EDPBRDG_SCL_1V8",
681 "AP_I2C_EDPBRDG_SDA_1V8",
682 "AP_I2C_TCHSCR_SCL_1V8",
683 "AP_I2C_TCHSCR_SDA_1V8",
684 "AP_I2C_TCHPAD_SCL_1V8",
685 "AP_I2C_TCHPAD_SDA_1V8",
686 "AP_I2C_DPBRDG_SCL_1V8",
687 "AP_I2C_DPBRDG_SDA_1V8",
688 "AP_I2C_WLAN_SCL_1V8",
689 "AP_I2C_WLAN_SDA_1V8",
690 "AP_I2C_AUD_SCL_1V8",
691 "AP_I2C_AUD_SDA_1V8",
692 "AP_I2C_TPM_SCL_1V8",
693 "AP_I2C_UCAM_SDA_1V8",
694 "AP_I2C_UCAM_SCL_1V8",
695 "AP_I2C_UCAM_SDA_1V8",
696 "AP_I2C_WCAM_SCL_1V8",
697 "AP_I2C_WCAM_SDA_1V8",
698 "SCP_I2C_SENSOR_SCL_1V8",
699 "SCP_I2C_SENSOR_SDA_1V8",
700 "AP_EC_WARM_RST_REQ",
701 "AP_XHCI_INIT_DONE",
702 "USB3_HUB_RST_L",
703 "EN_SPKR",
704 "BEEP_ON",
705 "AP_EDP_BKLTEN",
706 "EN_PP3300_DISP_X",
707 "EN_PP3300_SDBRDG_X",
708 "BT_KILL_1V8_L",
709 "WIFI_KILL_1V8_L",
710 "PWRAP_SPI0_CSN",
711 "PWRAP_SPI0_CK",
712 "PWRAP_SPI0_MO",
713 "PWRAP_SPI0_MI",
714 "SRCLKENA0",
715 "SRCLKENA1",
716 "SCP_VREQ_VAO",
717 "AP_RTC_CLK32K",
718 "AP_PMIC_WDTRST_L",
719 "AUD_CLK_MOSI",
720 "AUD_SYNC_MOSI",
721 "AUD_DAT_MOSI0",
722 "AUD_DAT_MOSI1",
723 "AUD_CLK_MISO",
724 "AUD_SYNC_MISO",
725 "AUD_DAT_MISO0",
726 "AUD_DAT_MISO1",
727 "NC",
728 "NC",
729 "DPBRDG_PWREN",
730 "DPBRDG_RST_L",
731 "LTE_W_DISABLE_L",
732 "LTE_SAR_DETECT_L",
733 "EN_PP3300_LTE_X",
734 "LTE_PWR_OFF_L",
735 "LTE_RESET_L",
736 "TP",
737 "TP";
738
739 aud_clk_mosi_off: aud-clk-mosi-off-pins {
740 pins-clk-sync {
741 pinmux = <PINMUX_GPIO166__FUNC_GPIO166>,
742 <PINMUX_GPIO167__FUNC_GPIO167>;
743 input-enable;
744 bias-pull-down;
745 };
746 };
747
748 aud_clk_mosi_on: aud-clk-mosi-on-pins {
749 pins-clk-sync {
750 pinmux = <PINMUX_GPIO166__FUNC_AUD_CLK_MOSI>,
751 <PINMUX_GPIO167__FUNC_AUD_SYNC_MOSI>;
752 };
753 };
754
755 aud_clk_miso_off: aud-clk-miso-off-pins {
756 pins-clk-sync {
757 pinmux = <PINMUX_GPIO170__FUNC_GPIO170>,
758 <PINMUX_GPIO171__FUNC_GPIO171>;
759 input-enable;
760 bias-pull-down;
761 };
762 };
763
764 aud_clk_miso_on: aud-clk-miso-on-pins {
765 pins-clk-sync {
766 pinmux = <PINMUX_GPIO170__FUNC_AUD_CLK_MISO>,
767 <PINMUX_GPIO171__FUNC_AUD_SYNC_MISO>;
768 };
769 };
770
771 aud_dat_mosi_off: aud-dat-mosi-off-pins {
772 pins-dat {
773 pinmux = <PINMUX_GPIO168__FUNC_GPIO168>,
774 <PINMUX_GPIO169__FUNC_GPIO169>;
775 input-enable;
776 bias-pull-down;
777 };
778 };
779
780 aud_dat_mosi_on: aud-dat-mosi-on-pins {
781 pins-dat {
782 pinmux = <PINMUX_GPIO168__FUNC_AUD_DAT_MOSI0>,
783 <PINMUX_GPIO169__FUNC_AUD_DAT_MOSI1>;
784 };
785 };
786
787 aud_dat_miso_off: aud-dat-miso-off-pins {
788 pins-dat {
789 pinmux = <PINMUX_GPIO172__FUNC_GPIO172>,
790 <PINMUX_GPIO173__FUNC_GPIO173>;
791 input-enable;
792 bias-pull-down;
793 };
794 };
795
796 aud_dat_miso_on: aud-dat-miso-on-pins {
797 pins-dat {
798 pinmux = <PINMUX_GPIO172__FUNC_AUD_DAT_MISO0>,
799 <PINMUX_GPIO173__FUNC_AUD_DAT_MISO1>;
800 input-schmitt-enable;
801 bias-disable;
802 };
803 };
804
805 aud_gpio_i2s0_off: aud-gpio-i2s0-off-pins {
806 pins-sdata {
807 pinmux = <PINMUX_GPIO3__FUNC_GPIO3>;
808 };
809 };
810
811 aud_gpio_i2s0_on: aud-gpio-i2s0-on-pins {
812 pins-sdata {
813 pinmux = <PINMUX_GPIO3__FUNC_I2S0_DI>;
814 };
815 };
816
817 aud_gpio_i2s1_off: aud-gpio-i2s-off-pins {
818 pins-clk-sdata {
819 pinmux = <PINMUX_GPIO56__FUNC_GPIO56>,
820 <PINMUX_GPIO57__FUNC_GPIO57>,
821 <PINMUX_GPIO58__FUNC_GPIO58>,
822 <PINMUX_GPIO59__FUNC_GPIO59>;
823 output-low;
824 };
825 };
826
827 aud_gpio_i2s1_on: aud-gpio-i2s1-on-pins {
828 pins-clk-sdata {
829 pinmux = <PINMUX_GPIO56__FUNC_I2S1_DO>,
830 <PINMUX_GPIO57__FUNC_I2S1_BCK>,
831 <PINMUX_GPIO58__FUNC_I2S1_LRCK>,
832 <PINMUX_GPIO59__FUNC_I2S1_MCK>;
833 };
834 };
835
836 aud_gpio_i2s2_off: aud-gpio-i2s2-off-pins {
837 pins-cmd-dat {
838 pinmux = <PINMUX_GPIO26__FUNC_GPIO26>,
839 <PINMUX_GPIO27__FUNC_GPIO27>;
840 output-low;
841 };
842 };
843
844 aud_gpio_i2s2_on: aud-gpio-i2s2-on-pins {
845 pins-clk {
846 pinmux = <PINMUX_GPIO26__FUNC_I2S2_BCK>,
847 <PINMUX_GPIO27__FUNC_I2S2_LRCK>;
848 drive-strength = <4>;
849 };
850 };
851
852 aud_gpio_i2s3_off: aud-gpio-i2s3-off-pins {
853 pins-sdata {
854 pinmux = <PINMUX_GPIO4__FUNC_GPIO4>;
855 output-low;
856 };
857 };
858
859 aud_gpio_i2s3_on: aud-gpio-i2s3-on-pins {
860 pins-sdata {
861 pinmux = <PINMUX_GPIO4__FUNC_I2S3_DO>;
862 drive-strength = <4>;
863 };
864 };
865
866 aud_gpio_pcm_off: aud-gpio-pcm-off-pins {
867 pins-clk-sdata {
868 pinmux = <PINMUX_GPIO115__FUNC_GPIO115>,
869 <PINMUX_GPIO116__FUNC_GPIO116>,
870 <PINMUX_GPIO117__FUNC_GPIO117>,
871 <PINMUX_GPIO118__FUNC_GPIO118>;
872 output-low;
873 };
874 };
875
876 aud_gpio_pcm_on: aud-gpio-pcm-on-pins {
877 pins-clk-sdata {
878 pinmux = <PINMUX_GPIO115__FUNC_PCM_CLK>,
879 <PINMUX_GPIO116__FUNC_PCM_SYNC>,
880 <PINMUX_GPIO117__FUNC_PCM_DI>,
881 <PINMUX_GPIO118__FUNC_PCM_DO>;
882 };
883 };
884
885 aud_gpio_dmic_sec: aud-gpio-dmic-sec-pins {
886 pins {
887 pinmux = <PINMUX_GPIO23__FUNC_GPIO23>;
888 output-low;
889 };
890 };
891
892 bt_pins_reset: bt-reset-pins {
893 pins-bt-reset {
894 pinmux = <PINMUX_GPIO155__FUNC_GPIO155>;
895 output-high;
896 };
897 };
898
899 dpi_pins_sleep: dpi-sleep-pins {
900 pins-cmd-dat {
901 pinmux = <PINMUX_GPIO103__FUNC_GPIO103>,
902 <PINMUX_GPIO104__FUNC_GPIO104>,
903 <PINMUX_GPIO105__FUNC_GPIO105>,
904 <PINMUX_GPIO106__FUNC_GPIO106>,
905 <PINMUX_GPIO107__FUNC_GPIO107>,
906 <PINMUX_GPIO108__FUNC_GPIO108>,
907 <PINMUX_GPIO109__FUNC_GPIO109>,
908 <PINMUX_GPIO110__FUNC_GPIO110>,
909 <PINMUX_GPIO111__FUNC_GPIO111>,
910 <PINMUX_GPIO112__FUNC_GPIO112>,
911 <PINMUX_GPIO113__FUNC_GPIO113>,
912 <PINMUX_GPIO114__FUNC_GPIO114>,
913 <PINMUX_GPIO101__FUNC_GPIO101>,
914 <PINMUX_GPIO100__FUNC_GPIO100>,
915 <PINMUX_GPIO102__FUNC_GPIO102>,
916 <PINMUX_GPIO99__FUNC_GPIO99>;
917 drive-strength = <10>;
918 output-low;
919 };
920 };
921
922 dpi_pins_default: dpi-default-pins {
923 pins-cmd-dat {
924 pinmux = <PINMUX_GPIO103__FUNC_DPI_DATA0>,
925 <PINMUX_GPIO104__FUNC_DPI_DATA1>,
926 <PINMUX_GPIO105__FUNC_DPI_DATA2>,
927 <PINMUX_GPIO106__FUNC_DPI_DATA3>,
928 <PINMUX_GPIO107__FUNC_DPI_DATA4>,
929 <PINMUX_GPIO108__FUNC_DPI_DATA5>,
930 <PINMUX_GPIO109__FUNC_DPI_DATA6>,
931 <PINMUX_GPIO110__FUNC_DPI_DATA7>,
932 <PINMUX_GPIO111__FUNC_DPI_DATA8>,
933 <PINMUX_GPIO112__FUNC_DPI_DATA9>,
934 <PINMUX_GPIO113__FUNC_DPI_DATA10>,
935 <PINMUX_GPIO114__FUNC_DPI_DATA11>,
936 <PINMUX_GPIO101__FUNC_DPI_HSYNC>,
937 <PINMUX_GPIO100__FUNC_DPI_VSYNC>,
938 <PINMUX_GPIO102__FUNC_DPI_DE>,
939 <PINMUX_GPIO99__FUNC_DPI_PCLK>;
940 drive-strength = <10>;
941 };
942 };
943
944 ec_ap_int: cros-ec-int-pins {
945 pins-ec-ap-int-odl {
946 pinmux = <PINMUX_GPIO13__FUNC_GPIO13>;
947 input-enable;
948 };
949 };
950
951 edp_panel_fixed_pins: edp-panel-fixed-pins {
952 pins-vreg-en {
953 pinmux = <PINMUX_GPIO153__FUNC_GPIO153>;
954 output-high;
955 };
956 };
957
958 en_pp1800_dpbrdg: en-pp1800-dpbrdg-pins {
959 pins-vreg-en {
960 pinmux = <PINMUX_GPIO39__FUNC_GPIO39>;
961 output-low;
962 };
963 };
964
965 gsc_int: gsc-int-pins {
966 pins-gsc-ap-int-odl {
967 pinmux = <PINMUX_GPIO15__FUNC_GPIO15>;
968 input-enable;
969 };
970 };
971
972 i2c0_pins: i2c0-pins {
973 pins-bus {
974 pinmux = <PINMUX_GPIO128__FUNC_SDA0>,
975 <PINMUX_GPIO127__FUNC_SCL0>;
976 bias-disable;
977 drive-strength = <4>;
978 input-enable;
979 };
980 };
981
982 i2c1_pins: i2c1-pins {
983 pins-bus {
984 pinmux = <PINMUX_GPIO130__FUNC_SDA1>,
985 <PINMUX_GPIO129__FUNC_SCL1>;
986 bias-disable;
987 drive-strength = <4>;
988 input-enable;
989 };
990 };
991
992 i2c2_pins: i2c2-pins {
993 pins-bus {
994 pinmux = <PINMUX_GPIO132__FUNC_SDA2>,
995 <PINMUX_GPIO131__FUNC_SCL2>;
996 bias-disable;
997 drive-strength = <4>;
998 input-enable;
999 };
1000 };
1001
1002 i2c3_pins: i2c3-pins {
1003 pins-bus {
1004 pinmux = <PINMUX_GPIO134__FUNC_SDA3>,
1005 <PINMUX_GPIO133__FUNC_SCL3>;
1006 bias-disable;
1007 drive-strength = <4>;
1008 input-enable;
1009 };
1010 };
1011
1012 i2c5_pins: i2c5-pins {
1013 pins-bus {
1014 pinmux = <PINMUX_GPIO138__FUNC_SDA5>,
1015 <PINMUX_GPIO137__FUNC_SCL5>;
1016 bias-disable;
1017 drive-strength = <4>;
1018 input-enable;
1019 };
1020 };
1021
1022 it6505_pins: it6505-pins {
1023 pins-hpd {
1024 pinmux = <PINMUX_GPIO10__FUNC_GPIO10>;
1025 input-enable;
1026 bias-pull-up;
1027 };
1028
1029 pins-int {
1030 pinmux = <PINMUX_GPIO8__FUNC_GPIO8>;
1031 input-enable;
1032 bias-pull-up;
1033 };
1034
1035 pins-reset {
1036 pinmux = <PINMUX_GPIO177__FUNC_GPIO177>;
1037 output-low;
1038 bias-pull-up;
1039 };
1040 };
1041
1042 mmc0_pins_default: mmc0-default-pins {
1043 pins-clk {
1044 pinmux = <PINMUX_GPIO68__FUNC_MSDC0_CLK>;
1045 bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
1046 };
1047
1048 pins-cmd-dat {
1049 pinmux = <PINMUX_GPIO71__FUNC_MSDC0_DAT0>,
1050 <PINMUX_GPIO72__FUNC_MSDC0_DAT1>,
1051 <PINMUX_GPIO73__FUNC_MSDC0_DAT2>,
1052 <PINMUX_GPIO74__FUNC_MSDC0_DAT3>,
1053 <PINMUX_GPIO75__FUNC_MSDC0_DAT4>,
1054 <PINMUX_GPIO76__FUNC_MSDC0_DAT5>,
1055 <PINMUX_GPIO77__FUNC_MSDC0_DAT6>,
1056 <PINMUX_GPIO78__FUNC_MSDC0_DAT7>,
1057 <PINMUX_GPIO69__FUNC_MSDC0_CMD>;
1058 input-enable;
1059 bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
1060 };
1061
1062 pins-rst {
1063 pinmux = <PINMUX_GPIO70__FUNC_MSDC0_RSTB>;
1064 bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
1065 };
1066 };
1067
1068 mmc0_pins_uhs: mmc0-uhs-pins {
1069 pins-clk {
1070 pinmux = <PINMUX_GPIO68__FUNC_MSDC0_CLK>;
1071 drive-strength = <6>;
1072 bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
1073 };
1074
1075 pins-cmd-dat {
1076 pinmux = <PINMUX_GPIO71__FUNC_MSDC0_DAT0>,
1077 <PINMUX_GPIO72__FUNC_MSDC0_DAT1>,
1078 <PINMUX_GPIO73__FUNC_MSDC0_DAT2>,
1079 <PINMUX_GPIO74__FUNC_MSDC0_DAT3>,
1080 <PINMUX_GPIO75__FUNC_MSDC0_DAT4>,
1081 <PINMUX_GPIO76__FUNC_MSDC0_DAT5>,
1082 <PINMUX_GPIO77__FUNC_MSDC0_DAT6>,
1083 <PINMUX_GPIO78__FUNC_MSDC0_DAT7>,
1084 <PINMUX_GPIO69__FUNC_MSDC0_CMD>;
1085 input-enable;
1086 drive-strength = <6>;
1087 bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
1088 };
1089
1090 pins-ds {
1091 pinmux = <PINMUX_GPIO67__FUNC_MSDC0_DSL>;
1092 drive-strength = <6>;
1093 bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
1094 };
1095
1096 pins-rst {
1097 pinmux = <PINMUX_GPIO70__FUNC_MSDC0_RSTB>;
1098 bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
1099 };
1100 };
1101
1102 mmc1_pins_default: mmc1-default-pins {
1103 pins-clk {
1104 pinmux = <PINMUX_GPIO84__FUNC_MSDC1_CLK>;
1105 drive-strength = <6>;
1106 bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
1107 };
1108
1109 pins-cmd-dat {
1110 pinmux = <PINMUX_GPIO86__FUNC_MSDC1_DAT0>,
1111 <PINMUX_GPIO87__FUNC_MSDC1_DAT1>,
1112 <PINMUX_GPIO88__FUNC_MSDC1_DAT2>,
1113 <PINMUX_GPIO89__FUNC_MSDC1_DAT3>,
1114 <PINMUX_GPIO85__FUNC_MSDC1_CMD>;
1115 input-enable;
1116 drive-strength = <6>;
1117 bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
1118 };
1119 };
1120
1121 mmc1_pins_uhs: mmc1-uhs-pins {
1122 pins-clk {
1123 pinmux = <PINMUX_GPIO84__FUNC_MSDC1_CLK>;
1124 drive-strength = <6>;
1125 bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
1126 };
1127
1128 pins-cmd-dat {
1129 pinmux = <PINMUX_GPIO86__FUNC_MSDC1_DAT0>,
1130 <PINMUX_GPIO87__FUNC_MSDC1_DAT1>,
1131 <PINMUX_GPIO88__FUNC_MSDC1_DAT2>,
1132 <PINMUX_GPIO89__FUNC_MSDC1_DAT3>,
1133 <PINMUX_GPIO85__FUNC_MSDC1_CMD>;
1134 input-enable;
1135 drive-strength = <8>;
1136 bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
1137 };
1138 };
1139
1140 mmc1_pins_eint: mmc1-eint-pins {
1141 pins-dat1 {
1142 pinmux = <PINMUX_GPIO87__FUNC_GPIO87>;
1143 input-enable;
1144 bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
1145 };
1146 };
1147
1148 nor_pins_default: nor-default-pins {
1149 pins-clk-dat {
1150 pinmux = <PINMUX_GPIO63__FUNC_SPINOR_IO0>,
1151 <PINMUX_GPIO61__FUNC_SPINOR_CK>,
1152 <PINMUX_GPIO64__FUNC_SPINOR_IO1>;
1153 drive-strength = <6>;
1154 bias-pull-down;
1155 };
1156
1157 pins-cs-dat {
1158 pinmux = <PINMUX_GPIO62__FUNC_SPINOR_CS>,
1159 <PINMUX_GPIO65__FUNC_SPINOR_IO2>,
1160 <PINMUX_GPIO66__FUNC_SPINOR_IO3>;
1161 drive-strength = <6>;
1162 bias-pull-up;
1163 };
1164 };
1165
1166 pen_eject: pen-eject-pins {
1167 pins {
1168 pinmux = <PINMUX_GPIO18__FUNC_GPIO18>;
1169 input-enable;
1170 /* External pull-up. */
1171 bias-disable;
1172 };
1173 };
1174
1175 pwm0_pin: disp-pwm-pins {
1176 pins {
1177 pinmux = <PINMUX_GPIO97__FUNC_DISP_PWM>;
1178 output-high;
1179 };
1180 };
1181
1182 speaker_codec_pins_default: speaker-codec-default-pins {
1183 pins-sdb {
1184 pinmux = <PINMUX_GPIO150__FUNC_GPIO150>;
1185 output-low;
1186 };
1187 };
1188
1189 scp_pins: scp-default-pins {
1190 pins-scp-uart {
1191 pinmux = <PINMUX_GPIO48__FUNC_TP_URXD2_AO>,
1192 <PINMUX_GPIO49__FUNC_TP_UTXD2_AO>;
1193 };
1194 };
1195
1196 spi1_pins: spi1-pins {
1197 pins-bus {
1198 pinmux = <PINMUX_GPIO40__FUNC_SPI1_CLK_A>,
1199 <PINMUX_GPIO41__FUNC_SPI1_CSB_A>,
1200 <PINMUX_GPIO42__FUNC_SPI1_MO_A>,
1201 <PINMUX_GPIO43__FUNC_SPI1_MI_A>;
1202 bias-disable;
1203 input-enable;
1204 };
1205 };
1206
1207 spi2_pins: spi2-pins {
1208 pins-bus {
1209 pinmux = <PINMUX_GPIO44__FUNC_SPI2_CLK_A>,
1210 <PINMUX_GPIO45__FUNC_GPIO45>,
1211 <PINMUX_GPIO46__FUNC_SPI2_MO_A>,
1212 <PINMUX_GPIO47__FUNC_SPI2_MI_A>;
1213 bias-disable;
1214 input-enable;
1215 };
1216 };
1217
1218 spmi_pins: spmi-pins {
1219 pins-bus {
1220 pinmux = <PINMUX_GPIO183__FUNC_SPMI_SCL>,
1221 <PINMUX_GPIO184__FUNC_SPMI_SDA>;
1222 };
1223 };
1224
1225 touchscreen_pins: touchscreen-pins {
1226 pins-irq {
1227 pinmux = <PINMUX_GPIO12__FUNC_GPIO12>;
1228 input-enable;
1229 bias-pull-up;
1230 };
1231
1232 pins-reset {
1233 pinmux = <PINMUX_GPIO60__FUNC_GPIO60>;
1234 output-high;
1235 };
1236
1237 pins-report-sw {
1238 pinmux = <PINMUX_GPIO37__FUNC_GPIO37>;
1239 output-low;
1240 };
1241 };
1242
1243 trackpad_pin: trackpad-default-pins {
1244 pins-int-n {
1245 pinmux = <PINMUX_GPIO11__FUNC_GPIO11>;
1246 input-enable;
1247 bias-disable; /* pulled externally */
1248 };
1249 };
1250
1251 wifi_enable_pin: wifi-enable-pins {
1252 pins-wifi-enable {
1253 pinmux = <PINMUX_GPIO54__FUNC_GPIO54>;
1254 };
1255 };
1256
1257 wifi_wakeup_pin: wifi-wakeup-pins {
1258 pins-wifi-wakeup {
1259 pinmux = <PINMUX_GPIO7__FUNC_GPIO7>;
1260 input-enable;
1261 };
1262 };
1263};
1264
1265&pwm0 {
1266 pinctrl-names = "default";
1267 pinctrl-0 = <&pwm0_pin>;
1268 status = "okay";
1269};
1270
1271&pwrap {
1272 pmic {
1273 compatible = "mediatek,mt6366", "mediatek,mt6358";
1274 interrupt-controller;
1275 interrupts-extended = <&pio 201 IRQ_TYPE_LEVEL_HIGH>;
1276 #interrupt-cells = <2>;
1277
1278 mt6366codec: codec {
1279 compatible = "mediatek,mt6366-sound", "mediatek,mt6358-sound";
1280 Avdd-supply = <&mt6366_vaud28_reg>;
1281 mediatek,dmic-mode = <1>; /* one-wire */
1282 };
1283
1284 mt6366_regulators: regulators {
1285 compatible = "mediatek,mt6366-regulator", "mediatek,mt6358-regulator";
1286 vsys-ldo1-supply = <&pp4200_z2>;
1287 vsys-ldo2-supply = <&pp4200_z2>;
1288 vsys-ldo3-supply = <&pp4200_z2>;
1289 vsys-vcore-supply = <&pp4200_z2>;
1290 vsys-vdram1-supply = <&pp4200_z2>;
1291 vsys-vgpu-supply = <&pp4200_z2>;
1292 vsys-vmodem-supply = <&pp4200_z2>;
1293 vsys-vpa-supply = <&pp4200_z2>;
1294 vsys-vproc11-supply = <&pp4200_z2>;
1295 vsys-vproc12-supply = <&pp4200_z2>;
1296 vsys-vs1-supply = <&pp4200_z2>;
1297 vsys-vs2-supply = <&pp4200_z2>;
1298 vs1-ldo1-supply = <&mt6366_vs1_reg>;
1299 vs2-ldo1-supply = <&mt6366_vdram1_reg>;
1300 vs2-ldo2-supply = <&mt6366_vs2_reg>;
1301 vs2-ldo3-supply = <&mt6366_vs2_reg>;
1302
1303 vcore {
1304 regulator-name = "pp0750_dvdd_core";
1305 regulator-min-microvolt = <550000>;
1306 regulator-max-microvolt = <800000>;
1307 regulator-ramp-delay = <6250>;
1308 regulator-enable-ramp-delay = <200>;
1309 regulator-allowed-modes = <MT6397_BUCK_MODE_AUTO
1310 MT6397_BUCK_MODE_FORCE_PWM>;
1311 regulator-always-on;
1312 };
1313
1314 mt6366_vdram1_reg: vdram1 {
1315 regulator-name = "pp1125_emi_vdd2";
1316 regulator-min-microvolt = <1125000>;
1317 regulator-max-microvolt = <1125000>;
1318 regulator-ramp-delay = <12500>;
1319 regulator-enable-ramp-delay = <0>;
1320 regulator-allowed-modes = <MT6397_BUCK_MODE_AUTO
1321 MT6397_BUCK_MODE_FORCE_PWM>;
1322 regulator-always-on;
1323 };
1324
1325 mt6366_vgpu_reg: vgpu {
1326 /*
1327 * Called "ppvar_dvdd_gpu" in the schematic.
1328 * Called "ppvar_dvdd_vgpu" here to match
1329 * regulator coupling requirements.
1330 */
1331 regulator-name = "ppvar_dvdd_vgpu";
1332 regulator-min-microvolt = <500000>;
1333 regulator-max-microvolt = <950000>;
1334 regulator-ramp-delay = <6250>;
1335 regulator-enable-ramp-delay = <200>;
1336 regulator-allowed-modes = <MT6397_BUCK_MODE_AUTO
1337 MT6397_BUCK_MODE_FORCE_PWM>;
1338 regulator-coupled-with = <&mt6366_vsram_gpu_reg>;
1339 regulator-coupled-max-spread = <100000>;
1340 };
1341
1342 mt6366_vproc11_reg: vproc11 {
1343 regulator-name = "ppvar_dvdd_proc_bc_mt6366";
1344 regulator-min-microvolt = <600000>;
1345 regulator-max-microvolt = <1200000>;
1346 regulator-ramp-delay = <6250>;
1347 regulator-enable-ramp-delay = <200>;
1348 regulator-allowed-modes = <MT6397_BUCK_MODE_AUTO
1349 MT6397_BUCK_MODE_FORCE_PWM>;
1350 regulator-always-on;
1351 };
1352
1353 mt6366_vproc12_reg: vproc12 {
1354 regulator-name = "ppvar_dvdd_proc_lc";
1355 regulator-min-microvolt = <600000>;
1356 regulator-max-microvolt = <1200000>;
1357 regulator-ramp-delay = <6250>;
1358 regulator-enable-ramp-delay = <200>;
1359 regulator-allowed-modes = <MT6397_BUCK_MODE_AUTO
1360 MT6397_BUCK_MODE_FORCE_PWM>;
1361 regulator-always-on;
1362 };
1363
1364 mt6366_vs1_reg: vs1 {
1365 regulator-name = "pp2000_vs1";
1366 regulator-min-microvolt = <2000000>;
1367 regulator-max-microvolt = <2000000>;
1368 regulator-ramp-delay = <12500>;
1369 regulator-enable-ramp-delay = <0>;
1370 regulator-always-on;
1371 };
1372
1373 mt6366_vs2_reg: vs2 {
1374 regulator-name = "pp1350_vs2";
1375 regulator-min-microvolt = <1350000>;
1376 regulator-max-microvolt = <1350000>;
1377 regulator-ramp-delay = <12500>;
1378 regulator-enable-ramp-delay = <0>;
1379 regulator-always-on;
1380 };
1381
1382 va12 {
1383 regulator-name = "pp1200_va12";
1384 regulator-min-microvolt = <1200000>;
1385 regulator-max-microvolt = <1200000>;
1386 regulator-enable-ramp-delay = <270>;
1387 regulator-always-on;
1388 };
1389
1390 mt6366_vaud28_reg: vaud28 {
1391 regulator-name = "pp2800_vaud28";
1392 regulator-min-microvolt = <2800000>;
1393 regulator-max-microvolt = <2800000>;
1394 regulator-enable-ramp-delay = <270>;
1395 };
1396
1397 mt6366_vaux18_reg: vaux18 {
1398 regulator-name = "pp1840_vaux18";
1399 regulator-min-microvolt = <1800000>;
1400 regulator-max-microvolt = <1840000>;
1401 regulator-enable-ramp-delay = <270>;
1402 };
1403
1404 mt6366_vbif28_reg: vbif28 {
1405 regulator-name = "pp2800_vbif28";
1406 regulator-min-microvolt = <2800000>;
1407 regulator-max-microvolt = <2800000>;
1408 regulator-enable-ramp-delay = <270>;
1409 };
1410
1411 mt6366_vcn18_reg: vcn18 {
1412 regulator-name = "pp1800_vcn18_x";
1413 regulator-min-microvolt = <1800000>;
1414 regulator-max-microvolt = <1800000>;
1415 regulator-enable-ramp-delay = <270>;
1416 };
1417
1418 mt6366_vcn28_reg: vcn28 {
1419 regulator-name = "pp2800_vcn28_x";
1420 regulator-min-microvolt = <2800000>;
1421 regulator-max-microvolt = <2800000>;
1422 regulator-enable-ramp-delay = <270>;
1423 };
1424
1425 mt6366_vefuse_reg: vefuse {
1426 regulator-name = "pp1800_vefuse";
1427 regulator-min-microvolt = <1800000>;
1428 regulator-max-microvolt = <1800000>;
1429 regulator-enable-ramp-delay = <270>;
1430 };
1431
1432 mt6366_vfe28_reg: vfe28 {
1433 regulator-name = "pp2800_vfe28_x";
1434 regulator-min-microvolt = <2800000>;
1435 regulator-max-microvolt = <2800000>;
1436 regulator-enable-ramp-delay = <270>;
1437 };
1438
1439 mt6366_vemc_reg: vemc {
1440 regulator-name = "pp3000_vemc";
1441 regulator-min-microvolt = <3000000>;
1442 regulator-max-microvolt = <3000000>;
1443 regulator-enable-ramp-delay = <60>;
1444 };
1445
1446 mt6366_vibr_reg: vibr {
1447 regulator-name = "pp2800_vibr_x";
1448 regulator-min-microvolt = <2800000>;
1449 regulator-max-microvolt = <2800000>;
1450 regulator-enable-ramp-delay = <60>;
1451 };
1452
1453 mt6366_vio18_reg: vio18 {
1454 regulator-name = "pp1800_vio18_s3";
1455 regulator-min-microvolt = <1800000>;
1456 regulator-max-microvolt = <1800000>;
1457 regulator-enable-ramp-delay = <2700>;
1458 regulator-always-on;
1459 };
1460
1461 mt6366_vio28_reg: vio28 {
1462 regulator-name = "pp2800_vio28_x";
1463 regulator-min-microvolt = <2800000>;
1464 regulator-max-microvolt = <2800000>;
1465 regulator-enable-ramp-delay = <270>;
1466 };
1467
1468 mt6366_vm18_reg: vm18 {
1469 regulator-name = "pp1800_emi_vdd1";
1470 regulator-min-microvolt = <1800000>;
1471 regulator-max-microvolt = <1840000>;
1472 regulator-enable-ramp-delay = <325>;
1473 regulator-always-on;
1474 };
1475
1476 mt6366_vmc_reg: vmc {
1477 regulator-name = "pp3000_vmc";
1478 regulator-min-microvolt = <3000000>;
1479 regulator-max-microvolt = <3000000>;
1480 regulator-enable-ramp-delay = <60>;
1481 };
1482
1483 mt6366_vmddr_reg: vmddr {
1484 regulator-name = "pm0750_emi_vmddr";
1485 regulator-min-microvolt = <700000>;
1486 regulator-max-microvolt = <750000>;
1487 regulator-enable-ramp-delay = <325>;
1488 regulator-always-on;
1489 };
1490
1491 mt6366_vmch_reg: vmch {
1492 regulator-name = "pp3000_vmch";
1493 regulator-min-microvolt = <3000000>;
1494 regulator-max-microvolt = <3000000>;
1495 regulator-enable-ramp-delay = <60>;
1496 };
1497
1498 mt6366_vcn33_reg: vcn33 {
1499 regulator-name = "pp3300_vcn33_x";
1500 regulator-min-microvolt = <3300000>;
1501 regulator-max-microvolt = <3300000>;
1502 regulator-enable-ramp-delay = <270>;
1503 };
1504
1505 vdram2 {
1506 regulator-name = "pp0600_emi_vddq";
1507 regulator-min-microvolt = <600000>;
1508 regulator-max-microvolt = <600000>;
1509 regulator-enable-ramp-delay = <3300>;
1510 regulator-always-on;
1511 };
1512
1513 mt6366_vrf12_reg: vrf12 {
1514 regulator-name = "pp1200_vrf12_x";
1515 regulator-min-microvolt = <1200000>;
1516 regulator-max-microvolt = <1200000>;
1517 regulator-enable-ramp-delay = <120>;
1518 };
1519
1520 mt6366_vrf18_reg: vrf18 {
1521 regulator-name = "pp1800_vrf18_x";
1522 regulator-min-microvolt = <1800000>;
1523 regulator-max-microvolt = <1800000>;
1524 regulator-enable-ramp-delay = <120>;
1525 };
1526
1527 vsim1 {
1528 regulator-name = "pp1860_vsim1_x";
1529 regulator-min-microvolt = <1800000>;
1530 regulator-max-microvolt = <1860000>;
1531 regulator-enable-ramp-delay = <540>;
1532 };
1533
1534 mt6366_vsim2_reg: vsim2 {
1535 regulator-name = "pp2760_vsim2_x";
1536 regulator-min-microvolt = <2700000>;
1537 regulator-max-microvolt = <2760000>;
1538 regulator-enable-ramp-delay = <540>;
1539 };
1540
1541 mt6366_vsram_gpu_reg: vsram-gpu {
1542 regulator-name = "pp0900_dvdd_sram_gpu";
1543 regulator-min-microvolt = <850000>;
1544 regulator-max-microvolt = <1050000>;
1545 regulator-ramp-delay = <6250>;
1546 regulator-enable-ramp-delay = <240>;
1547 regulator-coupled-with = <&mt6366_vgpu_reg>;
1548 regulator-coupled-max-spread = <100000>;
1549 };
1550
1551 mt6366_vsram_others_reg: vsram-others {
1552 regulator-name = "pp0900_dvdd_sram_core";
1553 regulator-min-microvolt = <900000>;
1554 regulator-max-microvolt = <900000>;
1555 regulator-ramp-delay = <6250>;
1556 regulator-enable-ramp-delay = <240>;
1557 regulator-always-on;
1558 };
1559
1560 mt6366_vsram_proc11_reg: vsram-proc11 {
1561 regulator-name = "pp0900_dvdd_sram_bc";
1562 regulator-min-microvolt = <850000>;
1563 regulator-max-microvolt = <1120000>;
1564 regulator-ramp-delay = <6250>;
1565 regulator-enable-ramp-delay = <240>;
1566 regulator-always-on;
1567 };
1568
1569 mt6366_vsram_proc12_reg: vsram-proc12 {
1570 regulator-name = "pp0900_dvdd_sram_lc";
1571 regulator-min-microvolt = <850000>;
1572 regulator-max-microvolt = <1120000>;
1573 regulator-ramp-delay = <6250>;
1574 regulator-enable-ramp-delay = <240>;
1575 regulator-always-on;
1576 };
1577
1578 vusb {
1579 regulator-name = "pp3070_vusb";
1580 regulator-min-microvolt = <3000000>;
1581 regulator-max-microvolt = <3070000>;
1582 regulator-enable-ramp-delay = <270>;
1583 regulator-always-on;
1584 };
1585
1586 vxo22 {
1587 regulator-name = "pp2240_vxo22";
1588 regulator-min-microvolt = <2200000>;
1589 regulator-max-microvolt = <2240000>;
1590 regulator-enable-ramp-delay = <120>;
1591 /* Feeds DCXO internally */
1592 regulator-always-on;
1593 };
1594 };
1595
1596 rtc {
1597 compatible = "mediatek,mt6366-rtc", "mediatek,mt6358-rtc";
1598 };
1599 };
1600};
1601
1602&scp {
1603 pinctrl-names = "default";
1604 pinctrl-0 = <&scp_pins>;
1605 firmware-name = "mediatek/mt8186/scp.img";
1606 memory-region = <&scp_mem>;
1607 status = "okay";
1608
1609 cros-ec-rpmsg {
1610 compatible = "google,cros-ec-rpmsg";
1611 mediatek,rpmsg-name = "cros-ec-rpmsg";
1612 };
1613};
1614
1615&spi1 {
1616 pinctrl-names = "default";
1617 pinctrl-0 = <&spi1_pins>;
1618 mediatek,pad-select = <0>;
1619 status = "okay";
1620
1621 cros_ec: ec@0 {
1622 compatible = "google,cros-ec-spi";
1623 reg = <0>;
1624 interrupts-extended = <&pio 13 IRQ_TYPE_LEVEL_LOW>;
1625 pinctrl-names = "default";
1626 pinctrl-0 = <&ec_ap_int>;
1627 spi-max-frequency = <1000000>;
1628
1629 i2c_tunnel: i2c-tunnel {
1630 compatible = "google,cros-ec-i2c-tunnel";
1631 google,remote-bus = <1>;
1632 #address-cells = <1>;
1633 #size-cells = <0>;
1634 };
1635
1636 typec {
1637 compatible = "google,cros-ec-typec";
1638 #address-cells = <1>;
1639 #size-cells = <0>;
1640
1641 usb_c0: connector@0 {
1642 compatible = "usb-c-connector";
1643 reg = <0>;
1644 label = "left";
1645 power-role = "dual";
1646 data-role = "host";
1647 try-power-role = "source";
1648 };
1649
1650 usb_c1: connector@1 {
1651 compatible = "usb-c-connector";
1652 reg = <1>;
1653 label = "right";
1654 power-role = "dual";
1655 data-role = "host";
1656 try-power-role = "source";
1657 };
1658 };
1659 };
1660};
1661
1662&spi2 {
1663 pinctrl-names = "default";
1664 pinctrl-0 = <&spi2_pins>;
1665 cs-gpios = <&pio 45 GPIO_ACTIVE_LOW>;
1666 mediatek,pad-select = <0>;
1667 status = "okay";
1668
1669 tpm@0 {
1670 compatible = "google,cr50";
1671 reg = <0>;
1672 interrupts-extended = <&pio 15 IRQ_TYPE_EDGE_RISING>;
1673 pinctrl-names = "default";
1674 pinctrl-0 = <&gsc_int>;
1675 spi-max-frequency = <1000000>;
1676 };
1677};
1678
1679&ssusb0 {
1680 status = "okay";
1681};
1682
1683&ssusb1 {
1684 status = "okay";
1685};
1686
1687&u3phy0 {
1688 status = "okay";
1689};
1690
1691&u3phy1 {
1692 status = "okay";
1693};
1694
1695&uart0 {
1696 status = "okay";
1697};
1698
1699&usb_host0 {
1700 vbus-supply = <&pp3300_s3>;
1701 status = "okay";
1702};
1703
1704&usb_host1 {
1705 vbus-supply = <&usb_p1_vbus>;
1706 status = "okay";
1707};
1708
1709&watchdog {
1710 mediatek,reset-by-toprgu;
1711};
1712
1713#include <arm/cros-ec-keyboard.dtsi>
1714#include <arm/cros-ec-sbs.dtsi>