]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
arm64: dts: mediatek: mt8188: Add MTU3 nodes and correctly describe USB
authorAngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
Thu, 20 Feb 2025 10:55:13 +0000 (11:55 +0100)
committerAngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
Tue, 25 Feb 2025 09:00:33 +0000 (10:00 +0100)
The MT8188 SoC has three USB controllers, and all of them are behind
the MTU3 DRD controller.

Add the missing MTU3 nodes, default disabled, for all USB controllers
and move the related XHCI nodes to be children of their MTU3 DRD to
correctly describe the SoC.

In order to retain USB functionality on all of the MT8188 and MT8390
boards, also move the vusb33 supply and enable the relevant MTU3 nodes
with special attention to the MT8188 Geralt Chromebooks, where it was
necessary to set the dr_mode of all MTU3 controllers to host to avoid
interfering with the EC performing DRD on its own.

Tested-by: Chen-Yu Tsai <wenst@chromium.org> # on MT8188 Ciri
Link: https://lore.kernel.org/r/20250220105514.43107-3-angelogioacchino.delregno@collabora.com
Signed-off-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
arch/arm64/boot/dts/mediatek/mt8188-geralt.dtsi
arch/arm64/boot/dts/mediatek/mt8188.dtsi
arch/arm64/boot/dts/mediatek/mt8390-genio-common.dtsi

index b6abecbcfa81064074780fe134ef6fadf2e50dd0..faed5c8bc721343d12ccf5c110ec4253d8608647 100644 (file)
 };
 
 /* USB detachable base */
+&ssusb0 {
+       dr_mode = "host";
+       vusb33-supply = <&pp3300_s3>;
+       status = "okay";
+};
+
 &xhci0 {
        /* controlled by EC */
        vbus-supply = <&pp3300_z1>;
 };
 
 /* USB3 hub */
+&ssusb1 {
+       dr_mode = "host";
+       vusb33-supply = <&pp3300_s3>;
+       status = "okay";
+};
+
 &xhci1 {
        vusb33-supply = <&pp3300_s3>;
        vbus-supply = <&pp5000_usb_vbus>;
 };
 
 /* USB BT */
+&ssusb2 {
+       dr_mode = "host";
+       vusb33-supply = <&pp3300_s3>;
+       status = "okay";
+};
+
 &xhci2 {
        /* no power supply since MT7921's power is controlled by PCIe */
        /* MT7921's USB BT has issues with USB2 LPM */
index 9e6a77a63ef9e742f2cdf55278d2867794f83661..b117c51dd67329c0f350a44ea9f499b937cbacf0 100644 (file)
                        status = "disabled";
                };
 
+               ssusb1: usb@11201000 {
+                       compatible = "mediatek,mt8188-mtu3", "mediatek,mtu3";
+                       reg = <0 0x11201000 0 0x2dff>, <0 0x11203e00 0 0x0100>;
+                       reg-names = "mac", "ippc";
+                       ranges = <0 0 0 0x11200000 0 0x3f00>;
+                       #address-cells = <2>;
+                       #size-cells = <2>;
+                       interrupts = <GIC_SPI 128 IRQ_TYPE_LEVEL_HIGH 0>;
+                       assigned-clocks = <&topckgen CLK_TOP_USB_TOP>;
+                       assigned-clock-parents = <&topckgen CLK_TOP_UNIVPLL_D5_D4>;
+                       clocks = <&pericfg_ao CLK_PERI_AO_SSUSB_BUS>,
+                                <&topckgen CLK_TOP_SSUSB_TOP_REF>,
+                                <&pericfg_ao CLK_PERI_AO_SSUSB_XHCI>;
+                       clock-names = "sys_ck", "ref_ck", "mcu_ck";
+                       phys = <&u2port1 PHY_TYPE_USB2>, <&u3port1 PHY_TYPE_USB3>;
+                       wakeup-source;
+                       mediatek,syscon-wakeup = <&pericfg 0x468 2>;
+                       status = "disabled";
+
+                       xhci1: usb@0 {
+                               compatible = "mediatek,mt8188-xhci", "mediatek,mtk-xhci";
+                               reg = <0 0 0 0x1000>;
+                               reg-names = "mac";
+                               interrupts = <GIC_SPI 129 IRQ_TYPE_LEVEL_HIGH 0>;
+                               assigned-clocks = <&topckgen CLK_TOP_SSUSB_XHCI>;
+                               assigned-clock-parents = <&topckgen CLK_TOP_UNIVPLL_D5_D4>;
+                               clocks = <&pericfg_ao CLK_PERI_AO_SSUSB_XHCI>;
+                               clock-names = "sys_ck";
+                               status = "disabled";
+                       };
+               };
+
                eth: ethernet@11021000 {
                        compatible = "mediatek,mt8188-gmac", "mediatek,mt8195-gmac",
                                     "snps,dwmac-5.10a";
                        };
                };
 
-               xhci1: usb@11200000 {
-                       compatible = "mediatek,mt8188-xhci", "mediatek,mtk-xhci";
-                       reg = <0 0x11200000 0 0x1000>,
-                             <0 0x11203e00 0 0x0100>;
-                       reg-names = "mac", "ippc";
-                       interrupts = <GIC_SPI 129 IRQ_TYPE_LEVEL_HIGH 0>;
-                       phys = <&u2port1 PHY_TYPE_USB2>,
-                              <&u3port1 PHY_TYPE_USB3>;
-                       assigned-clocks = <&topckgen CLK_TOP_USB_TOP>,
-                                         <&topckgen CLK_TOP_SSUSB_XHCI>;
-                       assigned-clock-parents = <&topckgen CLK_TOP_UNIVPLL_D5_D4>,
-                                                <&topckgen CLK_TOP_UNIVPLL_D5_D4>;
-                       clocks = <&pericfg_ao CLK_PERI_AO_SSUSB_BUS>,
-                                <&topckgen CLK_TOP_SSUSB_TOP_REF>,
-                                <&pericfg_ao CLK_PERI_AO_SSUSB_XHCI>;
-                       clock-names = "sys_ck", "ref_ck", "mcu_ck";
-                       mediatek,syscon-wakeup = <&pericfg 0x468 2>;
-                       wakeup-source;
-                       status = "disabled";
-               };
-
                mmc0: mmc@11230000 {
                        compatible = "mediatek,mt8188-mmc", "mediatek,mt8183-mmc";
                        reg = <0 0x11230000 0 0x10000>,
                        #clock-cells = <1>;
                };
 
-               xhci2: usb@112a0000 {
-                       compatible = "mediatek,mt8188-xhci", "mediatek,mtk-xhci";
-                       reg = <0 0x112a0000 0 0x1000>,
-                             <0 0x112a3e00 0 0x0100>;
+               ssusb2: usb@112a1000 {
+                       compatible = "mediatek,mt8188-mtu3", "mediatek,mtu3";
+                       reg = <0 0x112a1000 0 0x2dff>, <0 0x112a3e00 0 0x0100>;
                        reg-names = "mac", "ippc";
-                       interrupts = <GIC_SPI 536 IRQ_TYPE_LEVEL_HIGH 0>;
-                       phys = <&u2port2 PHY_TYPE_USB2>;
-                       assigned-clocks = <&topckgen CLK_TOP_SSUSB_XHCI_3P>,
-                                         <&topckgen CLK_TOP_USB_TOP_3P>;
-                       assigned-clock-parents = <&topckgen CLK_TOP_UNIVPLL_D5_D4>,
-                                                <&topckgen CLK_TOP_UNIVPLL_D5_D4>;
+                       ranges = <0 0 0 0x112a0000 0 0x3f00>;
+                       #address-cells = <2>;
+                       #size-cells = <2>;
+                       interrupts = <GIC_SPI 535 IRQ_TYPE_LEVEL_HIGH 0>;
+                       assigned-clocks = <&topckgen CLK_TOP_USB_TOP_3P>;
+                       assigned-clock-parents = <&topckgen CLK_TOP_UNIVPLL_D5_D4>;
                        clocks = <&pericfg_ao CLK_PERI_AO_SSUSB_3P_BUS>,
                                 <&topckgen CLK_TOP_SSUSB_TOP_P3_REF>,
                                 <&pericfg_ao CLK_PERI_AO_SSUSB_3P_XHCI>;
                        clock-names = "sys_ck", "ref_ck", "mcu_ck";
+                       phys = <&u2port2 PHY_TYPE_USB2>;
+                       wakeup-source;
+                       mediatek,syscon-wakeup = <&pericfg 0x470 2>;
                        status = "disabled";
+
+                       xhci2: usb@0 {
+                               compatible = "mediatek,mt8188-xhci", "mediatek,mtk-xhci";
+                               reg = <0 0 0 0x1000>;
+                               reg-names = "mac";
+                               interrupts = <GIC_SPI 536 IRQ_TYPE_LEVEL_HIGH 0>;
+                               assigned-clocks = <&topckgen CLK_TOP_SSUSB_XHCI_3P>;
+                               assigned-clock-parents = <&topckgen CLK_TOP_UNIVPLL_D5_D4>;
+                               clocks = <&pericfg_ao CLK_PERI_AO_SSUSB_3P_XHCI>;
+                               clock-names = "sys_ck";
+                               status = "disabled";
+                       };
                };
 
-               xhci0: usb@112b0000 {
-                       compatible = "mediatek,mt8188-xhci", "mediatek,mtk-xhci";
-                       reg = <0 0x112b0000 0 0x1000>,
-                             <0 0x112b3e00 0 0x0100>;
+               ssusb0: usb@112b1000 {
+                       compatible = "mediatek,mt8188-mtu3", "mediatek,mtu3";
+                       reg = <0 0x112b1000 0 0x2dff>, <0 0x112b3e00 0 0x0100>;
                        reg-names = "mac", "ippc";
-                       interrupts = <GIC_SPI 533 IRQ_TYPE_LEVEL_HIGH 0>;
-                       phys = <&u2port0 PHY_TYPE_USB2>;
-                       assigned-clocks = <&topckgen CLK_TOP_SSUSB_XHCI_2P>,
-                                         <&topckgen CLK_TOP_USB_TOP_2P>;
-                       assigned-clock-parents = <&topckgen CLK_TOP_UNIVPLL_D5_D4>,
-                                                <&topckgen CLK_TOP_UNIVPLL_D5_D4>;
+                       ranges = <0 0 0 0x112b0000 0 0x3f00>;
+                       #address-cells = <2>;
+                       #size-cells = <2>;
+                       interrupts = <GIC_SPI 532 IRQ_TYPE_LEVEL_HIGH 0>;
+                       assigned-clocks = <&topckgen CLK_TOP_SSUSB_XHCI_2P>;
+                       assigned-clock-parents = <&topckgen CLK_TOP_UNIVPLL_D5_D4>;
                        clocks = <&pericfg_ao CLK_PERI_AO_SSUSB_2P_BUS>,
                                 <&topckgen CLK_TOP_SSUSB_TOP_P2_REF>,
                                 <&pericfg_ao CLK_PERI_AO_SSUSB_2P_XHCI>;
                        clock-names = "sys_ck", "ref_ck", "mcu_ck";
-                       mediatek,syscon-wakeup = <&pericfg 0x460 2>;
+                       phys = <&u2port0 PHY_TYPE_USB2>;
                        wakeup-source;
+                       mediatek,syscon-wakeup = <&pericfg 0x460 2>;
                        status = "disabled";
+
+                       xhci0: usb@0 {
+                               compatible = "mediatek,mt8188-xhci", "mediatek,mtk-xhci";
+                               reg = <0 0 0 0x1000>;
+                               reg-names = "mac";
+                               interrupts = <GIC_SPI 533 IRQ_TYPE_LEVEL_HIGH 0>;
+                               assigned-clocks = <&topckgen CLK_TOP_USB_TOP_2P>;
+                               assigned-clock-parents = <&topckgen CLK_TOP_UNIVPLL_D5_D4>;
+                               clocks = <&pericfg_ao CLK_PERI_AO_SSUSB_2P_XHCI>;
+                               clock-names = "sys_ck";
+                               status = "disabled";
+                       };
                };
 
                pcie: pcie@112f0000 {
index e828864433a6f4195944ff67bb7bb4808d1fd262..0b22a1e2462569514da2b4300308a2800127895a 100644 (file)
        status = "okay";
 };
 
+&ssusb0 {
+       dr_mode = "host";
+       vusb33-supply = <&mt6359_vusb_ldo_reg>;
+       status = "okay";
+};
+
 &xhci0 {
        status = "okay";
+};
+
+&ssusb1 {
+       dr_mode = "host";
        vusb33-supply = <&mt6359_vusb_ldo_reg>;
+       status = "okay";
 };
 
 &xhci1 {
        status = "okay";
+       vdd-supply = <&usb_hub_fixed_3v3>;
        vusb33-supply = <&mt6359_vusb_ldo_reg>;
        #address-cells = <1>;
        #size-cells = <0>;
                reset-gpios = <&pio 7 GPIO_ACTIVE_HIGH>;
                vdd-supply = <&usb_hub_fixed_3v3>;
        };
+
+       port {
+               xhci_ss_ep: endpoint {
+                       remote-endpoint = <&typec_con_ss>;
+               };
+       };
+};
+
+&ssusb2 {
+       interrupts-extended = <&gic GIC_SPI 536 IRQ_TYPE_LEVEL_HIGH 0>,
+                             <&pio 220 IRQ_TYPE_LEVEL_HIGH>;
+       interrupt-names = "host", "wakeup";
+
+       dr_mode = "host";
+       vusb33-supply = <&mt6359_vusb_ldo_reg>;
+       status = "okay";
 };
 
 &xhci2 {