mmc: sdhci: Balance vmmc regulator_enable(), and always enable vqmmc
The vmmc regulator enable in sdhci_add_host is NOT necessary since it can be enabled during mmc_power_up by function mmc_regulator_set_ocr. And this extra enable will make regulator_enable/regulator_disable unbalanced. Consequently, vmmc can't be disabled during mmc_power_off. Also, if the vqmmc regulator exists, it should be enabled regardless it support 1.8v or not. Signed-off-by: Kevin Liu <kliu5@marvell.com> Signed-off-by: Philip Rakity <prakity@marvell.com> Signed-off-by: Chris Ball <cjb@laptop.org>
This commit is contained in:
parent
91ab252ac5
commit
8363c37414
1 changed files with 8 additions and 7 deletions
|
@ -2858,12 +2858,14 @@ int sdhci_add_host(struct sdhci_host *host)
|
||||||
mmc_hostname(mmc));
|
mmc_hostname(mmc));
|
||||||
host->vqmmc = NULL;
|
host->vqmmc = NULL;
|
||||||
}
|
}
|
||||||
}
|
} else {
|
||||||
else if (regulator_is_supported_voltage(host->vqmmc, 1800000, 1800000))
|
|
||||||
regulator_enable(host->vqmmc);
|
regulator_enable(host->vqmmc);
|
||||||
else
|
if (!regulator_is_supported_voltage(host->vqmmc, 1800000,
|
||||||
caps[1] &= ~(SDHCI_SUPPORT_SDR104 | SDHCI_SUPPORT_SDR50 |
|
1800000))
|
||||||
|
caps[1] &= ~(SDHCI_SUPPORT_SDR104 |
|
||||||
|
SDHCI_SUPPORT_SDR50 |
|
||||||
SDHCI_SUPPORT_DDR50);
|
SDHCI_SUPPORT_DDR50);
|
||||||
|
}
|
||||||
|
|
||||||
/* Any UHS-I mode in caps implies SDR12 and SDR25 support. */
|
/* Any UHS-I mode in caps implies SDR12 and SDR25 support. */
|
||||||
if (caps[1] & (SDHCI_SUPPORT_SDR104 | SDHCI_SUPPORT_SDR50 |
|
if (caps[1] & (SDHCI_SUPPORT_SDR104 | SDHCI_SUPPORT_SDR50 |
|
||||||
|
@ -2919,8 +2921,7 @@ int sdhci_add_host(struct sdhci_host *host)
|
||||||
mmc_hostname(mmc));
|
mmc_hostname(mmc));
|
||||||
host->vmmc = NULL;
|
host->vmmc = NULL;
|
||||||
}
|
}
|
||||||
} else
|
}
|
||||||
regulator_enable(host->vmmc);
|
|
||||||
|
|
||||||
#ifdef CONFIG_REGULATOR
|
#ifdef CONFIG_REGULATOR
|
||||||
if (host->vmmc) {
|
if (host->vmmc) {
|
||||||
|
|
Loading…
Add table
Reference in a new issue