On Wed, Oct 26, 2022 at 03:11:00PM +0200, Stefan Agner wrote:
On 2022-10-21 08:54, Johan Hovold wrote:
On Fri, Oct 21, 2022 at 12:06:12AM +0200, Stefan Agner wrote:
On 2022-10-19 10:59, Johan Hovold wrote:
On Tue, Oct 18, 2022 at 05:27:24PM +0200, Stefan Agner wrote:
On 2022-09-06 14:07, Johan Hovold wrote:
From: Johan Hovold johan+linaro@kernel.org
commit 6000b8d900cd5f52fbcd0776d0cc396e88c8c2ea upstream.
The dwc3 driver manages its PHYs itself so the USB core PHY management needs to be disabled.
Use the struct xhci_plat_priv hack added by commits 46034a999c07 ("usb: host: xhci-plat: add platform data support") and f768e718911e ("usb: host: xhci-plat: add priv quirk for skip PHY initialization") to propagate the setting for now.
For some reason, this commit seems to break detection of the USB to S-ATA controller on ODROID-HC1 devices (Exynos 5422).
I think this may be related to the calibration calls added to dwc3 and later removed again by commits:
d8c80bb3b55b ("phy: exynos5-usbdrd: Calibrate LOS levels for exynos5420/5800") a0a465569b45 ("usb: dwc3: remove generic PHY calibrate() calls")
The removal explicitly mentions that the expectation is that USB core will do the PHY calibration.
There could be other changes in the sequencing of events that this platform has been implicitly relying on, but as a start, could try adding the missing calibration calls (patch below) and see if that makes a difference?
The patch below did not apply to 5.15.74 directly, but I think I was able to get the corrected patch applied (see below)
The user reports the S-ATA disk is *not* recognized with that patch applied.
I just noticed a mistake in the instrumentation patch I sent you. Could you try moving the calibrations calls after dwc3_host_init() (e.g. as in the second chunk in the diff below)?
As mentioned in the commit message for a0a465569b45 ("usb: dwc3: remove generic PHY calibrate() calls"), this may not work if the xhci-plat driver is built as a module and there are some corner cases that it does not cover.
It seems we should revert the offending commit and then try to find some time to untangle this mess, but please check if the below addresses the issue first so we know what the problem is.
I'll prepare a revert in the meantime.
Johan
diff --git a/drivers/usb/dwc3/core.c b/drivers/usb/dwc3/core.c index 31156d4dec9f..37d49a394912 100644 --- a/drivers/usb/dwc3/core.c +++ b/drivers/usb/dwc3/core.c @@ -197,6 +197,8 @@ static void __dwc3_set_mode(struct work_struct *work) otg_set_vbus(dwc->usb2_phy->otg, true); phy_set_mode(dwc->usb2_generic_phy, PHY_MODE_USB_HOST); phy_set_mode(dwc->usb3_generic_phy, PHY_MODE_USB_HOST); + phy_calibrate(dwc->usb2_generic_phy); + phy_calibrate(dwc->usb3_generic_phy); if (dwc->dis_split_quirk) { reg = dwc3_readl(dwc->regs, DWC3_GUCTL3); reg |= DWC3_GUCTL3_SPLITDISABLE; @@ -1391,6 +1393,9 @@ static int dwc3_core_init_mode(struct dwc3 *dwc) ret = dwc3_host_init(dwc); if (ret) return dev_err_probe(dev, ret, "failed to initialize host\n"); + + phy_calibrate(dwc->usb2_generic_phy); + phy_calibrate(dwc->usb3_generic_phy); break; case USB_DR_MODE_OTG: INIT_WORK(&dwc->drd_work, __dwc3_set_mode);