diff options
author | Wolfgang Muees <wolfgang.mues@auerswald.de> | 2009-04-07 14:48:16 +0100 |
---|---|---|
committer | Pierre Ossman <pierre@ossman.eu> | 2009-04-08 20:37:53 +0200 |
commit | 9d9f25c036dd584db175552a7d162403d3ab54b3 (patch) | |
tree | 42aa05d8091832eb28ee2237e775e8b738af11d4 /drivers/mmc/core | |
parent | 00adadc12196c7b3e8923729e728162267e98ff7 (diff) | |
download | linux-3.10-9d9f25c036dd584db175552a7d162403d3ab54b3.tar.gz linux-3.10-9d9f25c036dd584db175552a7d162403d3ab54b3.tar.bz2 linux-3.10-9d9f25c036dd584db175552a7d162403d3ab54b3.zip |
mmc_spi: do not check CID and CSD blocks with CRC16
Some cards are not able to calculate a valid CRC16 value
for CID and CSD reads (CRC for 512 byte data blocks is OK).
By moving the CRC enable after the read of CID and CSD, these
cards can be used. This patch was tested with a faulty 8 GByte
takeMS Class 6 SDHC card. This patch was suggested by
Pierre Ossman.
Signed-off-by: Wolfgang Muees <wolfgang.mues@auerswald.de>
Signed-off-by: Pierre Ossman <pierre@ossman.eu>
Diffstat (limited to 'drivers/mmc/core')
-rw-r--r-- | drivers/mmc/core/sd.c | 21 |
1 files changed, 12 insertions, 9 deletions
diff --git a/drivers/mmc/core/sd.c b/drivers/mmc/core/sd.c index 26fc098d77c..cd81c395e16 100644 --- a/drivers/mmc/core/sd.c +++ b/drivers/mmc/core/sd.c @@ -363,15 +363,6 @@ static int mmc_sd_init_card(struct mmc_host *host, u32 ocr, goto err; /* - * For SPI, enable CRC as appropriate. - */ - if (mmc_host_is_spi(host)) { - err = mmc_spi_set_crc(host, use_spi_crc); - if (err) - goto err; - } - - /* * Fetch CID from card. */ if (mmc_host_is_spi(host)) @@ -458,6 +449,18 @@ static int mmc_sd_init_card(struct mmc_host *host, u32 ocr, } /* + * For SPI, enable CRC as appropriate. + * This CRC enable is located AFTER the reading of the + * card registers because some SDHC cards are not able + * to provide valid CRCs for non-512-byte blocks. + */ + if (mmc_host_is_spi(host)) { + err = mmc_spi_set_crc(host, use_spi_crc); + if (err) + goto free_card; + } + + /* * Attempt to change to high-speed (if supported) */ err = mmc_switch_hs(card); |