|
@@ -250,8 +250,9 @@ static void sdhci_reinit(struct sdhci_host *host)
|
|
|
* applicable to UHS-I cards. So reset these fields to their initial
|
|
|
* value when card is removed.
|
|
|
*/
|
|
|
- if (host->version >= SDHCI_SPEC_300 && host->tuning_count &&
|
|
|
- host->tuning_mode == SDHCI_TUNING_MODE_1) {
|
|
|
+ if (host->flags & SDHCI_USING_RETUNING_TIMER) {
|
|
|
+ host->flags &= ~SDHCI_USING_RETUNING_TIMER;
|
|
|
+
|
|
|
del_timer_sync(&host->tuning_timer);
|
|
|
host->flags &= ~SDHCI_NEEDS_RETUNING;
|
|
|
host->mmc->max_blk_count =
|
|
@@ -1873,6 +1874,7 @@ out:
|
|
|
*/
|
|
|
if (!(host->flags & SDHCI_NEEDS_RETUNING) && host->tuning_count &&
|
|
|
(host->tuning_mode == SDHCI_TUNING_MODE_1)) {
|
|
|
+ host->flags |= SDHCI_USING_RETUNING_TIMER;
|
|
|
mod_timer(&host->tuning_timer, jiffies +
|
|
|
host->tuning_count * HZ);
|
|
|
/* Tuning mode 1 limits the maximum data length to 4MB */
|
|
@@ -1890,10 +1892,10 @@ out:
|
|
|
* try tuning again at a later time, when the re-tuning timer expires.
|
|
|
* So for these controllers, we return 0. Since there might be other
|
|
|
* controllers who do not have this capability, we return error for
|
|
|
- * them.
|
|
|
+ * them. SDHCI_USING_RETUNING_TIMER means the host is currently using
|
|
|
+ * a retuning timer to do the retuning for the card.
|
|
|
*/
|
|
|
- if (err && host->tuning_count &&
|
|
|
- host->tuning_mode == SDHCI_TUNING_MODE_1)
|
|
|
+ if (err && (host->flags & SDHCI_USING_RETUNING_TIMER))
|
|
|
err = 0;
|
|
|
|
|
|
sdhci_clear_set_irqs(host, SDHCI_INT_DATA_AVAIL, ier);
|
|
@@ -2400,7 +2402,6 @@ out:
|
|
|
int sdhci_suspend_host(struct sdhci_host *host)
|
|
|
{
|
|
|
int ret;
|
|
|
- bool has_tuning_timer;
|
|
|
|
|
|
if (host->ops->platform_suspend)
|
|
|
host->ops->platform_suspend(host);
|
|
@@ -2408,16 +2409,14 @@ int sdhci_suspend_host(struct sdhci_host *host)
|
|
|
sdhci_disable_card_detection(host);
|
|
|
|
|
|
/* Disable tuning since we are suspending */
|
|
|
- has_tuning_timer = host->version >= SDHCI_SPEC_300 &&
|
|
|
- host->tuning_count && host->tuning_mode == SDHCI_TUNING_MODE_1;
|
|
|
- if (has_tuning_timer) {
|
|
|
+ if (host->flags & SDHCI_USING_RETUNING_TIMER) {
|
|
|
del_timer_sync(&host->tuning_timer);
|
|
|
host->flags &= ~SDHCI_NEEDS_RETUNING;
|
|
|
}
|
|
|
|
|
|
ret = mmc_suspend_host(host->mmc);
|
|
|
if (ret) {
|
|
|
- if (has_tuning_timer) {
|
|
|
+ if (host->flags & SDHCI_USING_RETUNING_TIMER) {
|
|
|
host->flags |= SDHCI_NEEDS_RETUNING;
|
|
|
mod_timer(&host->tuning_timer, jiffies +
|
|
|
host->tuning_count * HZ);
|
|
@@ -2468,8 +2467,7 @@ int sdhci_resume_host(struct sdhci_host *host)
|
|
|
host->ops->platform_resume(host);
|
|
|
|
|
|
/* Set the re-tuning expiration flag */
|
|
|
- if ((host->version >= SDHCI_SPEC_300) && host->tuning_count &&
|
|
|
- (host->tuning_mode == SDHCI_TUNING_MODE_1))
|
|
|
+ if (host->flags & SDHCI_USING_RETUNING_TIMER)
|
|
|
host->flags |= SDHCI_NEEDS_RETUNING;
|
|
|
|
|
|
return ret;
|
|
@@ -2508,8 +2506,7 @@ int sdhci_runtime_suspend_host(struct sdhci_host *host)
|
|
|
int ret = 0;
|
|
|
|
|
|
/* Disable tuning since we are suspending */
|
|
|
- if (host->version >= SDHCI_SPEC_300 &&
|
|
|
- host->tuning_mode == SDHCI_TUNING_MODE_1) {
|
|
|
+ if (host->flags & SDHCI_USING_RETUNING_TIMER) {
|
|
|
del_timer_sync(&host->tuning_timer);
|
|
|
host->flags &= ~SDHCI_NEEDS_RETUNING;
|
|
|
}
|
|
@@ -2550,8 +2547,7 @@ int sdhci_runtime_resume_host(struct sdhci_host *host)
|
|
|
sdhci_do_enable_preset_value(host, true);
|
|
|
|
|
|
/* Set the re-tuning expiration flag */
|
|
|
- if ((host->version >= SDHCI_SPEC_300) && host->tuning_count &&
|
|
|
- (host->tuning_mode == SDHCI_TUNING_MODE_1))
|
|
|
+ if (host->flags & SDHCI_USING_RETUNING_TIMER)
|
|
|
host->flags |= SDHCI_NEEDS_RETUNING;
|
|
|
|
|
|
spin_lock_irqsave(&host->lock, flags);
|
|
@@ -3140,8 +3136,6 @@ void sdhci_remove_host(struct sdhci_host *host, int dead)
|
|
|
free_irq(host->irq, host);
|
|
|
|
|
|
del_timer_sync(&host->timer);
|
|
|
- if (host->version >= SDHCI_SPEC_300)
|
|
|
- del_timer_sync(&host->tuning_timer);
|
|
|
|
|
|
tasklet_kill(&host->card_tasklet);
|
|
|
tasklet_kill(&host->finish_tasklet);
|