|
@@ -1130,7 +1130,7 @@ static void sdhci_set_clock(struct sdhci_host *host, unsigned int clock)
|
|
sdhci_writew(host, 0, SDHCI_CLOCK_CONTROL);
|
|
sdhci_writew(host, 0, SDHCI_CLOCK_CONTROL);
|
|
|
|
|
|
if (clock == 0)
|
|
if (clock == 0)
|
|
- goto out;
|
|
|
|
|
|
+ return;
|
|
|
|
|
|
if (host->version >= SDHCI_SPEC_300) {
|
|
if (host->version >= SDHCI_SPEC_300) {
|
|
if (sdhci_readw(host, SDHCI_HOST_CONTROL2) &
|
|
if (sdhci_readw(host, SDHCI_HOST_CONTROL2) &
|
|
@@ -1220,9 +1220,6 @@ clock_set:
|
|
|
|
|
|
clk |= SDHCI_CLOCK_CARD_EN;
|
|
clk |= SDHCI_CLOCK_CARD_EN;
|
|
sdhci_writew(host, clk, SDHCI_CLOCK_CONTROL);
|
|
sdhci_writew(host, clk, SDHCI_CLOCK_CONTROL);
|
|
-
|
|
|
|
-out:
|
|
|
|
- host->clock = clock;
|
|
|
|
}
|
|
}
|
|
|
|
|
|
static int sdhci_set_power(struct sdhci_host *host, unsigned short power)
|
|
static int sdhci_set_power(struct sdhci_host *host, unsigned short power)
|
|
@@ -1441,8 +1438,10 @@ static void sdhci_do_set_ios(struct sdhci_host *host, struct mmc_ios *ios)
|
|
!(host->quirks2 & SDHCI_QUIRK2_PRESET_VALUE_BROKEN))
|
|
!(host->quirks2 & SDHCI_QUIRK2_PRESET_VALUE_BROKEN))
|
|
sdhci_enable_preset_value(host, false);
|
|
sdhci_enable_preset_value(host, false);
|
|
|
|
|
|
- if (!ios->clock || ios->clock != host->clock)
|
|
|
|
|
|
+ if (!ios->clock || ios->clock != host->clock) {
|
|
sdhci_set_clock(host, ios->clock);
|
|
sdhci_set_clock(host, ios->clock);
|
|
|
|
+ host->clock = ios->clock;
|
|
|
|
+ }
|
|
|
|
|
|
if (ios->power_mode == MMC_POWER_OFF)
|
|
if (ios->power_mode == MMC_POWER_OFF)
|
|
vdd_bit = sdhci_set_power(host, -1);
|
|
vdd_bit = sdhci_set_power(host, -1);
|