MMC: Consolidate voltage definitions
authorPhilip Langdale <philipl@overt.org>
Mon, 12 Mar 2007 00:15:15 +0000 (17:15 -0700)
committerPierre Ossman <drzeus@drzeus.cx>
Tue, 1 May 2007 11:42:28 +0000 (13:42 +0200)
Consolidate the list of available voltages.

Up until now, a separate set of defines has been
used for host->vdd than that used for the OCR
voltage mask values. Having two sets of defines
allows them to get out of sync and the current
sets are already inconsistent with one claiming
to describe ranges and the other specific voltages.

Only the SDHCI driver uses the host->vdd defines and
it is easily fixed to use the OCR defines.

Signed-off-by: Philip Langdale <philipl@overt.org>
Signed-off-by: Pierre Ossman <drzeus@drzeus.cx>
drivers/mmc/host/sdhci.c
include/linux/mmc/host.h

index 579142a7904bfef769f26ecd088c3ad7cc65caa8..a57f6a3d48d340e94ad5e07ca6b6901ad4ff562f 100644 (file)
@@ -658,20 +658,17 @@ static void sdhci_set_power(struct sdhci_host *host, unsigned short power)
 
        pwr = SDHCI_POWER_ON;
 
-       switch (power) {
-       case MMC_VDD_170:
-       case MMC_VDD_180:
-       case MMC_VDD_190:
+       switch (1 << power) {
+       case MMC_VDD_17_18:
+       case MMC_VDD_18_19:
                pwr |= SDHCI_POWER_180;
                break;
-       case MMC_VDD_290:
-       case MMC_VDD_300:
-       case MMC_VDD_310:
+       case MMC_VDD_29_30:
+       case MMC_VDD_30_31:
                pwr |= SDHCI_POWER_300;
                break;
-       case MMC_VDD_320:
-       case MMC_VDD_330:
-       case MMC_VDD_340:
+       case MMC_VDD_32_33:
+       case MMC_VDD_33_34:
                pwr |= SDHCI_POWER_330;
                break;
        default:
index efae87b5c4e798ae75f871a93f61c95e214b78bb..5a66d8a2bf17a8b6614ce29bebd38ddf4bdeca08 100644 (file)
@@ -16,30 +16,7 @@ struct mmc_ios {
        unsigned int    clock;                  /* clock rate */
        unsigned short  vdd;
 
-#define        MMC_VDD_150     0
-#define        MMC_VDD_155     1
-#define        MMC_VDD_160     2
-#define        MMC_VDD_165     3
-#define        MMC_VDD_170     4
-#define        MMC_VDD_180     5
-#define        MMC_VDD_190     6
-#define        MMC_VDD_200     7
-#define        MMC_VDD_210     8
-#define        MMC_VDD_220     9
-#define        MMC_VDD_230     10
-#define        MMC_VDD_240     11
-#define        MMC_VDD_250     12
-#define        MMC_VDD_260     13
-#define        MMC_VDD_270     14
-#define        MMC_VDD_280     15
-#define        MMC_VDD_290     16
-#define        MMC_VDD_300     17
-#define        MMC_VDD_310     18
-#define        MMC_VDD_320     19
-#define        MMC_VDD_330     20
-#define        MMC_VDD_340     21
-#define        MMC_VDD_350     22
-#define        MMC_VDD_360     23
+/* vdd stores the bit number of the selected voltage range from below. */
 
        unsigned char   bus_mode;               /* command output mode */