From: Lee Jones <[email protected]>

There are currently two instances of the ios_handler being used.
Both of which mearly toy with some regulator settings. Now there
is a GPIO regulator API, we can use that instead, and lessen the
per platform burden. By doing this, we also become more Device
Tree compatible.

Cc: Chris Ball <[email protected]>
Cc: Russell King <[email protected]>
Signed-off-by: Lee Jones <[email protected]>
Signed-off-by: Ulf Hansson <[email protected]>
---
 drivers/mmc/host/mmci.c |    9 +++++++++
 1 file changed, 9 insertions(+)

diff --git a/drivers/mmc/host/mmci.c b/drivers/mmc/host/mmci.c
index 9da5f24..e56655a 100644
--- a/drivers/mmc/host/mmci.c
+++ b/drivers/mmc/host/mmci.c
@@ -1097,6 +1097,11 @@ static void mmci_set_ios(struct mmc_host *mmc, struct 
mmc_ios *ios)
        case MMC_POWER_OFF:
                if (!IS_ERR(mmc->supply.vmmc))
                        mmc_regulator_set_ocr(mmc, mmc->supply.vmmc, 0);
+
+               if (!IS_ERR(mmc->supply.vqmmc) &&
+                   regulator_is_enabled(mmc->supply.vqmmc))
+                       regulator_disable(mmc->supply.vqmmc);
+
                break;
        case MMC_POWER_UP:
                if (!IS_ERR(mmc->supply.vmmc))
@@ -1111,6 +1116,10 @@ static void mmci_set_ios(struct mmc_host *mmc, struct 
mmc_ios *ios)
 
                break;
        case MMC_POWER_ON:
+               if (!IS_ERR(mmc->supply.vqmmc) &&
+                   !regulator_is_enabled(mmc->supply.vqmmc))
+                       regulator_enable(mmc->supply.vqmmc);
+
                pwr |= MCI_PWR_ON;
                break;
        }
-- 
1.7.10

--
To unsubscribe from this list: send the line "unsubscribe linux-mmc" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to