Commit 09e23823 authored by Elad Nachman's avatar Elad Nachman Committed by Ulf Hansson

mmc: sdhci-xenon: add timeout for PHY init complete

AC5X spec says PHY init complete bit must be polled until zero.
We see cases in which timeout can take longer than the standard
calculation on AC5X, which is expected following the spec comment above.
According to the spec, we must wait as long as it takes for that bit to
toggle on AC5X.
Cap that with 100 delay loops so we won't get stuck forever.

Fixes: 06c8b667 ("mmc: sdhci-xenon: Add support to PHYs of Marvell Xenon SDHC")
Acked-by: default avatarAdrian Hunter <adrian.hunter@intel.com>
Cc: stable@vger.kernel.org
Signed-off-by: default avatarElad Nachman <enachman@marvell.com>
Link: https://lore.kernel.org/r/20240222191714.1216470-3-enachman@marvell.comSigned-off-by: default avatarUlf Hansson <ulf.hansson@linaro.org>
parent 8e9f25a2
...@@ -110,6 +110,8 @@ ...@@ -110,6 +110,8 @@
#define XENON_EMMC_PHY_LOGIC_TIMING_ADJUST (XENON_EMMC_PHY_REG_BASE + 0x18) #define XENON_EMMC_PHY_LOGIC_TIMING_ADJUST (XENON_EMMC_PHY_REG_BASE + 0x18)
#define XENON_LOGIC_TIMING_VALUE 0x00AA8977 #define XENON_LOGIC_TIMING_VALUE 0x00AA8977
#define XENON_MAX_PHY_TIMEOUT_LOOPS 100
/* /*
* List offset of PHY registers and some special register values * List offset of PHY registers and some special register values
* in eMMC PHY 5.0 or eMMC PHY 5.1 * in eMMC PHY 5.0 or eMMC PHY 5.1
...@@ -278,18 +280,27 @@ static int xenon_emmc_phy_init(struct sdhci_host *host) ...@@ -278,18 +280,27 @@ static int xenon_emmc_phy_init(struct sdhci_host *host)
/* get the wait time */ /* get the wait time */
wait /= clock; wait /= clock;
wait++; wait++;
/* wait for host eMMC PHY init completes */
udelay(wait);
reg = sdhci_readl(host, phy_regs->timing_adj); /*
reg &= XENON_PHY_INITIALIZAION; * AC5X spec says bit must be polled until zero.
if (reg) { * We see cases in which timeout can take longer
* than the standard calculation on AC5X, which is
* expected following the spec comment above.
* According to the spec, we must wait as long as
* it takes for that bit to toggle on AC5X.
* Cap that with 100 delay loops so we won't get
* stuck here forever:
*/
ret = read_poll_timeout(sdhci_readl, reg,
!(reg & XENON_PHY_INITIALIZAION),
wait, XENON_MAX_PHY_TIMEOUT_LOOPS * wait,
false, host, phy_regs->timing_adj);
if (ret)
dev_err(mmc_dev(host->mmc), "eMMC PHY init cannot complete after %d us\n", dev_err(mmc_dev(host->mmc), "eMMC PHY init cannot complete after %d us\n",
wait); wait * XENON_MAX_PHY_TIMEOUT_LOOPS);
return -ETIMEDOUT;
}
return 0; return ret;
} }
#define ARMADA_3700_SOC_PAD_1_8V 0x1 #define ARMADA_3700_SOC_PAD_1_8V 0x1
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment