diff options
author | Michael Grzeschik <m.grzeschik@pengutronix.de> | 2023-02-27 16:13:19 +0100 |
---|---|---|
committer | Vinod Koul <vkoul@kernel.org> | 2023-03-31 15:29:16 +0200 |
commit | c8879d3f87ffbaf6954dabec2199905616b0139e (patch) | |
tree | ccb6092e07a8da108bf5de7702a42a335183e2c7 /drivers/phy/st | |
parent | phy: xgene: Depend on ARCH_XGENE rather than plain arm64 (diff) | |
download | linux-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.c | 3 |
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: |