|
@@ -1083,24 +1083,23 @@ static void sdhci_finish_command(struct sdhci_host *host)
|
|
|
|
|
|
static u16 sdhci_get_preset_value(struct sdhci_host *host)
|
|
static u16 sdhci_get_preset_value(struct sdhci_host *host)
|
|
{
|
|
{
|
|
- u16 ctrl, preset = 0;
|
|
|
|
|
|
+ u16 preset = 0;
|
|
|
|
|
|
- ctrl = sdhci_readw(host, SDHCI_HOST_CONTROL2);
|
|
|
|
-
|
|
|
|
- switch (ctrl & SDHCI_CTRL_UHS_MASK) {
|
|
|
|
- case SDHCI_CTRL_UHS_SDR12:
|
|
|
|
|
|
+ switch (host->timing) {
|
|
|
|
+ case MMC_TIMING_UHS_SDR12:
|
|
preset = sdhci_readw(host, SDHCI_PRESET_FOR_SDR12);
|
|
preset = sdhci_readw(host, SDHCI_PRESET_FOR_SDR12);
|
|
break;
|
|
break;
|
|
- case SDHCI_CTRL_UHS_SDR25:
|
|
|
|
|
|
+ case MMC_TIMING_UHS_SDR25:
|
|
preset = sdhci_readw(host, SDHCI_PRESET_FOR_SDR25);
|
|
preset = sdhci_readw(host, SDHCI_PRESET_FOR_SDR25);
|
|
break;
|
|
break;
|
|
- case SDHCI_CTRL_UHS_SDR50:
|
|
|
|
|
|
+ case MMC_TIMING_UHS_SDR50:
|
|
preset = sdhci_readw(host, SDHCI_PRESET_FOR_SDR50);
|
|
preset = sdhci_readw(host, SDHCI_PRESET_FOR_SDR50);
|
|
break;
|
|
break;
|
|
- case SDHCI_CTRL_UHS_SDR104:
|
|
|
|
|
|
+ case MMC_TIMING_UHS_SDR104:
|
|
|
|
+ case MMC_TIMING_MMC_HS200:
|
|
preset = sdhci_readw(host, SDHCI_PRESET_FOR_SDR104);
|
|
preset = sdhci_readw(host, SDHCI_PRESET_FOR_SDR104);
|
|
break;
|
|
break;
|
|
- case SDHCI_CTRL_UHS_DDR50:
|
|
|
|
|
|
+ case MMC_TIMING_UHS_DDR50:
|
|
preset = sdhci_readw(host, SDHCI_PRESET_FOR_DDR50);
|
|
preset = sdhci_readw(host, SDHCI_PRESET_FOR_DDR50);
|
|
break;
|
|
break;
|
|
default:
|
|
default:
|
|
@@ -1538,6 +1537,7 @@ static void sdhci_do_set_ios(struct sdhci_host *host, struct mmc_ios *ios)
|
|
sdhci_writew(host, clk, SDHCI_CLOCK_CONTROL);
|
|
sdhci_writew(host, clk, SDHCI_CLOCK_CONTROL);
|
|
|
|
|
|
host->ops->set_uhs_signaling(host, ios->timing);
|
|
host->ops->set_uhs_signaling(host, ios->timing);
|
|
|
|
+ host->timing = ios->timing;
|
|
|
|
|
|
if (!(host->quirks2 & SDHCI_QUIRK2_PRESET_VALUE_BROKEN) &&
|
|
if (!(host->quirks2 & SDHCI_QUIRK2_PRESET_VALUE_BROKEN) &&
|
|
((ios->timing == MMC_TIMING_UHS_SDR12) ||
|
|
((ios->timing == MMC_TIMING_UHS_SDR12) ||
|
|
@@ -1842,12 +1842,13 @@ static int sdhci_execute_tuning(struct mmc_host *mmc, u32 opcode)
|
|
* If the Host Controller supports the HS200 mode then the
|
|
* If the Host Controller supports the HS200 mode then the
|
|
* tuning function has to be executed.
|
|
* tuning function has to be executed.
|
|
*/
|
|
*/
|
|
- if (((ctrl & SDHCI_CTRL_UHS_MASK) == SDHCI_CTRL_UHS_SDR50) &&
|
|
|
|
|
|
+ if (host->timing == MMC_TIMING_UHS_SDR50 &&
|
|
(host->flags & SDHCI_SDR50_NEEDS_TUNING ||
|
|
(host->flags & SDHCI_SDR50_NEEDS_TUNING ||
|
|
host->flags & SDHCI_SDR104_NEEDS_TUNING))
|
|
host->flags & SDHCI_SDR104_NEEDS_TUNING))
|
|
requires_tuning_nonuhs = true;
|
|
requires_tuning_nonuhs = true;
|
|
|
|
|
|
- if (((ctrl & SDHCI_CTRL_UHS_MASK) == SDHCI_CTRL_UHS_SDR104) ||
|
|
|
|
|
|
+ if (host->timing == MMC_TIMING_MMC_HS200 ||
|
|
|
|
+ host->timing == MMC_TIMING_UHS_SDR104 ||
|
|
requires_tuning_nonuhs)
|
|
requires_tuning_nonuhs)
|
|
ctrl |= SDHCI_CTRL_EXEC_TUNING;
|
|
ctrl |= SDHCI_CTRL_EXEC_TUNING;
|
|
else {
|
|
else {
|