summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorYang Xiwen <[email protected]>2024-02-01 22:05:43 +0800
committerJaehoon Chung <[email protected]>2024-04-15 16:01:32 +0900
commit1fa6dc2879899a42ba85d4ece617c2356d048308 (patch)
treecfdedf517ae3648f72732cd53d2bdc01c8ffc31b
parent4685d6fbe47f9aab196558334ec89c3ca7bdb642 (diff)
mmc: dw_mmc: Don't return error if data busy timeout
As described in [1], some poor hardware or cards would fail to release the bus and keep driving data lines low. Ignore it and send the next cmd directly seems okay for most cases. [1]: https://patchwork.kernel.org/project/linux-mmc/patch/[email protected]/ Signed-off-by: Yang Xiwen <[email protected]> Tested-by: Jaehoon Chung <[email protected]>
-rw-r--r--drivers/mmc/dw_mmc.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/mmc/dw_mmc.c b/drivers/mmc/dw_mmc.c
index 400066fa99a..e1036641452 100644
--- a/drivers/mmc/dw_mmc.c
+++ b/drivers/mmc/dw_mmc.c
@@ -262,8 +262,8 @@ static int dwmci_send_cmd(struct mmc *mmc, struct mmc_cmd *cmd,
while (dwmci_readl(host, DWMCI_STATUS) & DWMCI_BUSY) {
if (get_timer(start) > timeout) {
- debug("%s: Timeout on data busy\n", __func__);
- return -ETIMEDOUT;
+ debug("%s: Timeout on data busy, continue anyway\n", __func__);
+ break;
}
}