[PATCH v3 RESEND 2/4] arm64: dts: mediatek: Add MT8186 Chinchou Chromebooks
Zhengqiao Xia
xiazhengqiao at huaqin.corp-partner.google.com
Thu Nov 14 21:56:21 PST 2024
Hi
No one has responded to this patch for two weeks. Please help to review it.
thanks
Zhengqiao Xia <xiazhengqiao at huaqin.corp-partner.google.com>
于2024年10月21日周一 15:27写道:
>
> MT8186 chinchou, known as ASUS Chromebook CZ12 Flip (CZ1204F)
> and CZ12(CZ1204C), is a MT8186 based laptop.
> It is based on the "corsola" design.It includes chinchou and chinchou360,
> including LTE, stylus, touchscreen combinations.
>
> Signed-off-by: Zhengqiao Xia <xiazhengqiao at huaqin.corp-partner.google.com>
> ---
> arch/arm64/boot/dts/mediatek/Makefile | 3 +
> .../mediatek/mt8186-corsola-chinchou-sku0.dts | 18 +
> .../mediatek/mt8186-corsola-chinchou-sku1.dts | 35 ++
> .../mt8186-corsola-chinchou-sku16.dts | 29 ++
> .../dts/mediatek/mt8186-corsola-chinchou.dtsi | 321 ++++++++++++++++++
> 5 files changed, 406 insertions(+)
> create mode 100644 arch/arm64/boot/dts/mediatek/mt8186-corsola-chinchou-sku0.dts
> create mode 100644 arch/arm64/boot/dts/mediatek/mt8186-corsola-chinchou-sku1.dts
> create mode 100644 arch/arm64/boot/dts/mediatek/mt8186-corsola-chinchou-sku16.dts
> create mode 100644 arch/arm64/boot/dts/mediatek/mt8186-corsola-chinchou.dtsi
>
> diff --git a/arch/arm64/boot/dts/mediatek/Makefile b/arch/arm64/boot/dts/mediatek/Makefile
> index 8fd7b2bb7a15..0db7770e8907 100644
> --- a/arch/arm64/boot/dts/mediatek/Makefile
> +++ b/arch/arm64/boot/dts/mediatek/Makefile
> @@ -55,6 +55,9 @@ dtb-$(CONFIG_ARCH_MEDIATEK) += mt8183-kukui-kodama-sku32.dtb
> dtb-$(CONFIG_ARCH_MEDIATEK) += mt8183-kukui-krane-sku0.dtb
> dtb-$(CONFIG_ARCH_MEDIATEK) += mt8183-kukui-krane-sku176.dtb
> dtb-$(CONFIG_ARCH_MEDIATEK) += mt8183-pumpkin.dtb
> +dtb-$(CONFIG_ARCH_MEDIATEK) += mt8186-corsola-chinchou-sku0.dtb
> +dtb-$(CONFIG_ARCH_MEDIATEK) += mt8186-corsola-chinchou-sku1.dtb
> +dtb-$(CONFIG_ARCH_MEDIATEK) += mt8186-corsola-chinchou-sku16.dtb
> dtb-$(CONFIG_ARCH_MEDIATEK) += mt8186-corsola-magneton-sku393216.dtb
> dtb-$(CONFIG_ARCH_MEDIATEK) += mt8186-corsola-magneton-sku393217.dtb
> dtb-$(CONFIG_ARCH_MEDIATEK) += mt8186-corsola-magneton-sku393218.dtb
> diff --git a/arch/arm64/boot/dts/mediatek/mt8186-corsola-chinchou-sku0.dts b/arch/arm64/boot/dts/mediatek/mt8186-corsola-chinchou-sku0.dts
> new file mode 100644
> index 000000000000..5d012bc4ff0d
> --- /dev/null
> +++ b/arch/arm64/boot/dts/mediatek/mt8186-corsola-chinchou-sku0.dts
> @@ -0,0 +1,18 @@
> +// SPDX-License-Identifier: (GPL-2.0 OR MIT)
> +/*
> + * Copyright 2024 Google LLC
> + */
> +
> +/dts-v1/;
> +#include "mt8186-corsola-chinchou.dtsi"
> +
> +/ {
> + model = "Google chinchou CZ1104CM2A/CZ1204CM2A";
> + compatible = "google,chinchou-sku0", "google,chinchou-sku2",
> + "google,chinchou-sku4", "google,chinchou-sku5",
> + "google,chinchou", "mediatek,mt8186";
> +};
> +
> +&gpio_keys {
> + status = "disabled";
> +};
> diff --git a/arch/arm64/boot/dts/mediatek/mt8186-corsola-chinchou-sku1.dts b/arch/arm64/boot/dts/mediatek/mt8186-corsola-chinchou-sku1.dts
> new file mode 100644
> index 000000000000..c18f473f6a0f
> --- /dev/null
> +++ b/arch/arm64/boot/dts/mediatek/mt8186-corsola-chinchou-sku1.dts
> @@ -0,0 +1,35 @@
> +// SPDX-License-Identifier: (GPL-2.0 OR MIT)
> +/*
> + * Copyright 2024 Google LLC
> + */
> +
> +/dts-v1/;
> +#include "mt8186-corsola-chinchou.dtsi"
> +
> +/ {
> + model = "Google chinchou CZ1104FM2A/CZ1204FM2A/CZ1104CM2A/CZ1204CM2A";
> + compatible = "google,chinchou-sku1", "google,chinchou-sku17",
> + "google,chinchou-sku3", "google,chinchou-sku6",
> + "google,chinchou-sku7", "google,chinchou-sku20",
> + "google,chinchou-sku22", "google,chinchou-sku23",
> + "google,chinchou", "mediatek,mt8186";
> +};
> +
> +&gpio_keys {
> + status = "disabled";
> +};
> +
> +&i2c1 {
> + i2c-scl-internal-delay-ns = <10000>;
> +
> + touchscreen: touchscreen at 41 {
> + compatible = "ilitek,ili2901";
> + reg = <0x41>;
> + interrupts-extended = <&pio 12 IRQ_TYPE_LEVEL_LOW>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&touchscreen_pins>;
> + reset-gpios = <&pio 60 GPIO_ACTIVE_LOW>;
> + vccio-supply = <&pp1800_tchscr_report_disable>;
> + vcc33-supply = <&pp3300_z2>;
> + };
> +};
> diff --git a/arch/arm64/boot/dts/mediatek/mt8186-corsola-chinchou-sku16.dts b/arch/arm64/boot/dts/mediatek/mt8186-corsola-chinchou-sku16.dts
> new file mode 100644
> index 000000000000..eb377de1fcde
> --- /dev/null
> +++ b/arch/arm64/boot/dts/mediatek/mt8186-corsola-chinchou-sku16.dts
> @@ -0,0 +1,29 @@
> +// SPDX-License-Identifier: (GPL-2.0 OR MIT)
> +/*
> + * Copyright 2024 Google LLC
> + */
> +
> +/dts-v1/;
> +#include "mt8186-corsola-chinchou.dtsi"
> +
> +/ {
> + model = "Google chinchou CZ1104FM2A/CZ1204FM2A";
> + compatible = "google,chinchou-sku16", "google,chinchou-sku18",
> + "google,chinchou-sku19", "google,chinchou-sku21",
> + "google,chinchou", "mediatek,mt8186";
> +};
> +
> +&i2c1 {
> + i2c-scl-internal-delay-ns = <10000>;
> +
> + touchscreen: touchscreen at 41 {
> + compatible = "ilitek,ili2901";
> + reg = <0x41>;
> + interrupts-extended = <&pio 12 IRQ_TYPE_LEVEL_LOW>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&touchscreen_pins>;
> + reset-gpios = <&pio 60 GPIO_ACTIVE_LOW>;
> + vccio-supply = <&pp1800_tchscr_report_disable>;
> + vcc33-supply = <&pp3300_z2>;
> + };
> +};
> diff --git a/arch/arm64/boot/dts/mediatek/mt8186-corsola-chinchou.dtsi b/arch/arm64/boot/dts/mediatek/mt8186-corsola-chinchou.dtsi
> new file mode 100644
> index 000000000000..389f8b66e968
> --- /dev/null
> +++ b/arch/arm64/boot/dts/mediatek/mt8186-corsola-chinchou.dtsi
> @@ -0,0 +1,321 @@
> +// SPDX-License-Identifier: (GPL-2.0 OR MIT)
> +/*
> + * Copyright 2024 Google LLC
> + */
> +
> +/dts-v1/;
> +#include "mt8186-corsola.dtsi"
> +
> +/ {
> + /delete-node/ speaker-codec;
> +
> + pp1000_edpbrdg: regulator-pp1000-edpbrdg {
> + compatible = "regulator-fixed";
> + regulator-name = "pp1000_edpbrdg";
> + pinctrl-names = "default";
> + pinctrl-0 = <&en_pp1000_edpbrdg>;
> + enable-active-high;
> + regulator-boot-on;
> + gpio = <&pio 29 GPIO_ACTIVE_HIGH>;
> + vin-supply = <&pp3300_z2>;
> + };
> +
> + pp1800_edpbrdg_dx: regulator-pp1800-edpbrdg-dx {
> + compatible = "regulator-fixed";
> + regulator-name = "pp1800_edpbrdg_dx";
> + pinctrl-names = "default";
> + pinctrl-0 = <&en_pp1800_edpbrdg>;
> + enable-active-high;
> + regulator-boot-on;
> + gpio = <&pio 30 GPIO_ACTIVE_HIGH>;
> + vin-supply = <&mt6366_vio18_reg>;
> + };
> +
> + pp3300_edp_dx: regulator-pp3300-edp-dx {
> + compatible = "regulator-fixed";
> + regulator-name = "pp3300_edp_dx";
> + pinctrl-names = "default";
> + pinctrl-0 = <&en_pp3300_edpbrdg>;
> + enable-active-high;
> + regulator-boot-on;
> + gpio = <&pio 31 GPIO_ACTIVE_HIGH>;
> + vin-supply = <&pp3300_z2>;
> + };
> +
> + pp1800_tchscr_report_disable: regulator-pp1800-tchscr-report-disable {
> + compatible = "regulator-fixed";
> + regulator-name = "pp1800_tchscr_report_disable";
> + pinctrl-names = "default";
> + regulator-boot-on;
> + pinctrl-0 = <&touch_pin_report>;
> + gpio = <&pio 37 GPIO_ACTIVE_LOW>;
> + };
> +};
> +
> +&dsi_out {
> + remote-endpoint = <&anx7625_in>;
> +};
> +
> +&i2c0 {
> + clock-frequency = <400000>;
> +
> + anx_bridge: anx7625 at 58 {
> + compatible = "analogix,anx7625";
> + reg = <0x58>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&anx7625_pins>;
> + enable-gpios = <&pio 96 GPIO_ACTIVE_HIGH>;
> + reset-gpios = <&pio 98 GPIO_ACTIVE_HIGH>;
> + vdd10-supply = <&pp1000_edpbrdg>;
> + vdd18-supply = <&pp1800_edpbrdg_dx>;
> + vdd33-supply = <&pp3300_edp_dx>;
> + analogix,lane0-swing = /bits/ 8 <0x70 0x30>;
> + analogix,lane1-swing = /bits/ 8 <0x70 0x30>;
> +
> + ports {
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + port at 0 {
> + reg = <0>;
> +
> + anx7625_in: endpoint {
> + remote-endpoint = <&dsi_out>;
> + data-lanes = <0 1 2 3>;
> + };
> + };
> +
> + port at 1 {
> + reg = <1>;
> +
> + anx7625_out: endpoint {
> + remote-endpoint = <&panel_in>;
> + };
> + };
> + };
> +
> + aux-bus {
> + panel: panel {
> + compatible = "edp-panel";
> + power-supply = <&pp3300_disp_x>;
> + backlight = <&backlight_lcd0>;
> +
> + port {
> + panel_in: endpoint {
> + remote-endpoint = <&anx7625_out>;
> + };
> + };
> + };
> + };
> + };
> +};
> +
> +&i2c2 {
> + /delete-node/ trackpad at 15;
> +
> + touchpad at 15 {
> + compatible = "hid-over-i2c";
> + reg = <0x15>;
> + interrupts-extended = <&pio 11 IRQ_TYPE_LEVEL_LOW>;
> + post-power-on-delay-ms = <10>;
> + hid-descr-addr = <0x0001>;
> + vdd-supply = <&pp3300_s3>;
> + wakeup-source;
> + };
> +};
> +
> +&i2c5 {
> + clock-frequency = <400000>;
> + /delete-node/ codec at 1a;
> +
> + rt5650: rt5650 at 1a {
> + compatible = "realtek,rt5650";
> + reg = <0x1a>;
> + avdd-supply = <&mt6366_vio18_reg>;
> + cpvdd-supply = <&mt6366_vio18_reg>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&rt1019p_pins_default>;
> + cbj-sleeve-gpios = <&pio 150 GPIO_ACTIVE_HIGH>;
> + interrupt-parent = <&pio>;
> + interrupts = <17 IRQ_TYPE_EDGE_BOTH>;
> + #sound-dai-cells = <0>;
> + realtek,dmic1-data-pin = <2>;
> + realtek,jd-mode = <2>;
> + };
> +};
> +
> +&i2c_tunnel {
> + /delete-node/ sbs-battery at b;
> +
> + battery: sbs-battery at f {
> + compatible = "sbs,sbs-battery";
> + reg = <0xf>;
> + sbs,i2c-retry-count = <2>;
> + sbs,poll-retry-count = <1>;
> + };
> +};
> +
> +&keyboard_controller {
> + keypad,num-columns = <15>;
> +
> + function-row-physmap = <
> + MATRIX_KEY(0x00, 0x02, 0) /* T1 */
> + MATRIX_KEY(0x03, 0x02, 0) /* T2 */
> + MATRIX_KEY(0x02, 0x02, 0) /* T3 */
> + MATRIX_KEY(0x01, 0x02, 0) /* T4 */
> + MATRIX_KEY(0x03, 0x04, 0) /* T5 */
> + MATRIX_KEY(0x02, 0x04, 0) /* T6 */
> + MATRIX_KEY(0x01, 0x04, 0) /* T7 */
> + MATRIX_KEY(0x02, 0x09, 0) /* T8 */
> + MATRIX_KEY(0x01, 0x09, 0) /* T9 */
> + MATRIX_KEY(0x00, 0x04, 0) /* T10 */
> + MATRIX_KEY(0x00, 0x01, 0) /* T11 */
> + MATRIX_KEY(0x01, 0x05, 0) /* T12 */
> + >;
> +
> + linux,keymap = <
> + CROS_STD_MAIN_KEYMAP
> + MATRIX_KEY(0x00, 0x02, KEY_BACK) /* T1 */
> + MATRIX_KEY(0x03, 0x02, KEY_REFRESH) /* T2 */
> + MATRIX_KEY(0x02, 0x02, KEY_ZOOM) /* T3 */
> + MATRIX_KEY(0x01, 0x02, KEY_SCALE) /* T4 */
> + MATRIX_KEY(0x03, 0x04, KEY_SYSRQ) /* T5 */
> + MATRIX_KEY(0x02, 0x04, KEY_BRIGHTNESSDOWN) /* T6 */
> + MATRIX_KEY(0x01, 0x04, KEY_BRIGHTNESSUP) /* T7 */
> + MATRIX_KEY(0x02, 0x09, KEY_MUTE) /* T8 */
> + MATRIX_KEY(0x01, 0x09, KEY_VOLUMEDOWN) /* T9 */
> + MATRIX_KEY(0x00, 0x04, KEY_VOLUMEUP) /* T10 */
> + MATRIX_KEY(0x00, 0x01, KEY_MICMUTE) /* T11 */
> + MATRIX_KEY(0x01, 0x05, KEY_CONTROLPANEL) /* T12 */
> + MATRIX_KEY(0x03, 0x05, KEY_PREVIOUSSONG) /* T13 */
> + MATRIX_KEY(0x00, 0x09, KEY_PLAYPAUSE) /* T14 */
> + MATRIX_KEY(0x00, 0x0b, KEY_NEXTSONG) /* T15 */
> + MATRIX_KEY(0x03, 0x00, KEY_LEFTMETA) /* Search*/
> + MATRIX_KEY(0x01, 0x0e, KEY_LEFTCTRL) /* Left Control*/
> + MATRIX_KEY(0x06, 0x0d, KEY_LEFTALT) /* Left ALT*/
> + MATRIX_KEY(0x03, 0x0e, KEY_RIGHTCTRL) /* Right Control*/
> + MATRIX_KEY(0x06, 0x0a, KEY_BACKSLASH) /* BACKSLASH*/
> + >;
> +};
> +
> +&mmc1_pins_default {
> + pins-clk {
> + drive-strength = <MTK_DRIVE_8mA>;
> + };
> +
> + pins-cmd-dat {
> + drive-strength = <MTK_DRIVE_8mA>;
> + };
> +};
> +
> +&mmc1_pins_uhs {
> + pins-clk {
> + drive-strength = <MTK_DRIVE_8mA>;
> + };
> +
> + pins-cmd-dat {
> + drive-strength = <MTK_DRIVE_8mA>;
> + };
> +};
> +
> +&pen_insert {
> + wakeup-event-action = <EV_ACT_ANY>;
> +};
> +
> +&pio {
> + anx7625_pins: anx7625-pins {
> + pins-int {
> + pinmux = <PINMUX_GPIO9__FUNC_GPIO9>;
> + input-enable;
> + bias-disable;
> + };
> +
> + pins-reset {
> + pinmux = <PINMUX_GPIO98__FUNC_GPIO98>;
> + output-low;
> + };
> +
> + pins-power-en {
> + pinmux = <PINMUX_GPIO96__FUNC_GPIO96>;
> + output-low;
> + };
> + };
> +
> + en_pp1000_edpbrdg: pp1000-edpbrdg-en-pins {
> + pins-vreg-en {
> + pinmux = <PINMUX_GPIO29__FUNC_GPIO29>;
> + output-low;
> + };
> + };
> +
> + en_pp1800_edpbrdg: pp1800-edpbrdg-en-pins {
> + pins-vreg-en {
> + pinmux = <PINMUX_GPIO30__FUNC_GPIO30>;
> + output-low;
> + };
> + };
> +
> + en_pp3300_edpbrdg: pp3300-edpbrdg-en-pins {
> + pins-vreg-en {
> + pinmux = <PINMUX_GPIO31__FUNC_GPIO31>;
> + output-low;
> + };
> + };
> +
> + touch_pin_report: pin-report-pins {
> + pins-touch-en {
> + pinmux = <PINMUX_GPIO37__FUNC_GPIO37>;
> + output-low;
> + };
> + };
> +};
> +
> +&sound {
> + compatible = "mediatek,mt8186-mt6366-rt5650-sound";
> + model = "mt8186_rt5650";
> + mediatek,adsp = <&adsp>;
> +
> + audio-routing =
> + "Headphone", "HPOL",
> + "Headphone", "HPOR",
> + "IN1P", "Headset Mic",
> + "IN1N", "Headset Mic",
> + "Speakers", "SPOL",
> + "Speakers", "SPOR",
> + "HDMI1", "TX";
> +
> + hs-playback-dai-link {
> + codec {
> + sound-dai = <&rt5650>;
> + };
> + };
> +
> + hs-capture-dai-link {
> + codec {
> + sound-dai = <&rt5650>;
> + };
> + };
> +
> + spk-share-dai-link {
> + };
> +
> + spk-hdmi-playback-dai-link {
> + codec {
> + sound-dai = <&it6505dptx>;
> + };
> + };
> +};
> +
> +&touchscreen_pins {
> + /delete-node/ pins-report-sw;
> +};
> +
> +&wifi_enable_pin {
> + pins-wifi-enable {
> + pinmux = <PINMUX_GPIO51__FUNC_GPIO51>;
> + };
> +};
> +
> +&wifi_pwrseq {
> + reset-gpios = <&pio 51 GPIO_ACTIVE_LOW>;
> +};
> --
> 2.17.1
>
More information about the Linux-mediatek
mailing list