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> 1715