diff options
author | Daniel Chen <daniel.ch_chen@htc.com> | 2009-12-09 09:45:36 -0800 |
---|---|---|
committer | Troy Kisky <troy.kisky@boundarydevices.com> | 2013-03-05 13:38:20 -0700 |
commit | 0fb947743c824d58352dbc617714ad6920b5c20d (patch) | |
tree | 069c7119b3959bcec7e99791054b5c53fea17a23 | |
parent | 0c427415156aefe06ddef38b2a10c05d16454ae0 (diff) |
mmc: sdio: Add high speed support to sdio_reset_comm()
Signed-off-by: San Mehat <san@google.com>
-rw-r--r-- | drivers/mmc/core/sdio.c | 23 |
1 files changed, 22 insertions, 1 deletions
diff --git a/drivers/mmc/core/sdio.c b/drivers/mmc/core/sdio.c index f593082b4898..e03d512906a0 100644 --- a/drivers/mmc/core/sdio.c +++ b/drivers/mmc/core/sdio.c @@ -927,7 +927,28 @@ int sdio_reset_comm(struct mmc_card *card) goto err; } - mmc_set_clock(host, card->cis.max_dtr); + /* + * Switch to high-speed (if supported). + */ + err = sdio_enable_hs(card); + if (err) + goto err; + + /* + * Change to the card's maximum speed. + */ + if (mmc_card_highspeed(card)) { + /* + * The SDIO specification doesn't mention how + * the CIS transfer speed register relates to + * high-speed, but it seems that 50 MHz is + * mandatory. + */ + mmc_set_clock(host, 50000000); + } else { + mmc_set_clock(host, card->cis.max_dtr); + } + err = sdio_enable_wide(card); if (err) goto err; |