[v4,2/2] arm64: dts: mediatek: add device-tree for Genio 700 EVK board

Message ID 20230915081212.13959-2-macpaul.lin@mediatek.com
State New
Headers
Series [v4,1/2] dt-bindings: arm64: mediatek: add mt8390-evk board |

Commit Message

Macpaul Lin Sept. 15, 2023, 8:12 a.m. UTC
  Add basic device-tree for the Genio 700 EVK board. The
Genio 700 EVK is based on MediaTek MT8390 SoC.
MT8390 hardware register maps are identical to MT8188.

The Genio 700 EVK has following features:

- MT8390 SoC
- MT6365 PMIC
- MT6319 Buck IC
- 12V DC Jack
- 2x4GB LPDDR4X
- 64GB eMMC 5.1
- 64Mb SPI NOR
- M.2 Key A-E slot with PCIe Gen2 and USB 2.0
- 2x DSI LCM ports
- 2x touch sensor ports
- 2x MIPI-CSI, as camera daughter board slots
- USB 2 micro USB connector
- USB 3 with 1 to 2 hub:
  - M.2 Key B slot
  - Type-C connector, with DisplayPort over Type-C
- HDMI 2.0 TX port with Type A HDMI connector
- eDP port
- Gigabit Ethernet with RJ45 connector
- SD card slot
- Earphone Jack
- Analog Microphone
- 2x Digital Microphone
- 3x UART with serial-to-usb converters and micro USB connectors

Signed-off-by: Chris-QJ Chen <chris-qj.chen@mediatek.com>
Signed-off-by: Pablo Sun <pablo.sun@mediatek.com>
Signed-off-by: Macpaul Lin <macpaul.lin@mediatek.com>
Reviewed-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
---
 arch/arm64/boot/dts/mediatek/Makefile         |   1 +
 .../dts/mediatek/mt8390-genio-700-evk.dts     | 880 ++++++++++++++++++
 2 files changed, 881 insertions(+)
 create mode 100644 arch/arm64/boot/dts/mediatek/mt8390-genio-700-evk.dts

dependencies for v1:
 - This patch should be applied after the following patch set
  - mt8365-gneio-350-evk's dts change (v4)
   - https://lore.kernel.org/linux-arm-kernel/20230912092444.31635-1-macpaul.lin@mediatek.com/T/
  - mt8395-genio-1200-evk's dts basic support (v6)
   - https://lore.kernel.org/lkml/20230911115717.26184-1-macpaul.lin@mediatek.com/T/
  - mt8188 platform's basic support
   - https://lore.kernel.org/lkml/a4e1a80ebd19896410f50b0297e05dce06fb47cc.camel@mediatek.com/T/

changes for v2:
 - Fix gpio defines '0' to 'GPIO_ACTIVE_HIGH'.
 - Drop duplicate name: 'default' for I2C4.
 - Update dependencies
  - mt8365-gneio-350-evk's dts change (v5)
   - https://lore.kernel.org/lkml/20230913032226.4092-1-macpaul.lin@mediatek.com/
  - mt8395-genio-1200-evk's dts basic support (v7)
   - https://lore.kernel.org/linux-arm-kernel/20230913032057.3197-1-macpaul.lin@mediatek.com/T/
  - mt8188 platform's basic support (v4)
   - https://lore.kernel.org/lkml/a4e1a80ebd19896410f50b0297e05dce06fb47cc.camel@mediatek.com/T/

changes for v3:
 - No change.
 - Update dependencies
  - mt8365-gneio-350-evk's dts change (v5)
   - https://lore.kernel.org/lkml/20230913032226.4092-1-macpaul.lin@mediatek.com/
  - mt8395-genio-1200-evk's dts basic support (v8)
   - https://lore.kernel.org/lkml/20230914055145.16801-1-macpaul.lin@mediatek.com/T/ 
  - mt8188 platform's basic support (v4)
   - https://lore.kernel.org/lkml/a4e1a80ebd19896410f50b0297e05dce06fb47cc.camel@mediatek.com/T/

changes for v4:
 - Fix 'interrupts' of touchscreen on i2c0 to 'interrupts-extended'.
 - Add 'Reviewed-by' tag, Thanks!
  

Comments

Chen-Yu Tsai Sept. 22, 2023, 6:50 a.m. UTC | #1
On Fri, Sep 15, 2023 at 4:13 PM Macpaul Lin <macpaul.lin@mediatek.com> wrote:
>
> Add basic device-tree for the Genio 700 EVK board. The
> Genio 700 EVK is based on MediaTek MT8390 SoC.
> MT8390 hardware register maps are identical to MT8188.
>
> The Genio 700 EVK has following features:
>
> - MT8390 SoC
> - MT6365 PMIC
> - MT6319 Buck IC
> - 12V DC Jack
> - 2x4GB LPDDR4X
> - 64GB eMMC 5.1
> - 64Mb SPI NOR
> - M.2 Key A-E slot with PCIe Gen2 and USB 2.0
> - 2x DSI LCM ports
> - 2x touch sensor ports
> - 2x MIPI-CSI, as camera daughter board slots
> - USB 2 micro USB connector
> - USB 3 with 1 to 2 hub:
>   - M.2 Key B slot
>   - Type-C connector, with DisplayPort over Type-C
> - HDMI 2.0 TX port with Type A HDMI connector
> - eDP port
> - Gigabit Ethernet with RJ45 connector
> - SD card slot
> - Earphone Jack
> - Analog Microphone
> - 2x Digital Microphone
> - 3x UART with serial-to-usb converters and micro USB connectors
>
> Signed-off-by: Chris-QJ Chen <chris-qj.chen@mediatek.com>
> Signed-off-by: Pablo Sun <pablo.sun@mediatek.com>
> Signed-off-by: Macpaul Lin <macpaul.lin@mediatek.com>
> Reviewed-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
> ---
>  arch/arm64/boot/dts/mediatek/Makefile         |   1 +
>  .../dts/mediatek/mt8390-genio-700-evk.dts     | 880 ++++++++++++++++++
>  2 files changed, 881 insertions(+)
>  create mode 100644 arch/arm64/boot/dts/mediatek/mt8390-genio-700-evk.dts
>
> dependencies for v1:
>  - This patch should be applied after the following patch set
>   - mt8365-gneio-350-evk's dts change (v4)
>    - https://lore.kernel.org/linux-arm-kernel/20230912092444.31635-1-macpaul.lin@mediatek.com/T/
>   - mt8395-genio-1200-evk's dts basic support (v6)
>    - https://lore.kernel.org/lkml/20230911115717.26184-1-macpaul.lin@mediatek.com/T/
>   - mt8188 platform's basic support
>    - https://lore.kernel.org/lkml/a4e1a80ebd19896410f50b0297e05dce06fb47cc.camel@mediatek.com/T/
>
> changes for v2:
>  - Fix gpio defines '0' to 'GPIO_ACTIVE_HIGH'.
>  - Drop duplicate name: 'default' for I2C4.
>  - Update dependencies
>   - mt8365-gneio-350-evk's dts change (v5)
>    - https://lore.kernel.org/lkml/20230913032226.4092-1-macpaul.lin@mediatek.com/
>   - mt8395-genio-1200-evk's dts basic support (v7)
>    - https://lore.kernel.org/linux-arm-kernel/20230913032057.3197-1-macpaul.lin@mediatek.com/T/
>   - mt8188 platform's basic support (v4)
>    - https://lore.kernel.org/lkml/a4e1a80ebd19896410f50b0297e05dce06fb47cc.camel@mediatek.com/T/
>
> changes for v3:
>  - No change.
>  - Update dependencies
>   - mt8365-gneio-350-evk's dts change (v5)
>    - https://lore.kernel.org/lkml/20230913032226.4092-1-macpaul.lin@mediatek.com/
>   - mt8395-genio-1200-evk's dts basic support (v8)
>    - https://lore.kernel.org/lkml/20230914055145.16801-1-macpaul.lin@mediatek.com/T/
>   - mt8188 platform's basic support (v4)
>    - https://lore.kernel.org/lkml/a4e1a80ebd19896410f50b0297e05dce06fb47cc.camel@mediatek.com/T/
>
> changes for v4:
>  - Fix 'interrupts' of touchscreen on i2c0 to 'interrupts-extended'.
>  - Add 'Reviewed-by' tag, Thanks!
>
> diff --git a/arch/arm64/boot/dts/mediatek/Makefile b/arch/arm64/boot/dts/mediatek/Makefile
> index 22f362bbbdac..3262849c0f6b 100644
> --- a/arch/arm64/boot/dts/mediatek/Makefile
> +++ b/arch/arm64/boot/dts/mediatek/Makefile
> @@ -54,5 +54,6 @@ dtb-$(CONFIG_ARCH_MEDIATEK) += mt8195-cherry-tomato-r3.dtb
>  dtb-$(CONFIG_ARCH_MEDIATEK) += mt8195-demo.dtb
>  dtb-$(CONFIG_ARCH_MEDIATEK) += mt8195-evb.dtb
>  dtb-$(CONFIG_ARCH_MEDIATEK) += mt8365-genio-350-evk.dtb
> +dtb-$(CONFIG_ARCH_MEDIATEK) += mt8390-genio-700-evk.dtb
>  dtb-$(CONFIG_ARCH_MEDIATEK) += mt8395-genio-1200-evk.dtb
>  dtb-$(CONFIG_ARCH_MEDIATEK) += mt8516-pumpkin.dtb
> diff --git a/arch/arm64/boot/dts/mediatek/mt8390-genio-700-evk.dts b/arch/arm64/boot/dts/mediatek/mt8390-genio-700-evk.dts
> new file mode 100644
> index 000000000000..6bb1d5d112ef
> --- /dev/null
> +++ b/arch/arm64/boot/dts/mediatek/mt8390-genio-700-evk.dts
> @@ -0,0 +1,880 @@
> +// SPDX-License-Identifier: (GPL-2.0 OR MIT)
> +/*
> + * Copyright (C) 2023 MediaTek Inc.
> + * Author: Chris Chen <chris-qj.chen@mediatek.com>
> + *        Pablo Sun <pablo.sun@mediatek.com>
> + *        Macpaul Lin <macpaul.lin@mediatek.com>
> + */
> +/dts-v1/;
> +
> +#include "mt8188.dtsi"
> +#include "mt6359.dtsi"
> +#include <dt-bindings/gpio/gpio.h>
> +#include <dt-bindings/input/input.h>
> +#include <dt-bindings/interrupt-controller/irq.h>
> +#include <dt-bindings/pinctrl/mediatek,mt8188-pinfunc.h>
> +#include <dt-bindings/regulator/mediatek,mt6360-regulator.h>
> +#include <dt-bindings/spmi/spmi.h>
> +#include <dt-bindings/usb/pd.h>
> +
> +/ {
> +       model = "MediaTek Genio-700 EVK";
> +       compatible = "mediatek,mt8390-evk", "mediatek,mt8390",
> +                    "mediatek,mt8188";
> +
> +       aliases {
> +               serial0 = &uart0;
> +       };
> +
> +       chosen {
> +               stdout-path = "serial0:921600n8";
> +       };
> +
> +       firmware {
> +               optee {
> +                       compatible = "linaro,optee-tz";
> +                       method = "smc";
> +               };
> +       };
> +
> +       memory@40000000 {
> +               device_type = "memory";
> +               reg = <0 0x40000000 0x2 0x00000000>;
> +       };
> +
> +       reserved-memory {
> +               #address-cells = <2>;
> +               #size-cells = <2>;
> +               ranges;
> +
> +               /*
> +                * 12 MiB reserved for OP-TEE (BL32)
> +                * +-----------------------+ 0x43e0_0000
> +                * |      SHMEM 2MiB       |
> +                * +-----------------------+ 0x43c0_0000
> +                * |        | TA_RAM  8MiB |
> +                * + TZDRAM +--------------+ 0x4340_0000
> +                * |        | TEE_RAM 2MiB |
> +                * +-----------------------+ 0x4320_0000
> +                */
> +               optee_reserved: optee@43200000 {
> +                       no-map;
> +                       reg = <0 0x43200000 0 0x00c00000>;
> +               };
> +
> +               scp_mem: memory@50000000 {
> +                       compatible = "shared-dma-pool";
> +                       reg = <0 0x50000000 0 0x2900000>;
> +                       no-map;
> +               };
> +
> +               /* 2 MiB reserved for ARM Trusted Firmware (BL31) */
> +               bl31_secmon_reserved: memory@54600000 {
> +                       no-map;
> +                       reg = <0 0x54600000 0x0 0x200000>;
> +               };
> +
> +               apu_mem: memory@55000000 {
> +                       compatible = "shared-dma-pool";
> +                       reg = <0 0x55000000 0 0x1400000>; /* 20 MB */
> +               };
> +
> +               vpu_mem: memory@57000000 {
> +                       compatible = "shared-dma-pool";
> +                       reg = <0 0x57000000 0 0x1400000>; /* 20 MB */
> +               };
> +       };
> +
> +       common_fixed_5v: regulator-0 {
> +               compatible = "regulator-fixed";
> +               regulator-name = "5v_en";
> +               regulator-min-microvolt = <5000000>;
> +               regulator-max-microvolt = <5000000>;
> +               gpio = <&pio 10 GPIO_ACTIVE_HIGH>;
> +               enable-active-high;
> +               regulator-always-on;
> +       };
> +
> +       edp_panel_fixed_3v3: regulator-1 {
> +               compatible = "regulator-fixed";
> +               regulator-name = "edp_panel_3v3";
> +               regulator-min-microvolt = <3300000>;
> +               regulator-max-microvolt = <3300000>;
> +               enable-active-high;
> +               gpio = <&pio 15 GPIO_ACTIVE_HIGH>;
> +               pinctrl-names = "default";
> +               pinctrl-0 = <&edp_panel_3v3_en_pins>;
> +       };
> +
> +       gpio_fixed_3v3: regulator-2 {
> +               compatible = "regulator-fixed";
> +               regulator-name = "gpio_3v3_en";
> +               regulator-min-microvolt = <3300000>;
> +               regulator-max-microvolt = <3300000>;
> +               gpio = <&pio 9 GPIO_ACTIVE_HIGH>;
> +               enable-active-high;
> +               regulator-always-on;
> +       };
> +
> +       sdio_fixed_1v8: regulator-3 {
> +               compatible = "regulator-fixed";
> +               regulator-name = "sdio_io";
> +               regulator-min-microvolt = <1800000>;
> +               regulator-max-microvolt = <1800000>;
> +               enable-active-high;
> +               regulator-always-on;
> +       };
> +
> +       sdio_fixed_3v3: regulator-4 {
> +               compatible = "regulator-fixed";
> +               regulator-name = "sdio_card";
> +               regulator-min-microvolt = <3300000>;
> +               regulator-max-microvolt = <3300000>;
> +               gpio = <&pio 74 GPIO_ACTIVE_HIGH>;
> +               enable-active-high;
> +               regulator-always-on;
> +       };
> +
> +       touch0_fixed_3v3: regulator-5 {
> +               compatible = "regulator-fixed";
> +               regulator-name = "touch_3v3";
> +               regulator-min-microvolt = <3300000>;
> +               regulator-max-microvolt = <3300000>;
> +               gpio = <&pio 119 GPIO_ACTIVE_HIGH>;
> +               enable-active-high;
> +       };
> +
> +       usb_hub_fixed_3v3: regulator-6 {
> +               compatible = "regulator-fixed";
> +               regulator-name = "usb_hub_3v3";
> +               regulator-min-microvolt = <3300000>;
> +               regulator-max-microvolt = <3300000>;
> +               gpio = <&pio 112 GPIO_ACTIVE_HIGH>; /* HUB_3V3_EN */
> +               startup-delay-us = <10000>;
> +               enable-active-high;
> +       };
> +
> +       usb_hub_reset_1v8: regulator-7 {
> +               compatible = "regulator-fixed";
> +               regulator-name = "usb_hub_reset";
> +               regulator-min-microvolt = <1800000>;
> +               regulator-max-microvolt = <1800000>;
> +               gpio = <&pio 7 GPIO_ACTIVE_HIGH>; /* HUB_RESET */
> +               vin-supply = <&usb_hub_fixed_3v3>;
> +       };
> +
> +       usb_p0_vbus: regulator-8 {
> +               compatible = "regulator-fixed";
> +               regulator-name = "usb_p0_vbus";
> +               regulator-min-microvolt = <5000000>;
> +               regulator-max-microvolt = <5000000>;
> +               gpio = <&pio 84 GPIO_ACTIVE_HIGH>;
> +               enable-active-high;
> +       };
> +
> +       usb_p1_vbus: regulator-9 {
> +               compatible = "regulator-fixed";
> +               regulator-name = "usb_p1_vbus";
> +               regulator-min-microvolt = <5000000>;
> +               regulator-max-microvolt = <5000000>;
> +               gpio = <&pio 87 GPIO_ACTIVE_HIGH>;
> +               enable-active-high;
> +       };
> +
> +       usb_p2_vbus: regulator-10 {
> +               compatible = "regulator-fixed";
> +               regulator-name = "usb_p2_vbus";
> +               regulator-min-microvolt = <5000000>;
> +               regulator-max-microvolt = <5000000>;
> +               enable-active-high;
> +       };

Please try to provide supplies for all the fixed regulators if possible?

> +};
> +
> +&i2c0 {
> +       pinctrl-names = "default";
> +       pinctrl-0 = <&i2c0_pins>;
> +       clock-frequency = <400000>;
> +       status = "okay";
> +
> +       touchscreen@5d {
> +               compatible = "goodix,gt9271";
> +               reg = <0x5d>;
> +               interrupt-parent = <&pio>;
> +               interrupts-extended = <&pio 6 IRQ_TYPE_EDGE_RISING>;
> +               irq-gpios = <&pio 6 GPIO_ACTIVE_HIGH>;
> +               reset-gpios = <&pio 5 GPIO_ACTIVE_HIGH>;
> +               AVDD28-supply = <&touch0_fixed_3v3>;
> +               VDDIO-supply = <&mt6359_vio18_ldo_reg>;
> +               pinctrl-names = "default";
> +               pinctrl-0 = <&touch_pins>;
> +       };
> +};
> +
> +&i2c1 {
> +       pinctrl-names = "default";
> +       pinctrl-0 = <&i2c1_pins>;
> +       clock-frequency = <400000>;
> +       status = "okay";
> +};
> +
> +&i2c2 {
> +       pinctrl-names = "default";
> +       pinctrl-0 = <&i2c2_pins>;
> +       clock-frequency = <400000>;
> +       status = "okay";
> +};
> +
> +&i2c3 {
> +       pinctrl-names = "default";
> +       pinctrl-0 = <&i2c3_pins>;
> +       clock-frequency = <400000>;
> +       status = "okay";
> +};
> +
> +&i2c4 {
> +       pinctrl-names = "default";
> +       pinctrl-0 = <&i2c4_pins>;
> +       pinctrl-1 = <&rt1715_int_pins>;
> +       clock-frequency = <1000000>;
> +       status = "okay";
> +};
> +
> +&i2c5 {
> +       pinctrl-names = "default";
> +       pinctrl-0 = <&i2c5_pins>;
> +       clock-frequency = <400000>;
> +       status = "okay";
> +};
> +
> +&i2c6 {
> +       pinctrl-names = "default";
> +       pinctrl-0 = <&i2c6_pins>;
> +       clock-frequency = <400000>;
> +       status = "okay";
> +};

Are all these I2C controllers used or connected to something? Are they
on dedicated headers or a generic Raspberry-Pi-like GPIO header?

> +&mmc0 {
> +       status = "okay";
> +       pinctrl-names = "default", "state_uhs";
> +       pinctrl-0 = <&mmc0_default_pins>;
> +       pinctrl-1 = <&mmc0_uhs_pins>;
> +       bus-width = <8>;
> +       max-frequency = <200000000>;
> +       cap-mmc-highspeed;
> +       mmc-hs200-1_8v;
> +       mmc-hs400-1_8v;
> +       supports-cqe;
> +       cap-mmc-hw-reset;
> +       no-sdio;
> +       no-sd;
> +       hs400-ds-delay = <0x1481b>;
> +       vmmc-supply = <&mt6359_vemc_1_ldo_reg>;
> +       vqmmc-supply = <&mt6359_vufs_ldo_reg>;
> +       non-removable;
> +};
> +
> +&mmc1 {
> +       status = "okay";
> +       pinctrl-names = "default", "state_uhs";
> +       pinctrl-0 = <&mmc1_default_pins>;
> +       pinctrl-1 = <&mmc1_uhs_pins>;
> +       bus-width = <4>;
> +       max-frequency = <200000000>;
> +       cap-sd-highspeed;
> +       sd-uhs-sdr50;
> +       sd-uhs-sdr104;
> +       no-mmc;
> +       no-sdio;
> +       cd-gpios = <&pio 2 GPIO_ACTIVE_LOW>;
> +       vmmc-supply = <&mt6359_vpa_buck_reg>;
> +       vqmmc-supply = <&mt6359_vsim1_ldo_reg>;
> +};
> +
> +&mt6359_vbbck_ldo_reg {
> +       regulator-always-on;
> +};
> +
> +&mt6359_vcn18_ldo_reg {
> +       regulator-always-on;
> +};
> +
> +&mt6359_vcn33_2_bt_ldo_reg {
> +       regulator-always-on;
> +};
> +
> +&mt6359_vcore_buck_reg {
> +       regulator-always-on;
> +};
> +
> +&mt6359_vgpu11_buck_reg {
> +       regulator-always-on;
> +};
> +
> +&mt6359_vpa_buck_reg {
> +       regulator-max-microvolt = <3100000>;
> +};
> +
> +&mt6359_vpu_buck_reg {
> +       regulator-always-on;
> +};
> +
> +&mt6359_vrf12_ldo_reg {
> +       regulator-always-on;
> +};
> +
> +&mt6359_vsim1_ldo_reg {
> +       regulator-enable-ramp-delay = <480>;
> +};
> +
> +&mt6359_vufs_ldo_reg {
> +       regulator-always-on;
> +};
> +
> +&mt6359codec {
> +       mediatek,mic-type-0 = <1>; /* ACC */
> +       mediatek,mic-type-1 = <3>; /* DCC */
> +};
> +
> +&pio {
> +       audio_default_pins: audio-default-pins {
> +               pins-cmd-dat {
> +                       pinmux = <PINMUX_GPIO101__FUNC_O_AUD_CLK_MOSI>,
> +                                <PINMUX_GPIO102__FUNC_O_AUD_SYNC_MOSI>,
> +                                <PINMUX_GPIO103__FUNC_O_AUD_DAT_MOSI0>,
> +                                <PINMUX_GPIO104__FUNC_O_AUD_DAT_MOSI1>,
> +                                <PINMUX_GPIO105__FUNC_I0_AUD_DAT_MISO0>,
> +                                <PINMUX_GPIO106__FUNC_I0_AUD_DAT_MISO1>,
> +                                <PINMUX_GPIO107__FUNC_B0_I2SIN_MCK>,
> +                                <PINMUX_GPIO108__FUNC_B0_I2SIN_BCK>,
> +                                <PINMUX_GPIO109__FUNC_B0_I2SIN_WS>,
> +                                <PINMUX_GPIO110__FUNC_I0_I2SIN_D0>,
> +                                <PINMUX_GPIO114__FUNC_O_I2SO2_MCK>,
> +                                <PINMUX_GPIO115__FUNC_B0_I2SO2_BCK>,
> +                                <PINMUX_GPIO116__FUNC_B0_I2SO2_WS>,
> +                                <PINMUX_GPIO117__FUNC_O_I2SO2_D0>,
> +                                <PINMUX_GPIO118__FUNC_O_I2SO2_D1>,
> +                                <PINMUX_GPIO121__FUNC_B0_PCM_CLK>,
> +                                <PINMUX_GPIO122__FUNC_B0_PCM_SYNC>,
> +                                <PINMUX_GPIO124__FUNC_I0_PCM_DI>,
> +                                <PINMUX_GPIO125__FUNC_O_DMIC1_CLK>,
> +                                <PINMUX_GPIO126__FUNC_I0_DMIC1_DAT>,
> +                                <PINMUX_GPIO128__FUNC_O_DMIC2_CLK>,
> +                                <PINMUX_GPIO129__FUNC_I0_DMIC2_DAT>;
> +               };
> +       };
> +
> +       dptx_pins: dptx-pins {
> +               pins-cmd-dat {
> +                       pinmux = <PINMUX_GPIO46__FUNC_I0_DP_TX_HPD>;
> +                       bias-pull-up;
> +               };
> +       };
> +
> +       edp_panel_3v3_en_pins: edp-panel-3v3-en-pins {
> +               pins1 {
> +                       pinmux = <PINMUX_GPIO15__FUNC_B_GPIO15>;
> +                       output-high;
> +               };
> +       };
> +
> +       eth_default_pins: eth-default-pins {
> +               pins-cc {
> +                       pinmux = <PINMUX_GPIO139__FUNC_B0_GBE_TXC>,
> +                                <PINMUX_GPIO140__FUNC_I0_GBE_RXC>,
> +                                <PINMUX_GPIO141__FUNC_I0_GBE_RXDV>,
> +                                <PINMUX_GPIO142__FUNC_O_GBE_TXEN>;
> +                       drive-strength = <MTK_DRIVE_8mA>;
> +               };
> +
> +               pins-mdio {
> +                       pinmux = <PINMUX_GPIO143__FUNC_O_GBE_MDC>,
> +                                <PINMUX_GPIO144__FUNC_B1_GBE_MDIO>;
> +                       drive-strength = <MTK_DRIVE_8mA>;
> +                       input-enable;
> +               };
> +
> +               pins-power {
> +                       pinmux = <PINMUX_GPIO145__FUNC_B_GPIO145>,
> +                                <PINMUX_GPIO146__FUNC_B_GPIO146>;
> +                       output-high;
> +               };
> +
> +               pins-rxd {
> +                       pinmux = <PINMUX_GPIO135__FUNC_I0_GBE_RXD3>,
> +                                <PINMUX_GPIO136__FUNC_I0_GBE_RXD2>,
> +                                <PINMUX_GPIO137__FUNC_I0_GBE_RXD1>,
> +                                <PINMUX_GPIO138__FUNC_I0_GBE_RXD0>;
> +                       drive-strength = <MTK_DRIVE_8mA>;
> +               };
> +
> +               pins-txd {
> +                       pinmux = <PINMUX_GPIO131__FUNC_O_GBE_TXD3>,
> +                                <PINMUX_GPIO132__FUNC_O_GBE_TXD2>,
> +                                <PINMUX_GPIO133__FUNC_O_GBE_TXD1>,
> +                                <PINMUX_GPIO134__FUNC_O_GBE_TXD0>;
> +                       drive-strength = <MTK_DRIVE_8mA>;
> +               };
> +       };
> +
> +       eth_sleep_pins: eth-sleep-pins {
> +               pins-cc {
> +                       pinmux = <PINMUX_GPIO139__FUNC_B_GPIO139>,
> +                                <PINMUX_GPIO140__FUNC_B_GPIO140>,
> +                                <PINMUX_GPIO141__FUNC_B_GPIO141>,
> +                                <PINMUX_GPIO142__FUNC_B_GPIO142>;
> +               };
> +
> +               pins-mdio {
> +                       pinmux = <PINMUX_GPIO143__FUNC_B_GPIO143>,
> +                                <PINMUX_GPIO144__FUNC_B_GPIO144>;
> +                       input-disable;
> +                       bias-disable;
> +               };
> +
> +               pins-rxd {
> +                       pinmux = <PINMUX_GPIO135__FUNC_B_GPIO135>,
> +                                <PINMUX_GPIO136__FUNC_B_GPIO136>,
> +                                <PINMUX_GPIO137__FUNC_B_GPIO137>,
> +                                <PINMUX_GPIO138__FUNC_B_GPIO138>;
> +               };
> +
> +               pins-txd {
> +                       pinmux = <PINMUX_GPIO131__FUNC_B_GPIO131>,
> +                                <PINMUX_GPIO132__FUNC_B_GPIO132>,
> +                                <PINMUX_GPIO133__FUNC_B_GPIO133>,
> +                                <PINMUX_GPIO134__FUNC_B_GPIO134>;
> +               };
> +       };
> +
> +       i2c0_pins: i2c0-pins {
> +               pins {
> +                       pinmux = <PINMUX_GPIO56__FUNC_B1_SDA0>,
> +                                <PINMUX_GPIO55__FUNC_B1_SCL0>;
> +                       bias-pull-up = <MTK_PULL_SET_RSEL_011>;
> +                       drive-strength-microamp = <1000>;
> +               };
> +       };
> +
> +       i2c1_pins: i2c1-pins {
> +               pins {
> +                       pinmux = <PINMUX_GPIO58__FUNC_B1_SDA1>,
> +                                <PINMUX_GPIO57__FUNC_B1_SCL1>;
> +                       bias-pull-up = <MTK_PULL_SET_RSEL_011>;
> +                       drive-strength-microamp = <1000>;
> +               };
> +       };
> +
> +       i2c2_pins: i2c2-pins {
> +               pins {
> +                       pinmux = <PINMUX_GPIO60__FUNC_B1_SDA2>,
> +                                <PINMUX_GPIO59__FUNC_B1_SCL2>;
> +                       bias-pull-up = <MTK_PULL_SET_RSEL_011>;
> +                       drive-strength-microamp = <1000>;
> +               };
> +       };
> +
> +       i2c3_pins: i2c3-pins {
> +               pins {
> +                       pinmux = <PINMUX_GPIO62__FUNC_B1_SDA3>,
> +                                <PINMUX_GPIO61__FUNC_B1_SCL3>;
> +                       bias-pull-up = <MTK_PULL_SET_RSEL_011>;
> +                       drive-strength-microamp = <1000>;
> +               };
> +       };
> +
> +       i2c4_pins: i2c4-pins {
> +               pins {
> +                       pinmux = <PINMUX_GPIO64__FUNC_B1_SDA4>,
> +                                <PINMUX_GPIO63__FUNC_B1_SCL4>;
> +                       bias-pull-up = <MTK_PULL_SET_RSEL_011>;
> +                       drive-strength-microamp = <1000>;
> +               };
> +       };
> +
> +       i2c5_pins: i2c5-pins {
> +               pins {
> +                       pinmux = <PINMUX_GPIO66__FUNC_B1_SDA5>,
> +                                <PINMUX_GPIO65__FUNC_B1_SCL5>;
> +                       bias-pull-up = <MTK_PULL_SET_RSEL_011>;
> +                       drive-strength-microamp = <1000>;
> +               };
> +       };
> +
> +       i2c6_pins: i2c6-pins {
> +               pins {
> +                       pinmux = <PINMUX_GPIO68__FUNC_B1_SDA6>,
> +                                <PINMUX_GPIO67__FUNC_B1_SCL6>;
> +                       bias-pull-up = <MTK_PULL_SET_RSEL_011>;
> +                       drive-strength-microamp = <1000>;
> +               };
> +       };
> +
> +       gpio_key_pins: gpio-key-pins {
> +               pins {
> +                       pinmux = <PINMUX_GPIO42__FUNC_B1_KPCOL0>,
> +                                <PINMUX_GPIO43__FUNC_B1_KPCOL1>,
> +                                <PINMUX_GPIO44__FUNC_B1_KPROW0>;
> +               };
> +       };
> +
> +       mmc0_default_pins: mmc0-default-pins {
> +               pins-clk {
> +                       pinmux = <PINMUX_GPIO157__FUNC_B1_MSDC0_CLK>;
> +                       drive-strength = <MTK_DRIVE_6mA>;
> +                       bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
> +               };
> +
> +               pins-cmd-dat {
> +                       pinmux = <PINMUX_GPIO161__FUNC_B1_MSDC0_DAT0>,
> +                                <PINMUX_GPIO160__FUNC_B1_MSDC0_DAT1>,
> +                                <PINMUX_GPIO159__FUNC_B1_MSDC0_DAT2>,
> +                                <PINMUX_GPIO158__FUNC_B1_MSDC0_DAT3>,
> +                                <PINMUX_GPIO154__FUNC_B1_MSDC0_DAT4>,
> +                                <PINMUX_GPIO153__FUNC_B1_MSDC0_DAT5>,
> +                                <PINMUX_GPIO152__FUNC_B1_MSDC0_DAT6>,
> +                                <PINMUX_GPIO151__FUNC_B1_MSDC0_DAT7>,
> +                                <PINMUX_GPIO156__FUNC_B1_MSDC0_CMD>;
> +                       input-enable;
> +                       drive-strength = <MTK_DRIVE_6mA>;
> +                       bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
> +               };
> +
> +               pins-rst {
> +                       pinmux = <PINMUX_GPIO155__FUNC_O_MSDC0_RSTB>;
> +                       drive-strength = <MTK_DRIVE_6mA>;
> +                       bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
> +               };
> +       };
> +
> +       mmc0_uhs_pins: mmc0-uhs-pins {
> +               pins-clk {
> +                       pinmux = <PINMUX_GPIO157__FUNC_B1_MSDC0_CLK>;
> +                       drive-strength = <MTK_DRIVE_8mA>;
> +                       bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
> +               };
> +
> +               pins-cmd-dat {
> +                       pinmux = <PINMUX_GPIO161__FUNC_B1_MSDC0_DAT0>,
> +                                <PINMUX_GPIO160__FUNC_B1_MSDC0_DAT1>,
> +                                <PINMUX_GPIO159__FUNC_B1_MSDC0_DAT2>,
> +                                <PINMUX_GPIO158__FUNC_B1_MSDC0_DAT3>,
> +                                <PINMUX_GPIO154__FUNC_B1_MSDC0_DAT4>,
> +                                <PINMUX_GPIO153__FUNC_B1_MSDC0_DAT5>,
> +                                <PINMUX_GPIO152__FUNC_B1_MSDC0_DAT6>,
> +                                <PINMUX_GPIO151__FUNC_B1_MSDC0_DAT7>,
> +                                <PINMUX_GPIO156__FUNC_B1_MSDC0_CMD>;
> +                       input-enable;
> +                       drive-strength = <MTK_DRIVE_8mA>;
> +                       bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
> +               };
> +
> +               pins-ds {
> +                       pinmux = <PINMUX_GPIO162__FUNC_B0_MSDC0_DSL>;
> +                       drive-strength = <MTK_DRIVE_8mA>;
> +                       bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
> +               };
> +
> +               pins-rst {
> +                       pinmux = <PINMUX_GPIO155__FUNC_O_MSDC0_RSTB>;
> +                       drive-strength = <MTK_DRIVE_8mA>;
> +                       bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
> +               };
> +       };
> +
> +       mmc1_default_pins: mmc1-default-pins {
> +               pins-clk {
> +                       pinmux = <PINMUX_GPIO164__FUNC_B1_MSDC1_CLK>;
> +                       drive-strength = <MTK_DRIVE_6mA>;
> +                       bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
> +               };
> +
> +               pins-cmd-dat {
> +                       pinmux = <PINMUX_GPIO163__FUNC_B1_MSDC1_CMD>,
> +                                <PINMUX_GPIO165__FUNC_B1_MSDC1_DAT0>,
> +                                <PINMUX_GPIO166__FUNC_B1_MSDC1_DAT1>,
> +                                <PINMUX_GPIO167__FUNC_B1_MSDC1_DAT2>,
> +                                <PINMUX_GPIO168__FUNC_B1_MSDC1_DAT3>;
> +                       input-enable;
> +                       drive-strength = <MTK_DRIVE_6mA>;
> +                       bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
> +               };
> +
> +               pins-insert {
> +                       pinmux = <PINMUX_GPIO2__FUNC_B_GPIO2>;
> +                       bias-pull-up;
> +               };
> +       };
> +
> +       mmc1_uhs_pins: mmc1-uhs-pins {
> +               pins-clk {
> +                       pinmux = <PINMUX_GPIO164__FUNC_B1_MSDC1_CLK>;
> +                       drive-strength = <MTK_DRIVE_6mA>;
> +                       bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
> +               };
> +
> +               pins-cmd-dat {
> +                       pinmux = <PINMUX_GPIO163__FUNC_B1_MSDC1_CMD>,
> +                                <PINMUX_GPIO165__FUNC_B1_MSDC1_DAT0>,
> +                                <PINMUX_GPIO166__FUNC_B1_MSDC1_DAT1>,
> +                                <PINMUX_GPIO167__FUNC_B1_MSDC1_DAT2>,
> +                                <PINMUX_GPIO168__FUNC_B1_MSDC1_DAT3>;
> +                       input-enable;
> +                       drive-strength = <MTK_DRIVE_6mA>;
> +                       bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
> +               };
> +       };
> +
> +       mmc2_default_pins: mmc2-default-pins {
> +               pins-clk {
> +                       pinmux = <PINMUX_GPIO170__FUNC_B1_MSDC2_CLK>;
> +                       drive-strength = <MTK_DRIVE_4mA>;
> +                       bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
> +               };
> +
> +               pins-cmd-dat {
> +                       pinmux = <PINMUX_GPIO169__FUNC_B1_MSDC2_CMD>,
> +                                <PINMUX_GPIO171__FUNC_B1_MSDC2_DAT0>,
> +                                <PINMUX_GPIO172__FUNC_B1_MSDC2_DAT1>,
> +                                <PINMUX_GPIO173__FUNC_B1_MSDC2_DAT2>,
> +                                <PINMUX_GPIO174__FUNC_B1_MSDC2_DAT3>;
> +                       input-enable;
> +                       drive-strength = <MTK_DRIVE_6mA>;
> +                       bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
> +               };
> +
> +               pins-pcm {
> +                       pinmux = <PINMUX_GPIO123__FUNC_O_PCM_DO>;
> +               };
> +       };
> +
> +       mmc2_uhs_pins: mmc2-uhs-pins {
> +               pins-clk {
> +                       pinmux = <PINMUX_GPIO170__FUNC_B1_MSDC2_CLK>;
> +                       drive-strength = <MTK_DRIVE_4mA>;
> +                       bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
> +               };
> +
> +               pins-cmd-dat {
> +                       pinmux = <PINMUX_GPIO169__FUNC_B1_MSDC2_CMD>,
> +                                <PINMUX_GPIO171__FUNC_B1_MSDC2_DAT0>,
> +                                <PINMUX_GPIO172__FUNC_B1_MSDC2_DAT1>,
> +                                <PINMUX_GPIO173__FUNC_B1_MSDC2_DAT2>,
> +                                <PINMUX_GPIO174__FUNC_B1_MSDC2_DAT3>;
> +                       input-enable;
> +                       drive-strength = <MTK_DRIVE_6mA>;
> +                       bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
> +               };
> +       };
> +
> +       mmc2_eint_pins: mmc2-eint-pins {
> +               pins-dat1 {
> +                       pinmux = <PINMUX_GPIO172__FUNC_B_GPIO172>;
> +                       input-enable;
> +                       bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
> +               };
> +       };
> +
> +       mmc2_dat1_pins: mmc2-dat1-pins {
> +               pins-dat1 {
> +                       pinmux = <PINMUX_GPIO172__FUNC_B1_MSDC2_DAT1>;
> +                       input-enable;
> +                       drive-strength = <MTK_DRIVE_6mA>;
> +                       bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
> +               };
> +       };
> +
> +       panel_default_pins: panel-default-pins {
> +               pins-dcdc {
> +                       pinmux = <PINMUX_GPIO45__FUNC_B_GPIO45>;
> +                       output-low;
> +               };
> +
> +               pins-en {
> +                       pinmux = <PINMUX_GPIO111__FUNC_B_GPIO111>;
> +                       output-low;
> +               };
> +
> +               pins-rst {
> +                       pinmux = <PINMUX_GPIO25__FUNC_B_GPIO25>;
> +                       output-high;
> +               };
> +       };
> +
> +       rt1715_int_pins: rt1715-int-pins {
> +               pins_cmd0_dat {
> +                       pinmux = <PINMUX_GPIO12__FUNC_B_GPIO12>;
> +                       bias-pull-up;
> +                       input-enable;
> +               };
> +       };
> +
> +       spi0_pins: spi0-pins {
> +               pins-spi {
> +                       pinmux = <PINMUX_GPIO69__FUNC_O_SPIM0_CSB>,
> +                               <PINMUX_GPIO70__FUNC_O_SPIM0_CLK>,
> +                               <PINMUX_GPIO71__FUNC_B0_SPIM0_MOSI>,
> +                               <PINMUX_GPIO72__FUNC_B0_SPIM0_MISO>;
> +                       bias-disable;
> +               };
> +       };
> +
> +       spi1_pins: spi1-pins {
> +               pins-spi {
> +                       pinmux = <PINMUX_GPIO75__FUNC_O_SPIM1_CSB>,
> +                               <PINMUX_GPIO76__FUNC_O_SPIM1_CLK>,
> +                               <PINMUX_GPIO77__FUNC_B0_SPIM1_MOSI>,
> +                               <PINMUX_GPIO78__FUNC_B0_SPIM1_MISO>;
> +                       bias-disable;
> +               };
> +       };
> +
> +       spi2_pins: spi2-pins {
> +               pins-spi {
> +                       pinmux = <PINMUX_GPIO79__FUNC_O_SPIM2_CSB>,
> +                               <PINMUX_GPIO80__FUNC_O_SPIM2_CLK>,
> +                               <PINMUX_GPIO81__FUNC_B0_SPIM2_MOSI>,
> +                               <PINMUX_GPIO82__FUNC_B0_SPIM2_MISO>;
> +                       bias-disable;
> +               };
> +       };
> +
> +       touch_pins: touch-pins {
> +               pins-irq {
> +                       pinmux = <PINMUX_GPIO6__FUNC_B_GPIO6>;
> +                       input-enable;
> +                       bias-disable;
> +               };
> +
> +               pins-reset {
> +                       pinmux = <PINMUX_GPIO5__FUNC_B_GPIO5>;
> +                       output-high;
> +               };
> +       };
> +
> +       uart0_pins: uart0-pins {
> +               pins {
> +                       pinmux = <PINMUX_GPIO31__FUNC_O_UTXD0>,
> +                                <PINMUX_GPIO32__FUNC_I1_URXD0>;
> +                       bias-pull-up;
> +               };
> +       };
> +
> +       uart1_pins: uart1-pins {
> +               pins {
> +                       pinmux = <PINMUX_GPIO33__FUNC_O_UTXD1>,
> +                                <PINMUX_GPIO34__FUNC_I1_URXD1>;
> +                       bias-pull-up;
> +               };
> +       };
> +
> +       uart2_pins: uart2-pins {
> +               pins {
> +                       pinmux = <PINMUX_GPIO35__FUNC_O_UTXD2>,
> +                                <PINMUX_GPIO36__FUNC_I1_URXD2>;
> +                       bias-pull-up;
> +               };
> +       };
> +
> +       usb_default_pins: usb-default-pins {
> +               pins-iddig {
> +                       pinmux = <PINMUX_GPIO83__FUNC_B_GPIO83>;
> +                       input-enable;
> +                       bias-pull-up;
> +               };
> +
> +               pins-valid {
> +                       pinmux = <PINMUX_GPIO85__FUNC_I0_VBUSVALID>;
> +                       input-enable;
> +               };
> +
> +               pins-vbus {
> +                       pinmux = <PINMUX_GPIO84__FUNC_O_USB_DRVVBUS>;
> +                       output-high;
> +               };
> +
> +       };
> +
> +       usb1_default_pins: usb1-default-pins {
> +               pins-valid {
> +                       pinmux = <PINMUX_GPIO88__FUNC_I0_VBUSVALID_1P>;
> +                       input-enable;
> +               };
> +
> +               pins-usb-hub-3v3-en {
> +                       pinmux = <PINMUX_GPIO112__FUNC_B_GPIO112>;
> +                       output-high;
> +               };
> +       };
> +
> +       wifi_pwrseq_pins: wifi-pwrseq-pins {
> +               pins-wifi-enable {
> +                       pinmux = <PINMUX_GPIO127__FUNC_B_GPIO127>;
> +                       output-low;
> +               };
> +       };
> +};
> +
> +&pmic {
> +       interrupt-parent = <&pio>;
> +       interrupts = <222 IRQ_TYPE_LEVEL_HIGH>;
> +};
> +
> +&scp {
> +       memory-region = <&scp_mem>;
> +       status = "okay";
> +};
> +
> +&uart0 {
> +       pinctrl-0 = <&uart0_pins>;
> +       pinctrl-names = "default";
> +       status = "okay";
> +};
> +
> +&uart1 {
> +       pinctrl-0 = <&uart1_pins>;
> +       pinctrl-names = "default";
> +       status = "okay";
> +};
> +
> +&uart2 {
> +       pinctrl-0 = <&uart2_pins>;
> +       pinctrl-names = "default";
> +       status = "okay";
> +};
> +
> +&spi2 {
> +       pinctrl-0 = <&spi2_pins>;
> +       pinctrl-names = "default";
> +       mediatek,pad-select = <0>;
> +       #address-cells = <1>;
> +       #size-cells = <0>;
> +       status = "okay";
> +};

This should be moved to before the uarts and after the scp.

> +&u3phy0 {
> +       status = "okay";
> +};
> +
> +&u3phy1 {
> +       status = "okay";
> +};
> +
> +&u3phy2 {
> +       status = "okay";
> +};
> +
> +&xhci0 {
> +       status = "okay";
> +       vusb33-supply = <&mt6359_vusb_ldo_reg>;
> +};
> +
> +&xhci1 {
> +       status = "okay";
> +       vusb33-supply = <&mt6359_vusb_ldo_reg>;
> +       vbus-supply = <&usb_hub_reset_1v8>;
> +};
> +
> +&xhci2 {
> +       status = "okay";
> +       vusb33-supply = <&mt6359_vusb_ldo_reg>;
> +};
> --
> 2.18.0
>
>
  

Patch

diff --git a/arch/arm64/boot/dts/mediatek/Makefile b/arch/arm64/boot/dts/mediatek/Makefile
index 22f362bbbdac..3262849c0f6b 100644
--- a/arch/arm64/boot/dts/mediatek/Makefile
+++ b/arch/arm64/boot/dts/mediatek/Makefile
@@ -54,5 +54,6 @@  dtb-$(CONFIG_ARCH_MEDIATEK) += mt8195-cherry-tomato-r3.dtb
 dtb-$(CONFIG_ARCH_MEDIATEK) += mt8195-demo.dtb
 dtb-$(CONFIG_ARCH_MEDIATEK) += mt8195-evb.dtb
 dtb-$(CONFIG_ARCH_MEDIATEK) += mt8365-genio-350-evk.dtb
+dtb-$(CONFIG_ARCH_MEDIATEK) += mt8390-genio-700-evk.dtb
 dtb-$(CONFIG_ARCH_MEDIATEK) += mt8395-genio-1200-evk.dtb
 dtb-$(CONFIG_ARCH_MEDIATEK) += mt8516-pumpkin.dtb
diff --git a/arch/arm64/boot/dts/mediatek/mt8390-genio-700-evk.dts b/arch/arm64/boot/dts/mediatek/mt8390-genio-700-evk.dts
new file mode 100644
index 000000000000..6bb1d5d112ef
--- /dev/null
+++ b/arch/arm64/boot/dts/mediatek/mt8390-genio-700-evk.dts
@@ -0,0 +1,880 @@ 
+// SPDX-License-Identifier: (GPL-2.0 OR MIT)
+/*
+ * Copyright (C) 2023 MediaTek Inc.
+ * Author: Chris Chen <chris-qj.chen@mediatek.com>
+ *	   Pablo Sun <pablo.sun@mediatek.com>
+ *	   Macpaul Lin <macpaul.lin@mediatek.com>
+ */
+/dts-v1/;
+
+#include "mt8188.dtsi"
+#include "mt6359.dtsi"
+#include <dt-bindings/gpio/gpio.h>
+#include <dt-bindings/input/input.h>
+#include <dt-bindings/interrupt-controller/irq.h>
+#include <dt-bindings/pinctrl/mediatek,mt8188-pinfunc.h>
+#include <dt-bindings/regulator/mediatek,mt6360-regulator.h>
+#include <dt-bindings/spmi/spmi.h>
+#include <dt-bindings/usb/pd.h>
+
+/ {
+	model = "MediaTek Genio-700 EVK";
+	compatible = "mediatek,mt8390-evk", "mediatek,mt8390",
+		     "mediatek,mt8188";
+
+	aliases {
+		serial0 = &uart0;
+	};
+
+	chosen {
+		stdout-path = "serial0:921600n8";
+	};
+
+	firmware {
+		optee {
+			compatible = "linaro,optee-tz";
+			method = "smc";
+		};
+	};
+
+	memory@40000000 {
+		device_type = "memory";
+		reg = <0 0x40000000 0x2 0x00000000>;
+	};
+
+	reserved-memory {
+		#address-cells = <2>;
+		#size-cells = <2>;
+		ranges;
+
+		/*
+		 * 12 MiB reserved for OP-TEE (BL32)
+		 * +-----------------------+ 0x43e0_0000
+		 * |      SHMEM 2MiB       |
+		 * +-----------------------+ 0x43c0_0000
+		 * |        | TA_RAM  8MiB |
+		 * + TZDRAM +--------------+ 0x4340_0000
+		 * |        | TEE_RAM 2MiB |
+		 * +-----------------------+ 0x4320_0000
+		 */
+		optee_reserved: optee@43200000 {
+			no-map;
+			reg = <0 0x43200000 0 0x00c00000>;
+		};
+
+		scp_mem: memory@50000000 {
+			compatible = "shared-dma-pool";
+			reg = <0 0x50000000 0 0x2900000>;
+			no-map;
+		};
+
+		/* 2 MiB reserved for ARM Trusted Firmware (BL31) */
+		bl31_secmon_reserved: memory@54600000 {
+			no-map;
+			reg = <0 0x54600000 0x0 0x200000>;
+		};
+
+		apu_mem: memory@55000000 {
+			compatible = "shared-dma-pool";
+			reg = <0 0x55000000 0 0x1400000>; /* 20 MB */
+		};
+
+		vpu_mem: memory@57000000 {
+			compatible = "shared-dma-pool";
+			reg = <0 0x57000000 0 0x1400000>; /* 20 MB */
+		};
+	};
+
+	common_fixed_5v: regulator-0 {
+		compatible = "regulator-fixed";
+		regulator-name = "5v_en";
+		regulator-min-microvolt = <5000000>;
+		regulator-max-microvolt = <5000000>;
+		gpio = <&pio 10 GPIO_ACTIVE_HIGH>;
+		enable-active-high;
+		regulator-always-on;
+	};
+
+	edp_panel_fixed_3v3: regulator-1 {
+		compatible = "regulator-fixed";
+		regulator-name = "edp_panel_3v3";
+		regulator-min-microvolt = <3300000>;
+		regulator-max-microvolt = <3300000>;
+		enable-active-high;
+		gpio = <&pio 15 GPIO_ACTIVE_HIGH>;
+		pinctrl-names = "default";
+		pinctrl-0 = <&edp_panel_3v3_en_pins>;
+	};
+
+	gpio_fixed_3v3: regulator-2 {
+		compatible = "regulator-fixed";
+		regulator-name = "gpio_3v3_en";
+		regulator-min-microvolt = <3300000>;
+		regulator-max-microvolt = <3300000>;
+		gpio = <&pio 9 GPIO_ACTIVE_HIGH>;
+		enable-active-high;
+		regulator-always-on;
+	};
+
+	sdio_fixed_1v8: regulator-3 {
+		compatible = "regulator-fixed";
+		regulator-name = "sdio_io";
+		regulator-min-microvolt = <1800000>;
+		regulator-max-microvolt = <1800000>;
+		enable-active-high;
+		regulator-always-on;
+	};
+
+	sdio_fixed_3v3: regulator-4 {
+		compatible = "regulator-fixed";
+		regulator-name = "sdio_card";
+		regulator-min-microvolt = <3300000>;
+		regulator-max-microvolt = <3300000>;
+		gpio = <&pio 74 GPIO_ACTIVE_HIGH>;
+		enable-active-high;
+		regulator-always-on;
+	};
+
+	touch0_fixed_3v3: regulator-5 {
+		compatible = "regulator-fixed";
+		regulator-name = "touch_3v3";
+		regulator-min-microvolt = <3300000>;
+		regulator-max-microvolt = <3300000>;
+		gpio = <&pio 119 GPIO_ACTIVE_HIGH>;
+		enable-active-high;
+	};
+
+	usb_hub_fixed_3v3: regulator-6 {
+		compatible = "regulator-fixed";
+		regulator-name = "usb_hub_3v3";
+		regulator-min-microvolt = <3300000>;
+		regulator-max-microvolt = <3300000>;
+		gpio = <&pio 112 GPIO_ACTIVE_HIGH>; /* HUB_3V3_EN */
+		startup-delay-us = <10000>;
+		enable-active-high;
+	};
+
+	usb_hub_reset_1v8: regulator-7 {
+		compatible = "regulator-fixed";
+		regulator-name = "usb_hub_reset";
+		regulator-min-microvolt = <1800000>;
+		regulator-max-microvolt = <1800000>;
+		gpio = <&pio 7 GPIO_ACTIVE_HIGH>; /* HUB_RESET */
+		vin-supply = <&usb_hub_fixed_3v3>;
+	};
+
+	usb_p0_vbus: regulator-8 {
+		compatible = "regulator-fixed";
+		regulator-name = "usb_p0_vbus";
+		regulator-min-microvolt = <5000000>;
+		regulator-max-microvolt = <5000000>;
+		gpio = <&pio 84 GPIO_ACTIVE_HIGH>;
+		enable-active-high;
+	};
+
+	usb_p1_vbus: regulator-9 {
+		compatible = "regulator-fixed";
+		regulator-name = "usb_p1_vbus";
+		regulator-min-microvolt = <5000000>;
+		regulator-max-microvolt = <5000000>;
+		gpio = <&pio 87 GPIO_ACTIVE_HIGH>;
+		enable-active-high;
+	};
+
+	usb_p2_vbus: regulator-10 {
+		compatible = "regulator-fixed";
+		regulator-name = "usb_p2_vbus";
+		regulator-min-microvolt = <5000000>;
+		regulator-max-microvolt = <5000000>;
+		enable-active-high;
+	};
+};
+
+&i2c0 {
+	pinctrl-names = "default";
+	pinctrl-0 = <&i2c0_pins>;
+	clock-frequency = <400000>;
+	status = "okay";
+
+	touchscreen@5d {
+		compatible = "goodix,gt9271";
+		reg = <0x5d>;
+		interrupt-parent = <&pio>;
+		interrupts-extended = <&pio 6 IRQ_TYPE_EDGE_RISING>;
+		irq-gpios = <&pio 6 GPIO_ACTIVE_HIGH>;
+		reset-gpios = <&pio 5 GPIO_ACTIVE_HIGH>;
+		AVDD28-supply = <&touch0_fixed_3v3>;
+		VDDIO-supply = <&mt6359_vio18_ldo_reg>;
+		pinctrl-names = "default";
+		pinctrl-0 = <&touch_pins>;
+	};
+};
+
+&i2c1 {
+	pinctrl-names = "default";
+	pinctrl-0 = <&i2c1_pins>;
+	clock-frequency = <400000>;
+	status = "okay";
+};
+
+&i2c2 {
+	pinctrl-names = "default";
+	pinctrl-0 = <&i2c2_pins>;
+	clock-frequency = <400000>;
+	status = "okay";
+};
+
+&i2c3 {
+	pinctrl-names = "default";
+	pinctrl-0 = <&i2c3_pins>;
+	clock-frequency = <400000>;
+	status = "okay";
+};
+
+&i2c4 {
+	pinctrl-names = "default";
+	pinctrl-0 = <&i2c4_pins>;
+	pinctrl-1 = <&rt1715_int_pins>;
+	clock-frequency = <1000000>;
+	status = "okay";
+};
+
+&i2c5 {
+	pinctrl-names = "default";
+	pinctrl-0 = <&i2c5_pins>;
+	clock-frequency = <400000>;
+	status = "okay";
+};
+
+&i2c6 {
+	pinctrl-names = "default";
+	pinctrl-0 = <&i2c6_pins>;
+	clock-frequency = <400000>;
+	status = "okay";
+};
+
+&mmc0 {
+	status = "okay";
+	pinctrl-names = "default", "state_uhs";
+	pinctrl-0 = <&mmc0_default_pins>;
+	pinctrl-1 = <&mmc0_uhs_pins>;
+	bus-width = <8>;
+	max-frequency = <200000000>;
+	cap-mmc-highspeed;
+	mmc-hs200-1_8v;
+	mmc-hs400-1_8v;
+	supports-cqe;
+	cap-mmc-hw-reset;
+	no-sdio;
+	no-sd;
+	hs400-ds-delay = <0x1481b>;
+	vmmc-supply = <&mt6359_vemc_1_ldo_reg>;
+	vqmmc-supply = <&mt6359_vufs_ldo_reg>;
+	non-removable;
+};
+
+&mmc1 {
+	status = "okay";
+	pinctrl-names = "default", "state_uhs";
+	pinctrl-0 = <&mmc1_default_pins>;
+	pinctrl-1 = <&mmc1_uhs_pins>;
+	bus-width = <4>;
+	max-frequency = <200000000>;
+	cap-sd-highspeed;
+	sd-uhs-sdr50;
+	sd-uhs-sdr104;
+	no-mmc;
+	no-sdio;
+	cd-gpios = <&pio 2 GPIO_ACTIVE_LOW>;
+	vmmc-supply = <&mt6359_vpa_buck_reg>;
+	vqmmc-supply = <&mt6359_vsim1_ldo_reg>;
+};
+
+&mt6359_vbbck_ldo_reg {
+	regulator-always-on;
+};
+
+&mt6359_vcn18_ldo_reg {
+	regulator-always-on;
+};
+
+&mt6359_vcn33_2_bt_ldo_reg {
+	regulator-always-on;
+};
+
+&mt6359_vcore_buck_reg {
+	regulator-always-on;
+};
+
+&mt6359_vgpu11_buck_reg {
+	regulator-always-on;
+};
+
+&mt6359_vpa_buck_reg {
+	regulator-max-microvolt = <3100000>;
+};
+
+&mt6359_vpu_buck_reg {
+	regulator-always-on;
+};
+
+&mt6359_vrf12_ldo_reg {
+	regulator-always-on;
+};
+
+&mt6359_vsim1_ldo_reg {
+	regulator-enable-ramp-delay = <480>;
+};
+
+&mt6359_vufs_ldo_reg {
+	regulator-always-on;
+};
+
+&mt6359codec {
+	mediatek,mic-type-0 = <1>; /* ACC */
+	mediatek,mic-type-1 = <3>; /* DCC */
+};
+
+&pio {
+	audio_default_pins: audio-default-pins {
+		pins-cmd-dat {
+			pinmux = <PINMUX_GPIO101__FUNC_O_AUD_CLK_MOSI>,
+				 <PINMUX_GPIO102__FUNC_O_AUD_SYNC_MOSI>,
+				 <PINMUX_GPIO103__FUNC_O_AUD_DAT_MOSI0>,
+				 <PINMUX_GPIO104__FUNC_O_AUD_DAT_MOSI1>,
+				 <PINMUX_GPIO105__FUNC_I0_AUD_DAT_MISO0>,
+				 <PINMUX_GPIO106__FUNC_I0_AUD_DAT_MISO1>,
+				 <PINMUX_GPIO107__FUNC_B0_I2SIN_MCK>,
+				 <PINMUX_GPIO108__FUNC_B0_I2SIN_BCK>,
+				 <PINMUX_GPIO109__FUNC_B0_I2SIN_WS>,
+				 <PINMUX_GPIO110__FUNC_I0_I2SIN_D0>,
+				 <PINMUX_GPIO114__FUNC_O_I2SO2_MCK>,
+				 <PINMUX_GPIO115__FUNC_B0_I2SO2_BCK>,
+				 <PINMUX_GPIO116__FUNC_B0_I2SO2_WS>,
+				 <PINMUX_GPIO117__FUNC_O_I2SO2_D0>,
+				 <PINMUX_GPIO118__FUNC_O_I2SO2_D1>,
+				 <PINMUX_GPIO121__FUNC_B0_PCM_CLK>,
+				 <PINMUX_GPIO122__FUNC_B0_PCM_SYNC>,
+				 <PINMUX_GPIO124__FUNC_I0_PCM_DI>,
+				 <PINMUX_GPIO125__FUNC_O_DMIC1_CLK>,
+				 <PINMUX_GPIO126__FUNC_I0_DMIC1_DAT>,
+				 <PINMUX_GPIO128__FUNC_O_DMIC2_CLK>,
+				 <PINMUX_GPIO129__FUNC_I0_DMIC2_DAT>;
+		};
+	};
+
+	dptx_pins: dptx-pins {
+		pins-cmd-dat {
+			pinmux = <PINMUX_GPIO46__FUNC_I0_DP_TX_HPD>;
+			bias-pull-up;
+		};
+	};
+
+	edp_panel_3v3_en_pins: edp-panel-3v3-en-pins {
+		pins1 {
+			pinmux = <PINMUX_GPIO15__FUNC_B_GPIO15>;
+			output-high;
+		};
+	};
+
+	eth_default_pins: eth-default-pins {
+		pins-cc {
+			pinmux = <PINMUX_GPIO139__FUNC_B0_GBE_TXC>,
+				 <PINMUX_GPIO140__FUNC_I0_GBE_RXC>,
+				 <PINMUX_GPIO141__FUNC_I0_GBE_RXDV>,
+				 <PINMUX_GPIO142__FUNC_O_GBE_TXEN>;
+			drive-strength = <MTK_DRIVE_8mA>;
+		};
+
+		pins-mdio {
+			pinmux = <PINMUX_GPIO143__FUNC_O_GBE_MDC>,
+				 <PINMUX_GPIO144__FUNC_B1_GBE_MDIO>;
+			drive-strength = <MTK_DRIVE_8mA>;
+			input-enable;
+		};
+
+		pins-power {
+			pinmux = <PINMUX_GPIO145__FUNC_B_GPIO145>,
+				 <PINMUX_GPIO146__FUNC_B_GPIO146>;
+			output-high;
+		};
+
+		pins-rxd {
+			pinmux = <PINMUX_GPIO135__FUNC_I0_GBE_RXD3>,
+				 <PINMUX_GPIO136__FUNC_I0_GBE_RXD2>,
+				 <PINMUX_GPIO137__FUNC_I0_GBE_RXD1>,
+				 <PINMUX_GPIO138__FUNC_I0_GBE_RXD0>;
+			drive-strength = <MTK_DRIVE_8mA>;
+		};
+
+		pins-txd {
+			pinmux = <PINMUX_GPIO131__FUNC_O_GBE_TXD3>,
+				 <PINMUX_GPIO132__FUNC_O_GBE_TXD2>,
+				 <PINMUX_GPIO133__FUNC_O_GBE_TXD1>,
+				 <PINMUX_GPIO134__FUNC_O_GBE_TXD0>;
+			drive-strength = <MTK_DRIVE_8mA>;
+		};
+	};
+
+	eth_sleep_pins: eth-sleep-pins {
+		pins-cc {
+			pinmux = <PINMUX_GPIO139__FUNC_B_GPIO139>,
+				 <PINMUX_GPIO140__FUNC_B_GPIO140>,
+				 <PINMUX_GPIO141__FUNC_B_GPIO141>,
+				 <PINMUX_GPIO142__FUNC_B_GPIO142>;
+		};
+
+		pins-mdio {
+			pinmux = <PINMUX_GPIO143__FUNC_B_GPIO143>,
+				 <PINMUX_GPIO144__FUNC_B_GPIO144>;
+			input-disable;
+			bias-disable;
+		};
+
+		pins-rxd {
+			pinmux = <PINMUX_GPIO135__FUNC_B_GPIO135>,
+				 <PINMUX_GPIO136__FUNC_B_GPIO136>,
+				 <PINMUX_GPIO137__FUNC_B_GPIO137>,
+				 <PINMUX_GPIO138__FUNC_B_GPIO138>;
+		};
+
+		pins-txd {
+			pinmux = <PINMUX_GPIO131__FUNC_B_GPIO131>,
+				 <PINMUX_GPIO132__FUNC_B_GPIO132>,
+				 <PINMUX_GPIO133__FUNC_B_GPIO133>,
+				 <PINMUX_GPIO134__FUNC_B_GPIO134>;
+		};
+	};
+
+	i2c0_pins: i2c0-pins {
+		pins {
+			pinmux = <PINMUX_GPIO56__FUNC_B1_SDA0>,
+				 <PINMUX_GPIO55__FUNC_B1_SCL0>;
+			bias-pull-up = <MTK_PULL_SET_RSEL_011>;
+			drive-strength-microamp = <1000>;
+		};
+	};
+
+	i2c1_pins: i2c1-pins {
+		pins {
+			pinmux = <PINMUX_GPIO58__FUNC_B1_SDA1>,
+				 <PINMUX_GPIO57__FUNC_B1_SCL1>;
+			bias-pull-up = <MTK_PULL_SET_RSEL_011>;
+			drive-strength-microamp = <1000>;
+		};
+	};
+
+	i2c2_pins: i2c2-pins {
+		pins {
+			pinmux = <PINMUX_GPIO60__FUNC_B1_SDA2>,
+				 <PINMUX_GPIO59__FUNC_B1_SCL2>;
+			bias-pull-up = <MTK_PULL_SET_RSEL_011>;
+			drive-strength-microamp = <1000>;
+		};
+	};
+
+	i2c3_pins: i2c3-pins {
+		pins {
+			pinmux = <PINMUX_GPIO62__FUNC_B1_SDA3>,
+				 <PINMUX_GPIO61__FUNC_B1_SCL3>;
+			bias-pull-up = <MTK_PULL_SET_RSEL_011>;
+			drive-strength-microamp = <1000>;
+		};
+	};
+
+	i2c4_pins: i2c4-pins {
+		pins {
+			pinmux = <PINMUX_GPIO64__FUNC_B1_SDA4>,
+				 <PINMUX_GPIO63__FUNC_B1_SCL4>;
+			bias-pull-up = <MTK_PULL_SET_RSEL_011>;
+			drive-strength-microamp = <1000>;
+		};
+	};
+
+	i2c5_pins: i2c5-pins {
+		pins {
+			pinmux = <PINMUX_GPIO66__FUNC_B1_SDA5>,
+				 <PINMUX_GPIO65__FUNC_B1_SCL5>;
+			bias-pull-up = <MTK_PULL_SET_RSEL_011>;
+			drive-strength-microamp = <1000>;
+		};
+	};
+
+	i2c6_pins: i2c6-pins {
+		pins {
+			pinmux = <PINMUX_GPIO68__FUNC_B1_SDA6>,
+				 <PINMUX_GPIO67__FUNC_B1_SCL6>;
+			bias-pull-up = <MTK_PULL_SET_RSEL_011>;
+			drive-strength-microamp = <1000>;
+		};
+	};
+
+	gpio_key_pins: gpio-key-pins {
+		pins {
+			pinmux = <PINMUX_GPIO42__FUNC_B1_KPCOL0>,
+				 <PINMUX_GPIO43__FUNC_B1_KPCOL1>,
+				 <PINMUX_GPIO44__FUNC_B1_KPROW0>;
+		};
+	};
+
+	mmc0_default_pins: mmc0-default-pins {
+		pins-clk {
+			pinmux = <PINMUX_GPIO157__FUNC_B1_MSDC0_CLK>;
+			drive-strength = <MTK_DRIVE_6mA>;
+			bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
+		};
+
+		pins-cmd-dat {
+			pinmux = <PINMUX_GPIO161__FUNC_B1_MSDC0_DAT0>,
+				 <PINMUX_GPIO160__FUNC_B1_MSDC0_DAT1>,
+				 <PINMUX_GPIO159__FUNC_B1_MSDC0_DAT2>,
+				 <PINMUX_GPIO158__FUNC_B1_MSDC0_DAT3>,
+				 <PINMUX_GPIO154__FUNC_B1_MSDC0_DAT4>,
+				 <PINMUX_GPIO153__FUNC_B1_MSDC0_DAT5>,
+				 <PINMUX_GPIO152__FUNC_B1_MSDC0_DAT6>,
+				 <PINMUX_GPIO151__FUNC_B1_MSDC0_DAT7>,
+				 <PINMUX_GPIO156__FUNC_B1_MSDC0_CMD>;
+			input-enable;
+			drive-strength = <MTK_DRIVE_6mA>;
+			bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
+		};
+
+		pins-rst {
+			pinmux = <PINMUX_GPIO155__FUNC_O_MSDC0_RSTB>;
+			drive-strength = <MTK_DRIVE_6mA>;
+			bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
+		};
+	};
+
+	mmc0_uhs_pins: mmc0-uhs-pins {
+		pins-clk {
+			pinmux = <PINMUX_GPIO157__FUNC_B1_MSDC0_CLK>;
+			drive-strength = <MTK_DRIVE_8mA>;
+			bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
+		};
+
+		pins-cmd-dat {
+			pinmux = <PINMUX_GPIO161__FUNC_B1_MSDC0_DAT0>,
+				 <PINMUX_GPIO160__FUNC_B1_MSDC0_DAT1>,
+				 <PINMUX_GPIO159__FUNC_B1_MSDC0_DAT2>,
+				 <PINMUX_GPIO158__FUNC_B1_MSDC0_DAT3>,
+				 <PINMUX_GPIO154__FUNC_B1_MSDC0_DAT4>,
+				 <PINMUX_GPIO153__FUNC_B1_MSDC0_DAT5>,
+				 <PINMUX_GPIO152__FUNC_B1_MSDC0_DAT6>,
+				 <PINMUX_GPIO151__FUNC_B1_MSDC0_DAT7>,
+				 <PINMUX_GPIO156__FUNC_B1_MSDC0_CMD>;
+			input-enable;
+			drive-strength = <MTK_DRIVE_8mA>;
+			bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
+		};
+
+		pins-ds {
+			pinmux = <PINMUX_GPIO162__FUNC_B0_MSDC0_DSL>;
+			drive-strength = <MTK_DRIVE_8mA>;
+			bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
+		};
+
+		pins-rst {
+			pinmux = <PINMUX_GPIO155__FUNC_O_MSDC0_RSTB>;
+			drive-strength = <MTK_DRIVE_8mA>;
+			bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
+		};
+	};
+
+	mmc1_default_pins: mmc1-default-pins {
+		pins-clk {
+			pinmux = <PINMUX_GPIO164__FUNC_B1_MSDC1_CLK>;
+			drive-strength = <MTK_DRIVE_6mA>;
+			bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
+		};
+
+		pins-cmd-dat {
+			pinmux = <PINMUX_GPIO163__FUNC_B1_MSDC1_CMD>,
+				 <PINMUX_GPIO165__FUNC_B1_MSDC1_DAT0>,
+				 <PINMUX_GPIO166__FUNC_B1_MSDC1_DAT1>,
+				 <PINMUX_GPIO167__FUNC_B1_MSDC1_DAT2>,
+				 <PINMUX_GPIO168__FUNC_B1_MSDC1_DAT3>;
+			input-enable;
+			drive-strength = <MTK_DRIVE_6mA>;
+			bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
+		};
+
+		pins-insert {
+			pinmux = <PINMUX_GPIO2__FUNC_B_GPIO2>;
+			bias-pull-up;
+		};
+	};
+
+	mmc1_uhs_pins: mmc1-uhs-pins {
+		pins-clk {
+			pinmux = <PINMUX_GPIO164__FUNC_B1_MSDC1_CLK>;
+			drive-strength = <MTK_DRIVE_6mA>;
+			bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
+		};
+
+		pins-cmd-dat {
+			pinmux = <PINMUX_GPIO163__FUNC_B1_MSDC1_CMD>,
+				 <PINMUX_GPIO165__FUNC_B1_MSDC1_DAT0>,
+				 <PINMUX_GPIO166__FUNC_B1_MSDC1_DAT1>,
+				 <PINMUX_GPIO167__FUNC_B1_MSDC1_DAT2>,
+				 <PINMUX_GPIO168__FUNC_B1_MSDC1_DAT3>;
+			input-enable;
+			drive-strength = <MTK_DRIVE_6mA>;
+			bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
+		};
+	};
+
+	mmc2_default_pins: mmc2-default-pins {
+		pins-clk {
+			pinmux = <PINMUX_GPIO170__FUNC_B1_MSDC2_CLK>;
+			drive-strength = <MTK_DRIVE_4mA>;
+			bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
+		};
+
+		pins-cmd-dat {
+			pinmux = <PINMUX_GPIO169__FUNC_B1_MSDC2_CMD>,
+				 <PINMUX_GPIO171__FUNC_B1_MSDC2_DAT0>,
+				 <PINMUX_GPIO172__FUNC_B1_MSDC2_DAT1>,
+				 <PINMUX_GPIO173__FUNC_B1_MSDC2_DAT2>,
+				 <PINMUX_GPIO174__FUNC_B1_MSDC2_DAT3>;
+			input-enable;
+			drive-strength = <MTK_DRIVE_6mA>;
+			bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
+		};
+
+		pins-pcm {
+			pinmux = <PINMUX_GPIO123__FUNC_O_PCM_DO>;
+		};
+	};
+
+	mmc2_uhs_pins: mmc2-uhs-pins {
+		pins-clk {
+			pinmux = <PINMUX_GPIO170__FUNC_B1_MSDC2_CLK>;
+			drive-strength = <MTK_DRIVE_4mA>;
+			bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
+		};
+
+		pins-cmd-dat {
+			pinmux = <PINMUX_GPIO169__FUNC_B1_MSDC2_CMD>,
+				 <PINMUX_GPIO171__FUNC_B1_MSDC2_DAT0>,
+				 <PINMUX_GPIO172__FUNC_B1_MSDC2_DAT1>,
+				 <PINMUX_GPIO173__FUNC_B1_MSDC2_DAT2>,
+				 <PINMUX_GPIO174__FUNC_B1_MSDC2_DAT3>;
+			input-enable;
+			drive-strength = <MTK_DRIVE_6mA>;
+			bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
+		};
+	};
+
+	mmc2_eint_pins: mmc2-eint-pins {
+		pins-dat1 {
+			pinmux = <PINMUX_GPIO172__FUNC_B_GPIO172>;
+			input-enable;
+			bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
+		};
+	};
+
+	mmc2_dat1_pins: mmc2-dat1-pins {
+		pins-dat1 {
+			pinmux = <PINMUX_GPIO172__FUNC_B1_MSDC2_DAT1>;
+			input-enable;
+			drive-strength = <MTK_DRIVE_6mA>;
+			bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
+		};
+	};
+
+	panel_default_pins: panel-default-pins {
+		pins-dcdc {
+			pinmux = <PINMUX_GPIO45__FUNC_B_GPIO45>;
+			output-low;
+		};
+
+		pins-en {
+			pinmux = <PINMUX_GPIO111__FUNC_B_GPIO111>;
+			output-low;
+		};
+
+		pins-rst {
+			pinmux = <PINMUX_GPIO25__FUNC_B_GPIO25>;
+			output-high;
+		};
+	};
+
+	rt1715_int_pins: rt1715-int-pins {
+		pins_cmd0_dat {
+			pinmux = <PINMUX_GPIO12__FUNC_B_GPIO12>;
+			bias-pull-up;
+			input-enable;
+		};
+	};
+
+	spi0_pins: spi0-pins {
+		pins-spi {
+			pinmux = <PINMUX_GPIO69__FUNC_O_SPIM0_CSB>,
+				<PINMUX_GPIO70__FUNC_O_SPIM0_CLK>,
+				<PINMUX_GPIO71__FUNC_B0_SPIM0_MOSI>,
+				<PINMUX_GPIO72__FUNC_B0_SPIM0_MISO>;
+			bias-disable;
+		};
+	};
+
+	spi1_pins: spi1-pins {
+		pins-spi {
+			pinmux = <PINMUX_GPIO75__FUNC_O_SPIM1_CSB>,
+				<PINMUX_GPIO76__FUNC_O_SPIM1_CLK>,
+				<PINMUX_GPIO77__FUNC_B0_SPIM1_MOSI>,
+				<PINMUX_GPIO78__FUNC_B0_SPIM1_MISO>;
+			bias-disable;
+		};
+	};
+
+	spi2_pins: spi2-pins {
+		pins-spi {
+			pinmux = <PINMUX_GPIO79__FUNC_O_SPIM2_CSB>,
+				<PINMUX_GPIO80__FUNC_O_SPIM2_CLK>,
+				<PINMUX_GPIO81__FUNC_B0_SPIM2_MOSI>,
+				<PINMUX_GPIO82__FUNC_B0_SPIM2_MISO>;
+			bias-disable;
+		};
+	};
+
+	touch_pins: touch-pins {
+		pins-irq {
+			pinmux = <PINMUX_GPIO6__FUNC_B_GPIO6>;
+			input-enable;
+			bias-disable;
+		};
+
+		pins-reset {
+			pinmux = <PINMUX_GPIO5__FUNC_B_GPIO5>;
+			output-high;
+		};
+	};
+
+	uart0_pins: uart0-pins {
+		pins {
+			pinmux = <PINMUX_GPIO31__FUNC_O_UTXD0>,
+				 <PINMUX_GPIO32__FUNC_I1_URXD0>;
+			bias-pull-up;
+		};
+	};
+
+	uart1_pins: uart1-pins {
+		pins {
+			pinmux = <PINMUX_GPIO33__FUNC_O_UTXD1>,
+				 <PINMUX_GPIO34__FUNC_I1_URXD1>;
+			bias-pull-up;
+		};
+	};
+
+	uart2_pins: uart2-pins {
+		pins {
+			pinmux = <PINMUX_GPIO35__FUNC_O_UTXD2>,
+				 <PINMUX_GPIO36__FUNC_I1_URXD2>;
+			bias-pull-up;
+		};
+	};
+
+	usb_default_pins: usb-default-pins {
+		pins-iddig {
+			pinmux = <PINMUX_GPIO83__FUNC_B_GPIO83>;
+			input-enable;
+			bias-pull-up;
+		};
+
+		pins-valid {
+			pinmux = <PINMUX_GPIO85__FUNC_I0_VBUSVALID>;
+			input-enable;
+		};
+
+		pins-vbus {
+			pinmux = <PINMUX_GPIO84__FUNC_O_USB_DRVVBUS>;
+			output-high;
+		};
+
+	};
+
+	usb1_default_pins: usb1-default-pins {
+		pins-valid {
+			pinmux = <PINMUX_GPIO88__FUNC_I0_VBUSVALID_1P>;
+			input-enable;
+		};
+
+		pins-usb-hub-3v3-en {
+			pinmux = <PINMUX_GPIO112__FUNC_B_GPIO112>;
+			output-high;
+		};
+	};
+
+	wifi_pwrseq_pins: wifi-pwrseq-pins {
+		pins-wifi-enable {
+			pinmux = <PINMUX_GPIO127__FUNC_B_GPIO127>;
+			output-low;
+		};
+	};
+};
+
+&pmic {
+	interrupt-parent = <&pio>;
+	interrupts = <222 IRQ_TYPE_LEVEL_HIGH>;
+};
+
+&scp {
+	memory-region = <&scp_mem>;
+	status = "okay";
+};
+
+&uart0 {
+	pinctrl-0 = <&uart0_pins>;
+	pinctrl-names = "default";
+	status = "okay";
+};
+
+&uart1 {
+	pinctrl-0 = <&uart1_pins>;
+	pinctrl-names = "default";
+	status = "okay";
+};
+
+&uart2 {
+	pinctrl-0 = <&uart2_pins>;
+	pinctrl-names = "default";
+	status = "okay";
+};
+
+&spi2 {
+	pinctrl-0 = <&spi2_pins>;
+	pinctrl-names = "default";
+	mediatek,pad-select = <0>;
+	#address-cells = <1>;
+	#size-cells = <0>;
+	status = "okay";
+};
+
+&u3phy0 {
+	status = "okay";
+};
+
+&u3phy1 {
+	status = "okay";
+};
+
+&u3phy2 {
+	status = "okay";
+};
+
+&xhci0 {
+	status = "okay";
+	vusb33-supply = <&mt6359_vusb_ldo_reg>;
+};
+
+&xhci1 {
+	status = "okay";
+	vusb33-supply = <&mt6359_vusb_ldo_reg>;
+	vbus-supply = <&usb_hub_reset_1v8>;
+};
+
+&xhci2 {
+	status = "okay";
+	vusb33-supply = <&mt6359_vusb_ldo_reg>;
+};