mtd: Account for BBT blocks when a partition is being allocated
[firefly-linux-kernel-4.4.55.git] / drivers / mtd / mtdpart.c
index 921e8c647884f1bbf1bcfa5aad2238842e37b95e..a3e3a7d074d5c7b246aed2bebdd2ed25feba16f9 100644 (file)
@@ -535,7 +535,9 @@ static struct mtd_part *allocate_partition(struct mtd_info *master,
                uint64_t offs = 0;
 
                while (offs < slave->mtd.size) {
-                       if (mtd_block_isbad(master, offs + slave->offset))
+                       if (mtd_block_isreserved(master, offs + slave->offset))
+                               slave->mtd.ecc_stats.bbtblocks++;
+                       else if (mtd_block_isbad(master, offs + slave->offset))
                                slave->mtd.ecc_stats.badblocks++;
                        offs += slave->mtd.erasesize;
                }