Revert "mmc: subtract boot sectors from disk size for eMMC 4.3+ devices"
authorColin Cross <ccross@android.com>
Sat, 12 Feb 2011 21:21:32 +0000 (13:21 -0800)
committerColin Cross <ccross@android.com>
Sat, 12 Feb 2011 21:24:26 +0000 (13:24 -0800)
This reverts commit f0b0e4bec1e89014f3dcef4da8bcf95428cc771c.

The reverted commit incorrectly calculates the size of eMMC
devices in some (all?) cases.

This revert may cause problems in cases where the bootloader was
bug-compatible and puts a GPT partition at the incorrect end of
the eMMC device.

Change-Id: Ib006acf9e517b3b8f7570220c28e19c91e7b5f25
Signed-off-by: Colin Cross <ccross@android.com>
drivers/mmc/core/mmc.c
include/linux/mmc/mmc.h

index 45055c46d954957be5a49196c80be2b21ae6c7a3..6909a54c39beac1a8ca277f317f43c4a4ea9d583 100644 (file)
@@ -253,13 +253,8 @@ static int mmc_read_ext_csd(struct mmc_card *card)
                        ext_csd[EXT_CSD_SEC_CNT + 3] << 24;
 
                /* Cards with density > 2GiB are sector addressed */
-               if (card->ext_csd.sectors > (2u * 1024 * 1024 * 1024) / 512) {
-                       unsigned boot_sectors;
-                       /* size is in 256K chunks, i.e. 512 sectors each */
-                       boot_sectors = ext_csd[EXT_CSD_BOOT_SIZE_MULTI] * 512;
-                       card->ext_csd.sectors -= boot_sectors;
+               if (card->ext_csd.sectors > (2u * 1024 * 1024 * 1024) / 512)
                        mmc_card_set_blockaddr(card);
-               }
        }
 
        switch (ext_csd[EXT_CSD_CARD_TYPE] & EXT_CSD_CARD_TYPE_MASK) {
index 1041cf5220f6d05c51dc8b702849e8a618dcd768..dd11ae51fb68e8b847300a5fe78ac049c9ef8605 100644 (file)
@@ -266,7 +266,6 @@ struct _mmc_csd {
 #define EXT_CSD_SEC_ERASE_MULT         230     /* RO */
 #define EXT_CSD_SEC_FEATURE_SUPPORT    231     /* RO */
 #define EXT_CSD_TRIM_MULT              232     /* RO */
-#define EXT_CSD_BOOT_SIZE_MULTI                226     /* RO */
 
 /*
  * EXT_CSD field definitions