All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] mmc: core: in mmc_hw_reset(), allow power cycle.
@ 2016-04-01 16:46 Gwendal Grignou
  2016-04-01 17:25 ` [PATCH v2] " Gwendal Grignou
  0 siblings, 1 reply; 6+ messages in thread
From: Gwendal Grignou @ 2016-04-01 16:46 UTC (permalink / raw)
  To: ulf.hansson; +Cc: linux-mmc

When the eMMC device does not support/allow sending RST_n signal,
do a brute force power cycle instead of returning EOPNOTSUPP.

Signed-off-by: Gwendal Grignou <gwendal@chromium.org>
---
 drivers/mmc/core/core.c |  5 +++--
 drivers/mmc/core/mmc.c  | 18 ++++++++----------
 2 files changed, 11 insertions(+), 12 deletions(-)

diff --git a/drivers/mmc/core/core.c b/drivers/mmc/core/core.c
index d8bbc78..d5bc2d8 100644
--- a/drivers/mmc/core/core.c
+++ b/drivers/mmc/core/core.c
@@ -2468,8 +2468,9 @@ int mmc_hw_reset(struct mmc_host *host)
 	ret = host->bus_ops->reset(host);
 	mmc_bus_put(host);
 
-	if (ret != -EOPNOTSUPP)
-		pr_warn("%s: tried to reset card\n", mmc_hostname(host));
+	if (ret)
+		pr_warn("%s: tried to reset card, got error %d\n",
+			mmc_hostname(host), ret);
 
 	return ret;
 }
diff --git a/drivers/mmc/core/mmc.c b/drivers/mmc/core/mmc.c
index 96cc7e2..deb8c16 100644
--- a/drivers/mmc/core/mmc.c
+++ b/drivers/mmc/core/mmc.c
@@ -1988,19 +1988,17 @@ static int mmc_reset(struct mmc_host *host)
 {
 	struct mmc_card *card = host->card;
 
-	if (!(host->caps & MMC_CAP_HW_RESET) || !host->ops->hw_reset)
-		return -EOPNOTSUPP;
-
-	if (!mmc_can_reset(card))
-		return -EOPNOTSUPP;
-
 	mmc_set_clock(host, host->f_init);
-
-	host->ops->hw_reset(host);
-
+	if ((host->caps & MMC_CAP_HW_RESET) && host->ops->hw_reset &&
+	     mmc_can_reset(card)) {
+		 /* If the card accept RST_n signal, send it. */
+		host->ops->hw_reset(host);
+	} else {
+		/* Do a brute force power cycle */
+		mmc_power_cycle(host, host->card->ocr);
+	}
 	/* Set initial state and call mmc_set_ios */
 	mmc_set_initial_state(host);
-
 	return mmc_init_card(host, card->ocr, card);
 }
 
-- 
2.8.0.rc3.226.g39d4020


^ permalink raw reply related	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2016-04-11 13:33 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-04-01 16:46 [PATCH] mmc: core: in mmc_hw_reset(), allow power cycle Gwendal Grignou
2016-04-01 17:25 ` [PATCH v2] " Gwendal Grignou
2016-04-01 23:04   ` [PATCH v3] " Gwendal Grignou
2016-04-04 12:39     ` Ulf Hansson
2016-04-07 18:14       ` [PATCH v4] " Gwendal Grignou
2016-04-11 13:33       ` [PATCH v3] " Ulf Hansson

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.