mmc: tegra: Disable UHS-I modes for tegra114
authorJon Hunter <jonathanh@nvidia.com>
Fri, 26 Feb 2016 09:34:17 +0000 (09:34 +0000)
committerUlf Hansson <ulf.hansson@linaro.org>
Wed, 16 Mar 2016 11:35:37 +0000 (12:35 +0100)
SD card support for Tegra114 started failing after commit a8e326a911d3
("mmc: tegra: implement module external clock change") was merged. This
commit was part of a series to enable UHS-I modes for Tegra. To
workaround this problem for now, disable UHS-I modes for Tegra114 by
separating the soc data structures for Tegra114 and Tegra124 so that
UHS-I is still enabled for Tegra124 but not Tegra114.

Fixes: a8e326a911d3 ("mmc: tegra: implement module external clock change")
Signed-off-by: Jon Hunter <jonathanh@nvidia.com>
Reviewed-by: Lucas Stach <dev@lynxeye.de>
Acked-by: Thierry Reding <treding@nvidia.com>
Acked-by: Adrian Hunter <adrian.hunter@intel.com>
Cc: stable@vger.kernel.org
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
drivers/mmc/host/sdhci-tegra.c

index 2c3c57bbef0a602f0bec7e5506a79ea9d725b7a6..8993db376dc496b3b0edf8933994d6ce90aab37c 100644 (file)
@@ -147,10 +147,16 @@ static void tegra_sdhci_reset(struct sdhci_host *host, u8 mask)
        /* Advertise UHS modes as supported by host */
        if (soc_data->nvquirks & NVQUIRK_ENABLE_SDR50)
                misc_ctrl |= SDHCI_MISC_CTRL_ENABLE_SDR50;
+       else
+               misc_ctrl &= ~SDHCI_MISC_CTRL_ENABLE_SDR50;
        if (soc_data->nvquirks & NVQUIRK_ENABLE_DDR50)
                misc_ctrl |= SDHCI_MISC_CTRL_ENABLE_DDR50;
+       else
+               misc_ctrl &= ~SDHCI_MISC_CTRL_ENABLE_DDR50;
        if (soc_data->nvquirks & NVQUIRK_ENABLE_SDR104)
                misc_ctrl |= SDHCI_MISC_CTRL_ENABLE_SDR104;
+       else
+               misc_ctrl &= ~SDHCI_MISC_CTRL_ENABLE_SDR104;
        sdhci_writel(host, misc_ctrl, SDHCI_TEGRA_VENDOR_MISC_CTRL);
 
        clk_ctrl = sdhci_readl(host, SDHCI_TEGRA_VENDOR_CLOCK_CTRL);
@@ -335,6 +341,10 @@ static const struct sdhci_pltfm_data sdhci_tegra114_pdata = {
 
 static const struct sdhci_tegra_soc_data soc_data_tegra114 = {
        .pdata = &sdhci_tegra114_pdata,
+};
+
+static const struct sdhci_tegra_soc_data soc_data_tegra124 = {
+       .pdata = &sdhci_tegra114_pdata,
        .nvquirks = NVQUIRK_ENABLE_SDR50 |
                    NVQUIRK_ENABLE_DDR50 |
                    NVQUIRK_ENABLE_SDR104,
@@ -357,7 +367,7 @@ static const struct sdhci_tegra_soc_data soc_data_tegra210 = {
 
 static const struct of_device_id sdhci_tegra_dt_match[] = {
        { .compatible = "nvidia,tegra210-sdhci", .data = &soc_data_tegra210 },
-       { .compatible = "nvidia,tegra124-sdhci", .data = &soc_data_tegra114 },
+       { .compatible = "nvidia,tegra124-sdhci", .data = &soc_data_tegra124 },
        { .compatible = "nvidia,tegra114-sdhci", .data = &soc_data_tegra114 },
        { .compatible = "nvidia,tegra30-sdhci", .data = &soc_data_tegra30 },
        { .compatible = "nvidia,tegra20-sdhci", .data = &soc_data_tegra20 },