From: Yoshihiro Shimoda Date: Mon, 4 Jul 2011 22:13:26 +0000 (+0000) Subject: mmc: fix the condition for MMC version 4 X-Git-Tag: v2025.01-rc5-pxa1908~19258^2~4 X-Git-Url: http://git.dujemihanovic.xyz/img/sics.gif?a=commitdiff_plain;h=639b7827d1caf28801775e222fe1d1dedece58f0;p=u-boot.git mmc: fix the condition for MMC version 4 Fix the problem that if we use the chip of MMC version 4 and the capacity is smaller than 2GB or equal, the mmc->capacity is invalid. According to the JEDEC Standard, the value of ext_csd's capacity is valid if the value is more than 2GB. Signed-off-by: Yoshihiro Shimoda Acked-by: Andy Fleming --- diff --git a/drivers/mmc/mmc.c b/drivers/mmc/mmc.c index 9a1ee3d398..4e4e0fb0f3 100644 --- a/drivers/mmc/mmc.c +++ b/drivers/mmc/mmc.c @@ -853,7 +853,7 @@ int mmc_startup(struct mmc *mmc) { int err; uint mult, freq; - u64 cmult, csize; + u64 cmult, csize, capacity; struct mmc_cmd cmd; char ext_csd[512]; int timeout = 1000; @@ -1002,9 +1002,16 @@ int mmc_startup(struct mmc *mmc) /* check ext_csd version and capacity */ err = mmc_send_ext_csd(mmc, ext_csd); if (!err & (ext_csd[192] >= 2)) { - mmc->capacity = ext_csd[212] << 0 | ext_csd[213] << 8 | - ext_csd[214] << 16 | ext_csd[215] << 24; - mmc->capacity *= 512; + /* + * According to the JEDEC Standard, the value of + * ext_csd's capacity is valid if the value is more + * than 2GB + */ + capacity = ext_csd[212] << 0 | ext_csd[213] << 8 | + ext_csd[214] << 16 | ext_csd[215] << 24; + capacity *= 512; + if (capacity > 2 * 1024 * 1024 * 1024) + mmc->capacity = capacity; } /*