aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/mmc/core
diff options
context:
space:
mode:
authorPhilip Langdale <philipl@overt.org>2007-03-16 22:39:00 -0400
committerPierre Ossman <drzeus@drzeus.cx>2007-05-01 08:14:50 -0400
commit55556da01284af8c2174b786b3eca8e11301b656 (patch)
tree579e0dbd68021daee1ff0c5b400d9cdf71c6faf8 /drivers/mmc/core
parent4be34c99a2f3aa90fa42e62c0918f07afb8a645b (diff)
MMC: Fix handling of low-voltage cards
Fix handling of low voltage MMC cards. The latest MMC and SD specs both agree that support for low-voltage operations is indicated by bit 7 in the OCR. The MMC spec states that the low voltage range is 1.65-1.95V while the SD spec leaves the actual voltage range undefined - meaning that there is still no such thing as a low voltage SD card. However, an old Sandisk spec implied that bits 7.0 represented voltages below 2.0V in 1V or 0.5V increments, and the code was accordingly written with that expectation. This confusion meant that host drivers attempting to support the typical low voltage (1.8V) would set the wrong bits in the host OCR mask (usually bits 5 and/or 6) resulting in the the low voltage mode never being used. This change corrects the low voltage range and adds sanity checks on the reserved bits (0-6) and for SD cards that claim to support low-voltage operations. Signed-off-by: Philip Langdale <philipl@overt.org> Signed-off-by: Pierre Ossman <drzeus@drzeus.cx>
Diffstat (limited to 'drivers/mmc/core')
-rw-r--r--drivers/mmc/core/mmc.c11
-rw-r--r--drivers/mmc/core/sd.c18
2 files changed, 29 insertions, 0 deletions
diff --git a/drivers/mmc/core/mmc.c b/drivers/mmc/core/mmc.c
index c528017d6128..c2e120b11bef 100644
--- a/drivers/mmc/core/mmc.c
+++ b/drivers/mmc/core/mmc.c
@@ -323,6 +323,17 @@ int mmc_attach_mmc(struct mmc_host *host, u32 ocr)
323 323
324 mmc_attach_bus(host, &mmc_ops); 324 mmc_attach_bus(host, &mmc_ops);
325 325
326 /*
327 * Sanity check the voltages that the card claims to
328 * support.
329 */
330 if (ocr & 0x7F) {
331 printk(KERN_WARNING "%s: card claims to support voltages "
332 "below the defined range. These will be ignored.\n",
333 mmc_hostname(host));
334 ocr &= ~0x7F;
335 }
336
326 host->ocr = mmc_select_voltage(host, ocr); 337 host->ocr = mmc_select_voltage(host, ocr);
327 338
328 /* 339 /*
diff --git a/drivers/mmc/core/sd.c b/drivers/mmc/core/sd.c
index 6c6beb48f3a8..fb18b301502e 100644
--- a/drivers/mmc/core/sd.c
+++ b/drivers/mmc/core/sd.c
@@ -297,6 +297,24 @@ int mmc_attach_sd(struct mmc_host *host, u32 ocr)
297 297
298 mmc_attach_bus(host, &mmc_sd_ops); 298 mmc_attach_bus(host, &mmc_sd_ops);
299 299
300 /*
301 * Sanity check the voltages that the card claims to
302 * support.
303 */
304 if (ocr & 0x7F) {
305 printk(KERN_WARNING "%s: card claims to support voltages "
306 "below the defined range. These will be ignored.\n",
307 mmc_hostname(host));
308 ocr &= ~0x7F;
309 }
310
311 if (ocr & MMC_VDD_165_195) {
312 printk(KERN_WARNING "%s: SD card claims to support the "
313 "incompletely defined 'low voltage range'. This "
314 "will be ignored.\n", mmc_hostname(host));
315 ocr &= ~MMC_VDD_165_195;
316 }
317
300 host->ocr = mmc_select_voltage(host, ocr); 318 host->ocr = mmc_select_voltage(host, ocr);
301 319
302 /* 320 /*