Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/netbsd-9]: src/sys/dev/fdt Pull up following revision(s) (requested by j...



details:   https://anonhg.NetBSD.org/src/rev/ccb8f5444053
branches:  netbsd-9
changeset: 963413:ccb8f5444053
user:      martin <martin%NetBSD.org@localhost>
date:      Thu Dec 12 11:40:53 2019 +0000

description:
Pull up following revision(s) (requested by jmcneill in ticket #545):

        sys/arch/arm/dts/rk3328.dtsi: revision 1.2
        sys/dev/fdt/dwc3_fdt.c: revision 1.8
        sys/arch/arm/dts/rk3328-rock64.dts: revision 1.5

Add support for snps,dis-tx-ipgap-linecheck-quirk quirk

Enable USB3 support on RK3328

diffstat:

 sys/arch/arm/dts/rk3328-rock64.dts |   6 +-----
 sys/arch/arm/dts/rk3328.dtsi       |  10 +++++++++-
 sys/dev/fdt/dwc3_fdt.c             |  18 ++++++++++++++----
 3 files changed, 24 insertions(+), 10 deletions(-)

diffs (102 lines):

diff -r aa953c950083 -r ccb8f5444053 sys/arch/arm/dts/rk3328-rock64.dts
--- a/sys/arch/arm/dts/rk3328-rock64.dts        Wed Dec 11 14:58:03 2019 +0000
+++ b/sys/arch/arm/dts/rk3328-rock64.dts        Thu Dec 12 11:40:53 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: rk3328-rock64.dts,v 1.4 2019/05/23 20:50:29 jmcneill Exp $ */
+/* $NetBSD: rk3328-rock64.dts,v 1.4.2.1 2019/12/12 11:40:53 martin Exp $ */
 
 /*-
  * Copyright (c) 2018 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -31,8 +31,4 @@
 
 &usbdrd3 {
        status = "okay";
-       snps,phyif-utmi-bits = <16>;
-       snps,dis-enblslpm-quirk;
-       snps,dis-u2-freeclk-exists-quirk;
-       snps,dis_u2_susphy_quirk;
 };
diff -r aa953c950083 -r ccb8f5444053 sys/arch/arm/dts/rk3328.dtsi
--- a/sys/arch/arm/dts/rk3328.dtsi      Wed Dec 11 14:58:03 2019 +0000
+++ b/sys/arch/arm/dts/rk3328.dtsi      Thu Dec 12 11:40:53 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: rk3328.dtsi,v 1.1 2018/06/21 10:46:39 jmcneill Exp $ */
+/* $NetBSD: rk3328.dtsi,v 1.1.8.1 2019/12/12 11:40:53 martin Exp $ */
 
 /*-
  * Copyright (c) 2018 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -40,6 +40,14 @@
                        reg = <0x0 0xff600000 0x0 0x100000>;
                        interrupts = <GIC_SPI 67 IRQ_TYPE_LEVEL_HIGH>;
                        dr_mode = "host";
+
+                       phy_type = "utmi_wide";
+                       snps,dis_enblslpm_quirk;
+                       snps,dis-u2-freeclk-exists-quirk;
+                       snps,dis_u2_susphy_quirk;
+                       snps,dis_u3_susphy_quirk;
+                       snps,dis-del-phy-power-chg-quirk;
+                       snps,dis-tx-ipgap-linecheck-quirk;
                };
        };
 };
diff -r aa953c950083 -r ccb8f5444053 sys/dev/fdt/dwc3_fdt.c
--- a/sys/dev/fdt/dwc3_fdt.c    Wed Dec 11 14:58:03 2019 +0000
+++ b/sys/dev/fdt/dwc3_fdt.c    Thu Dec 12 11:40:53 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: dwc3_fdt.c,v 1.7 2019/04/19 19:05:56 jmcneill Exp $ */
+/* $NetBSD: dwc3_fdt.c,v 1.7.4.1 2019/12/12 11:40:53 martin Exp $ */
 
 /*-
  * Copyright (c) 2018 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: dwc3_fdt.c,v 1.7 2019/04/19 19:05:56 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: dwc3_fdt.c,v 1.7.4.1 2019/12/12 11:40:53 martin Exp $");
 
 #include <sys/param.h>
 #include <sys/bus.h>
@@ -52,6 +52,9 @@
 #define          GCTL_PRTCAP_OTG               3
 #define         GCTL_CORESOFTRESET             __BIT(11)
 
+#define        DWC3_GUCTL1                     0xc11c
+#define         GUCTL1_TX_IPGAP_LINECHECK_DIS  __BIT(28)
+
 #define        DWC3_SNPSID                     0xc120
 #define         DWC3_SNPSID_REV                __BITS(15,0)
 
@@ -120,7 +123,7 @@
 }
 
 static void
-dwc3_fdt_enable_phy(struct xhci_softc *sc, const int phandle)
+dwc3_fdt_enable_phy(struct xhci_softc *sc, const int phandle, u_int rev)
 {
        const char *max_speed, *phy_type;
        u_int phyif_utmi_bits;
@@ -162,6 +165,13 @@
                val &= ~GUSB3PIPECTL_DEPOCHANGE;
        WR4(sc, DWC3_GUSB3PIPECTL(0), val);
 
+       if (rev >= 0x250a) {
+               val = RD4(sc, DWC3_GUCTL1);
+               if (of_hasprop(phandle, "snps,dis-tx-ipgap-linecheck-quirk"))
+                       val |= GUCTL1_TX_IPGAP_LINECHECK_DIS;
+               WR4(sc, DWC3_GUCTL1, val);
+       }
+
        max_speed = fdtbus_get_string(phandle, "maximum-speed");
        if (max_speed == NULL)
                max_speed = "super-speed";
@@ -279,7 +289,7 @@
        }
 
        dwc3_fdt_soft_reset(sc);
-       dwc3_fdt_enable_phy(sc, dwc3_phandle);
+       dwc3_fdt_enable_phy(sc, dwc3_phandle, rev);
        dwc3_fdt_set_mode(sc, GCTL_PRTCAP_HOST);
 
        if (!fdtbus_intr_str(dwc3_phandle, 0, intrstr, sizeof(intrstr))) {



Home | Main Index | Thread Index | Old Index