Linux Audio

Check our new training course

Loading...
Note: File does not exist in v3.1.
   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>