mmc: mmci: Move ios_handler functionality into the driver
authorLee Jones <lee.jones@linaro.org>
Thu, 31 Jan 2013 11:27:52 +0000 (11:27 +0000)
committerLinus Walleij <linus.walleij@linaro.org>
Fri, 1 Mar 2013 22:25:25 +0000 (23:25 +0100)
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.

Acked-by: Chris Ball <cjb@laptop.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/mmc/host/mmci.c

index 372e921389c8e633f2b93c5d7259c482243d4647..375c109607ff2020e632834cb4ffe7eca95fc2b1 100644 (file)
@@ -1141,6 +1141,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))
@@ -1155,6 +1160,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;
        }