From: San Mehat Date: Mon, 1 Dec 2008 16:52:34 +0000 (-0800) Subject: mmc: sd: When resuming, try a little harder to init the card X-Git-Tag: firefly_0821_release~2958^2~499 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=f1da17ac8a32e862a25de3313b6d07c6ca14be68;p=firefly-linux-kernel-4.4.55.git mmc: sd: When resuming, try a little harder to init the card Signed-off-by: San Mehat --- diff --git a/drivers/mmc/core/sd.c b/drivers/mmc/core/sd.c index db828959d6d1..e41400bbe42f 100644 --- a/drivers/mmc/core/sd.c +++ b/drivers/mmc/core/sd.c @@ -1127,6 +1127,9 @@ static int mmc_sd_suspend(struct mmc_host *host) static int _mmc_sd_resume(struct mmc_host *host) { int err = 0; +#ifdef CONFIG_MMC_PARANOID_SD_INIT + int retries; +#endif BUG_ON(!host); BUG_ON(!host->card); @@ -1137,7 +1140,23 @@ static int _mmc_sd_resume(struct mmc_host *host) goto out; mmc_power_up(host, host->card->ocr); +#ifdef CONFIG_MMC_PARANOID_SD_INIT + retries = 5; + while (retries) { + err = mmc_sd_init_card(host, host->card->ocr, host->card); + + if (err) { + printk(KERN_ERR "%s: Re-init card rc = %d (retries = %d)\n", + mmc_hostname(host), err, retries); + mdelay(5); + retries--; + continue; + } + break; + } +#else err = mmc_sd_init_card(host, host->card->ocr, host->card); +#endif mmc_card_clr_suspended(host->card); out: