aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJonas Gorski <jonas.gorski@gmail.com>2012-11-12 04:52:49 -0500
committerArtem Bityutskiy <artem.bityutskiy@linux.intel.com>2012-11-21 10:15:05 -0500
commit4e4fb63955650e39ccfbd376733fa258adfb1e5d (patch)
tree6a869b51a6b156119ebd4b256c5fc04497e41f6f
parente190401ba1ca20d76f22c1f0aada0abd5bdc1afe (diff)
mtd: bcm63xxpart: make fixed part length calculation more generic
The CFE does not use 4K sectors even if the flash supports it, so for the fixed partitions like CFE itself or NVRAM the erase block size is always 64k or bigger. Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com> Reviewed-by: Florian Fainelli <florian@openwrt.org> Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
-rw-r--r--drivers/mtd/bcm63xxpart.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/drivers/mtd/bcm63xxpart.c b/drivers/mtd/bcm63xxpart.c
index ba7eeb874b31..b3db8e35a236 100644
--- a/drivers/mtd/bcm63xxpart.c
+++ b/drivers/mtd/bcm63xxpart.c
@@ -37,8 +37,7 @@
37 37
38#define BCM63XX_EXTENDED_SIZE 0xBFC00000 /* Extended flash address */ 38#define BCM63XX_EXTENDED_SIZE 0xBFC00000 /* Extended flash address */
39 39
40#define BCM63XX_MIN_CFE_SIZE 0x10000 /* always at least 64KiB */ 40#define BCM63XX_CFE_BLOCK_SIZE 0x10000 /* always at least 64KiB */
41#define BCM63XX_MIN_NVRAM_SIZE 0x10000 /* always at least 64KiB */
42 41
43#define BCM63XX_CFE_MAGIC_OFFSET 0x4e0 42#define BCM63XX_CFE_MAGIC_OFFSET 0x4e0
44 43
@@ -79,6 +78,7 @@ static int bcm63xx_parse_cfe_partitions(struct mtd_info *master,
79 unsigned int rootfsaddr, kerneladdr, spareaddr; 78 unsigned int rootfsaddr, kerneladdr, spareaddr;
80 unsigned int rootfslen, kernellen, sparelen, totallen; 79 unsigned int rootfslen, kernellen, sparelen, totallen;
81 unsigned int cfelen, nvramlen; 80 unsigned int cfelen, nvramlen;
81 unsigned int cfe_erasesize;
82 int i; 82 int i;
83 u32 computed_crc; 83 u32 computed_crc;
84 bool rootfs_first = false; 84 bool rootfs_first = false;
@@ -86,8 +86,11 @@ static int bcm63xx_parse_cfe_partitions(struct mtd_info *master,
86 if (bcm63xx_detect_cfe(master)) 86 if (bcm63xx_detect_cfe(master))
87 return -EINVAL; 87 return -EINVAL;
88 88
89 cfelen = max_t(uint32_t, master->erasesize, BCM63XX_MIN_CFE_SIZE); 89 cfe_erasesize = max_t(uint32_t, master->erasesize,
90 nvramlen = max_t(uint32_t, master->erasesize, BCM63XX_MIN_NVRAM_SIZE); 90 BCM63XX_CFE_BLOCK_SIZE);
91
92 cfelen = cfe_erasesize;
93 nvramlen = cfe_erasesize;
91 94
92 /* Allocate memory for buffer */ 95 /* Allocate memory for buffer */
93 buf = vmalloc(sizeof(struct bcm_tag)); 96 buf = vmalloc(sizeof(struct bcm_tag));