aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/mmc
diff options
context:
space:
mode:
authorFredrik Soderstedt <fredrik.soderstedt@stericsson.com>2013-04-17 07:50:53 -0400
committerChris Ball <cjb@laptop.org>2013-05-26 14:23:11 -0400
commit810e08ee425f8d7327e4b30069a9b2b3dccfc67d (patch)
tree0cc4264fa30f9fb5c31c420d34bc97b4e1b64e0b /drivers/mmc
parent4a29b5591faf25555fdf2b717594d50f70c15066 (diff)
mmc: core: Only execute tuning for SDR50 and SDR104
Only execute tuning for sd and sdio devices that are using SDR50 or SDR104. Make sure clock is hold during tuning for sdio devices. Signed-off-by: Fredrik Soderstedt <fredrik.soderstedt@stericsson.com> Acked-by: Johan Rudholm <jrudholm@gmail.com> Acked-by: Ulf Hansson <ulf.hansson@linaro.org> Signed-off-by: Chris Ball <cjb@laptop.org>
Diffstat (limited to 'drivers/mmc')
-rw-r--r--drivers/mmc/core/sd.c9
-rw-r--r--drivers/mmc/core/sdio.c12
2 files changed, 17 insertions, 4 deletions
diff --git a/drivers/mmc/core/sd.c b/drivers/mmc/core/sd.c
index 9e645e19cec6..8373d2288bb1 100644
--- a/drivers/mmc/core/sd.c
+++ b/drivers/mmc/core/sd.c
@@ -646,8 +646,13 @@ static int mmc_sd_init_uhs_card(struct mmc_card *card)
646 if (err) 646 if (err)
647 goto out; 647 goto out;
648 648
649 /* SPI mode doesn't define CMD19 */ 649 /*
650 if (!mmc_host_is_spi(card->host) && card->host->ops->execute_tuning) { 650 * SPI mode doesn't define CMD19 and tuning is only valid for SDR50 and
651 * SDR104 mode SD-cards. Note that tuning is mandatory for SDR104.
652 */
653 if (!mmc_host_is_spi(card->host) && card->host->ops->execute_tuning &&
654 (card->sd_bus_speed == UHS_SDR50_BUS_SPEED ||
655 card->sd_bus_speed == UHS_SDR104_BUS_SPEED)) {
651 mmc_host_clk_hold(card->host); 656 mmc_host_clk_hold(card->host);
652 err = card->host->ops->execute_tuning(card->host, 657 err = card->host->ops->execute_tuning(card->host,
653 MMC_SEND_TUNING_BLOCK); 658 MMC_SEND_TUNING_BLOCK);
diff --git a/drivers/mmc/core/sdio.c b/drivers/mmc/core/sdio.c
index 6889a821c1da..444668c210b2 100644
--- a/drivers/mmc/core/sdio.c
+++ b/drivers/mmc/core/sdio.c
@@ -563,10 +563,18 @@ static int mmc_sdio_init_uhs_card(struct mmc_card *card)
563 if (err) 563 if (err)
564 goto out; 564 goto out;
565 565
566 /* Initialize and start re-tuning timer */ 566 /*
567 if (!mmc_host_is_spi(card->host) && card->host->ops->execute_tuning) 567 * SPI mode doesn't define CMD19 and tuning is only valid for SDR50 and
568 * SDR104 mode SD-cards. Note that tuning is mandatory for SDR104.
569 */
570 if (!mmc_host_is_spi(card->host) && card->host->ops->execute_tuning &&
571 ((card->sw_caps.sd3_bus_mode & SD_MODE_UHS_SDR50) ||
572 (card->sw_caps.sd3_bus_mode & SD_MODE_UHS_SDR104))) {
573 mmc_host_clk_hold(card->host);
568 err = card->host->ops->execute_tuning(card->host, 574 err = card->host->ops->execute_tuning(card->host,
569 MMC_SEND_TUNING_BLOCK); 575 MMC_SEND_TUNING_BLOCK);
576 mmc_host_clk_release(card->host);
577 }
570 578
571out: 579out:
572 580