Commit e5942431 authored by Adrian Hunter's avatar Adrian Hunter Committed by James Toy

Some hosts can accept only certain types of cards. For example, an eMMC

is MMC only and a uSD slot may be SD only.  Pass host capabilities from
the board through to the driver.
Signed-off-by: default avatarAdrian Hunter <adrian.hunter@nokia.com>
Acked-by: default avatarMatt Fleming <matt@console-pimps.org>
Cc: Ian Molton <ian@mnementh.co.uk>
Cc: "Roberto A. Foglietta" <roberto.foglietta@gmail.com>
Cc: Jarkko Lavinen <jarkko.lavinen@nokia.com>
Cc: Denis Karpov <ext-denis.2.karpov@nokia.com>
Cc: Pierre Ossman <pierre@ossman.eu>
Cc: Philip Langdale <philipl@overt.org>
Cc: "Madhusudhan" <madhu.cr@ti.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent 108aa01a
...@@ -470,12 +470,11 @@ void __init twl4030_mmc_init(struct twl4030_hsmmc_info *controllers) ...@@ -470,12 +470,11 @@ void __init twl4030_mmc_init(struct twl4030_hsmmc_info *controllers)
} else } else
mmc->slots[0].gpio_wp = -EINVAL; mmc->slots[0].gpio_wp = -EINVAL;
if (c->nonremovable)
mmc->slots[0].nonremovable = 1;
if (c->power_saving) if (c->power_saving)
mmc->slots[0].power_saving = 1; mmc->slots[0].power_saving = 1;
mmc->slots[0].caps = c->caps;
/* NOTE: MMC slots should have a Vcc regulator set up. /* NOTE: MMC slots should have a Vcc regulator set up.
* This may be from a TWL4030-family chip, another * This may be from a TWL4030-family chip, another
* controllable regulator, or a fixed supply. * controllable regulator, or a fixed supply.
......
...@@ -12,8 +12,8 @@ struct twl4030_hsmmc_info { ...@@ -12,8 +12,8 @@ struct twl4030_hsmmc_info {
bool transceiver; /* MMC-2 option */ bool transceiver; /* MMC-2 option */
bool ext_clock; /* use external pin for input clock */ bool ext_clock; /* use external pin for input clock */
bool cover_only; /* No card detect - just cover switch */ bool cover_only; /* No card detect - just cover switch */
bool nonremovable; /* Nonremovable e.g. eMMC */
bool power_saving; /* Try to sleep or power off when possible */ bool power_saving; /* Try to sleep or power off when possible */
unsigned long caps; /* MMC host capabilities */
int gpio_cd; /* or -EINVAL */ int gpio_cd; /* or -EINVAL */
int gpio_wp; /* or -EINVAL */ int gpio_wp; /* or -EINVAL */
char *name; /* or NULL for default */ char *name; /* or NULL for default */
......
...@@ -83,12 +83,12 @@ struct omap_mmc_platform_data { ...@@ -83,12 +83,12 @@ struct omap_mmc_platform_data {
/* use the internal clock */ /* use the internal clock */
unsigned internal_clock:1; unsigned internal_clock:1;
/* nonremovable e.g. eMMC */
unsigned nonremovable:1;
/* Try to sleep or power off when possible */ /* Try to sleep or power off when possible */
unsigned power_saving:1; unsigned power_saving:1;
/* MMC host capabilities */
unsigned long caps;
int switch_pin; /* gpio (card detect) */ int switch_pin; /* gpio (card detect) */
int gpio_wp; /* gpio (write protect) */ int gpio_wp; /* gpio (write protect) */
......
...@@ -1671,9 +1671,10 @@ static int __init omap_mmc_probe(struct platform_device *pdev) ...@@ -1671,9 +1671,10 @@ static int __init omap_mmc_probe(struct platform_device *pdev)
else if (mmc_slot(host).wires >= 4) else if (mmc_slot(host).wires >= 4)
mmc->caps |= MMC_CAP_4_BIT_DATA; mmc->caps |= MMC_CAP_4_BIT_DATA;
if (mmc_slot(host).nonremovable) mmc->caps |= mmc_slot(host).caps;
mmc->caps |= MMC_CAP_NONREMOVABLE;
/* If no card caps specified then assume them all */
if (!(mmc->caps & (MMC_CAP_SDIO | MMC_CAP_SD | MMC_CAP_MMC)))
mmc->caps |= MMC_CAP_SDIO | MMC_CAP_SD | MMC_CAP_MMC; mmc->caps |= MMC_CAP_SDIO | MMC_CAP_SD | MMC_CAP_MMC;
omap_hsmmc_init(host); omap_hsmmc_init(host);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment