diff options
author | Ezequiel Garcia <ezequiel.garcia@free-electrons.com> | 2014-03-21 07:57:44 -0400 |
---|---|---|
committer | Brian Norris <computersforpeace@gmail.com> | 2014-07-08 21:38:29 -0400 |
commit | fdf43a420f5c2b737b0e65c4c3330867903b098a (patch) | |
tree | 949c3ed52b3355b0b0c39a4a971e7ef7bf9d2ba5 /drivers/mtd | |
parent | 8471bb73ba10ed6788b4f1e9b8a0f9dc6bdb05b5 (diff) |
mtd: Account for BBT blocks when a partition is being allocated
With the introduction of mtd_block_isreserved(), it's now possible
to fix the bad and reserved block distribution exposed by ecc_stats,
instead of accounting all the bad or reserved blocks as 'bad'.
Signed-off-by: Ezequiel Garcia <ezequiel.garcia@free-electrons.com>
Tested-by: Pekon Gupta <pekon@ti.com>
Signed-off-by: Brian Norris <computersforpeace@gmail.com>
Diffstat (limited to 'drivers/mtd')
-rw-r--r-- | drivers/mtd/mtdpart.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/mtd/mtdpart.c b/drivers/mtd/mtdpart.c index 921e8c647884..a3e3a7d074d5 100644 --- a/drivers/mtd/mtdpart.c +++ b/drivers/mtd/mtdpart.c | |||
@@ -535,7 +535,9 @@ static struct mtd_part *allocate_partition(struct mtd_info *master, | |||
535 | uint64_t offs = 0; | 535 | uint64_t offs = 0; |
536 | 536 | ||
537 | while (offs < slave->mtd.size) { | 537 | while (offs < slave->mtd.size) { |
538 | if (mtd_block_isbad(master, offs + slave->offset)) | 538 | if (mtd_block_isreserved(master, offs + slave->offset)) |
539 | slave->mtd.ecc_stats.bbtblocks++; | ||
540 | else if (mtd_block_isbad(master, offs + slave->offset)) | ||
539 | slave->mtd.ecc_stats.badblocks++; | 541 | slave->mtd.ecc_stats.badblocks++; |
540 | offs += slave->mtd.erasesize; | 542 | offs += slave->mtd.erasesize; |
541 | } | 543 | } |