diff options
| -rw-r--r-- | drivers/mmc/host/mmci.c | 13 | ||||
| -rw-r--r-- | include/linux/amba/mmci.h | 10 |
2 files changed, 9 insertions, 14 deletions
diff --git a/drivers/mmc/host/mmci.c b/drivers/mmc/host/mmci.c index 3eaa0e9373cd..7ae3eeeefc29 100644 --- a/drivers/mmc/host/mmci.c +++ b/drivers/mmc/host/mmci.c | |||
| @@ -493,16 +493,9 @@ static void mmci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios) | |||
| 493 | /* This implicitly enables the regulator */ | 493 | /* This implicitly enables the regulator */ |
| 494 | mmc_regulator_set_ocr(host->vcc, ios->vdd); | 494 | mmc_regulator_set_ocr(host->vcc, ios->vdd); |
| 495 | #endif | 495 | #endif |
| 496 | /* | 496 | if (host->plat->vdd_handler) |
| 497 | * The translate_vdd function is not used if you have | 497 | pwr |= host->plat->vdd_handler(mmc_dev(mmc), ios->vdd, |
| 498 | * an external regulator, or your design is really weird. | 498 | ios->power_mode); |
| 499 | * Using it would mean sending in power control BOTH using | ||
| 500 | * a regulator AND the 4 MMCIPWR bits. If we don't have | ||
| 501 | * a regulator, we might have some other platform specific | ||
| 502 | * power control behind this translate function. | ||
| 503 | */ | ||
| 504 | if (!host->vcc && host->plat->translate_vdd) | ||
| 505 | pwr |= host->plat->translate_vdd(mmc_dev(mmc), ios->vdd); | ||
| 506 | /* The ST version does not have this, fall through to POWER_ON */ | 499 | /* The ST version does not have this, fall through to POWER_ON */ |
| 507 | if (host->hw_designer != AMBA_VENDOR_ST) { | 500 | if (host->hw_designer != AMBA_VENDOR_ST) { |
| 508 | pwr |= MCI_PWR_UP; | 501 | pwr |= MCI_PWR_UP; |
diff --git a/include/linux/amba/mmci.h b/include/linux/amba/mmci.h index 7e466fe72025..ca84ce70d5d5 100644 --- a/include/linux/amba/mmci.h +++ b/include/linux/amba/mmci.h | |||
| @@ -15,9 +15,10 @@ | |||
| 15 | * @ocr_mask: available voltages on the 4 pins from the block, this | 15 | * @ocr_mask: available voltages on the 4 pins from the block, this |
| 16 | * is ignored if a regulator is used, see the MMC_VDD_* masks in | 16 | * is ignored if a regulator is used, see the MMC_VDD_* masks in |
| 17 | * mmc/host.h | 17 | * mmc/host.h |
| 18 | * @translate_vdd: a callback function to translate a MMC_VDD_* | 18 | * @vdd_handler: a callback function to translate a MMC_VDD_* |
| 19 | * mask into a value to be binary or:ed and written into the | 19 | * mask into a value to be binary (or set some other custom bits |
| 20 | * MMCIPWR register of the block | 20 | * in MMCIPWR) or:ed and written into the MMCIPWR register of the |
| 21 | * block. May also control external power based on the power_mode. | ||
| 21 | * @status: if no GPIO read function was given to the block in | 22 | * @status: if no GPIO read function was given to the block in |
| 22 | * gpio_wp (below) this function will be called to determine | 23 | * gpio_wp (below) this function will be called to determine |
| 23 | * whether a card is present in the MMC slot or not | 24 | * whether a card is present in the MMC slot or not |
| @@ -29,7 +30,8 @@ | |||
| 29 | struct mmci_platform_data { | 30 | struct mmci_platform_data { |
| 30 | unsigned int f_max; | 31 | unsigned int f_max; |
| 31 | unsigned int ocr_mask; | 32 | unsigned int ocr_mask; |
| 32 | u32 (*translate_vdd)(struct device *, unsigned int); | 33 | u32 (*vdd_handler)(struct device *, unsigned int vdd, |
| 34 | unsigned char power_mode); | ||
| 33 | unsigned int (*status)(struct device *); | 35 | unsigned int (*status)(struct device *); |
| 34 | int gpio_wp; | 36 | int gpio_wp; |
| 35 | int gpio_cd; | 37 | int gpio_cd; |
