summaryrefslogtreecommitdiffstats
path: root/drivers/phy/st
diff options
context:
space:
mode:
authorMichael Grzeschik <m.grzeschik@pengutronix.de>2023-02-27 16:13:19 +0100
committerVinod Koul <vkoul@kernel.org>2023-03-31 15:29:16 +0200
commitc8879d3f87ffbaf6954dabec2199905616b0139e (patch)
treeccb6092e07a8da108bf5de7702a42a335183e2c7 /drivers/phy/st
parentphy: xgene: Depend on ARCH_XGENE rather than plain arm64 (diff)
downloadlinux-c8879d3f87ffbaf6954dabec2199905616b0139e.tar.xz
linux-c8879d3f87ffbaf6954dabec2199905616b0139e.zip
phy: stm32-usphyc: add 200 to 300 us delay to fix timeout on some machines
An minimum udelay of 200 us seems to be necessary on some machines. After the setup of the pll, which needs about 100 us to be locked there seem to be additional 100 us to get the phy really functional. Without this delay the usb runs not functional. With this additional short udelay this issue was not reported again. Signed-off-by: Michael Grzeschik <m.grzeschik@pengutronix.de> Reviewed-by: Fabrice Gasnier <fabrice.gasnier@foss.st.com> Link: https://lore.kernel.org/r/20230227151318.1894938-1-m.grzeschik@pengutronix.de Signed-off-by: Vinod Koul <vkoul@kernel.org>
Diffstat (limited to 'drivers/phy/st')
-rw-r--r--drivers/phy/st/phy-stm32-usbphyc.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/phy/st/phy-stm32-usbphyc.c b/drivers/phy/st/phy-stm32-usbphyc.c
index 1add3b75f92f..0a8552628cbd 100644
--- a/drivers/phy/st/phy-stm32-usbphyc.c
+++ b/drivers/phy/st/phy-stm32-usbphyc.c
@@ -317,6 +317,9 @@ static int stm32_usbphyc_pll_enable(struct stm32_usbphyc *usbphyc)
stm32_usbphyc_set_bits(pll_reg, PLLEN);
+ /* Wait for maximum lock time */
+ usleep_range(200, 300);
+
return 0;
reg_disable: