aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/mtd
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/mtd')
-rw-r--r--drivers/mtd/nand/nand_bbt.c37
1 files changed, 3 insertions, 34 deletions
diff --git a/drivers/mtd/nand/nand_bbt.c b/drivers/mtd/nand/nand_bbt.c
index c75b6a7c6ea4..c0615d1526f9 100644
--- a/drivers/mtd/nand/nand_bbt.c
+++ b/drivers/mtd/nand/nand_bbt.c
@@ -412,25 +412,6 @@ static void read_abs_bbts(struct mtd_info *mtd, uint8_t *buf,
412 } 412 }
413} 413}
414 414
415/* Scan a given block full */
416static int scan_block_full(struct mtd_info *mtd, struct nand_bbt_descr *bd,
417 loff_t offs, uint8_t *buf, size_t readlen,
418 int scanlen, int numpages)
419{
420 int ret, j;
421
422 ret = scan_read_oob(mtd, buf, offs, readlen);
423 /* Ignore ECC errors when checking for BBM */
424 if (ret && !mtd_is_bitflip_or_eccerr(ret))
425 return ret;
426
427 for (j = 0; j < numpages; j++, buf += scanlen) {
428 if (check_pattern(buf, scanlen, mtd->writesize, bd))
429 return 1;
430 }
431 return 0;
432}
433
434/* Scan a given block partially */ 415/* Scan a given block partially */
435static int scan_block_fast(struct mtd_info *mtd, struct nand_bbt_descr *bd, 416static int scan_block_fast(struct mtd_info *mtd, struct nand_bbt_descr *bd,
436 loff_t offs, uint8_t *buf, int numpages) 417 loff_t offs, uint8_t *buf, int numpages)
@@ -477,24 +458,17 @@ static int create_bbt(struct mtd_info *mtd, uint8_t *buf,
477 struct nand_bbt_descr *bd, int chip) 458 struct nand_bbt_descr *bd, int chip)
478{ 459{
479 struct nand_chip *this = mtd->priv; 460 struct nand_chip *this = mtd->priv;
480 int i, numblocks, numpages, scanlen; 461 int i, numblocks, numpages;
481 int startblock; 462 int startblock;
482 loff_t from; 463 loff_t from;
483 size_t readlen;
484 464
485 pr_info("Scanning device for bad blocks\n"); 465 pr_info("Scanning device for bad blocks\n");
486 466
487 if (bd->options & NAND_BBT_SCANALLPAGES) 467 if (bd->options & NAND_BBT_SCAN2NDPAGE)
488 numpages = 1 << (this->bbt_erase_shift - this->page_shift);
489 else if (bd->options & NAND_BBT_SCAN2NDPAGE)
490 numpages = 2; 468 numpages = 2;
491 else 469 else
492 numpages = 1; 470 numpages = 1;
493 471
494 /* We need only read few bytes from the OOB area */
495 scanlen = 0;
496 readlen = bd->len;
497
498 if (chip == -1) { 472 if (chip == -1) {
499 numblocks = mtd->size >> this->bbt_erase_shift; 473 numblocks = mtd->size >> this->bbt_erase_shift;
500 startblock = 0; 474 startblock = 0;
@@ -519,12 +493,7 @@ static int create_bbt(struct mtd_info *mtd, uint8_t *buf,
519 493
520 BUG_ON(bd->options & NAND_BBT_NO_OOB); 494 BUG_ON(bd->options & NAND_BBT_NO_OOB);
521 495
522 if (bd->options & NAND_BBT_SCANALLPAGES) 496 ret = scan_block_fast(mtd, bd, from, buf, numpages);
523 ret = scan_block_full(mtd, bd, from, buf, readlen,
524 scanlen, numpages);
525 else
526 ret = scan_block_fast(mtd, bd, from, buf, numpages);
527
528 if (ret < 0) 497 if (ret < 0)
529 return ret; 498 return ret;
530 499