|
@@ -114,17 +114,18 @@ static int mmc_decode_cid(struct mmc_card *card)
|
|
|
static int mmc_decode_csd(struct mmc_card *card)
|
|
|
{
|
|
|
struct mmc_csd *csd = &card->csd;
|
|
|
- unsigned int e, m, csd_struct;
|
|
|
+ unsigned int e, m;
|
|
|
u32 *resp = card->raw_csd;
|
|
|
|
|
|
/*
|
|
|
* We only understand CSD structure v1.1 and v1.2.
|
|
|
* v1.2 has extra information in bits 15, 11 and 10.
|
|
|
+ * We also support eMMC v4.4 & v4.41.
|
|
|
*/
|
|
|
- csd_struct = UNSTUFF_BITS(resp, 126, 2);
|
|
|
- if (csd_struct != 1 && csd_struct != 2) {
|
|
|
+ csd->structure = UNSTUFF_BITS(resp, 126, 2);
|
|
|
+ if (csd->structure == 0) {
|
|
|
printk(KERN_ERR "%s: unrecognised CSD structure version %d\n",
|
|
|
- mmc_hostname(card->host), csd_struct);
|
|
|
+ mmc_hostname(card->host), csd->structure);
|
|
|
return -EINVAL;
|
|
|
}
|
|
|
|
|
@@ -207,11 +208,22 @@ static int mmc_read_ext_csd(struct mmc_card *card)
|
|
|
goto out;
|
|
|
}
|
|
|
|
|
|
+ /* Version is coded in the CSD_STRUCTURE byte in the EXT_CSD register */
|
|
|
+ if (card->csd.structure == 3) {
|
|
|
+ int ext_csd_struct = ext_csd[EXT_CSD_STRUCTURE];
|
|
|
+ if (ext_csd_struct > 2) {
|
|
|
+ printk(KERN_ERR "%s: unrecognised EXT_CSD structure "
|
|
|
+ "version %d\n", mmc_hostname(card->host),
|
|
|
+ ext_csd_struct);
|
|
|
+ err = -EINVAL;
|
|
|
+ goto out;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
card->ext_csd.rev = ext_csd[EXT_CSD_REV];
|
|
|
if (card->ext_csd.rev > 5) {
|
|
|
- printk(KERN_ERR "%s: unrecognised EXT_CSD structure "
|
|
|
- "version %d\n", mmc_hostname(card->host),
|
|
|
- card->ext_csd.rev);
|
|
|
+ printk(KERN_ERR "%s: unrecognised EXT_CSD revision %d\n",
|
|
|
+ mmc_hostname(card->host), card->ext_csd.rev);
|
|
|
err = -EINVAL;
|
|
|
goto out;
|
|
|
}
|