diff options
author | Adrian Hunter <adrian.hunter@nokia.com> | 2010-12-10 05:04:20 -0500 |
---|---|---|
committer | David Woodhouse <David.Woodhouse@intel.com> | 2011-01-06 10:23:10 -0500 |
commit | e0c1a921f62d22d1aa62c72ddb793f898945ff5a (patch) | |
tree | aee490559dfea9e103f6880dc7b022fdf549d37b | |
parent | 263a8c8635445c0ede3cb22c98a1a12da4672ebc (diff) |
mtd: OneNAND: lighten scary initial bad block messages
Initial bad blocks are normal but the messages look like
errors. Make the messages less scary, make the main
message an informational message not a warning, make the
message displaying registers a debug message and include
the address there instead of in the informational message.
Signed-off-by: Adrian Hunter <adrian.hunter@nokia.com>
Acked-by: Kyungmin Park <kyungmin.park@samsung.com>
Signed-off-by: Artem Bityutskiy <Artem.Bityutskiy@nokia.com>
Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
-rw-r--r-- | drivers/mtd/onenand/onenand_base.c | 22 | ||||
-rw-r--r-- | drivers/mtd/onenand/onenand_bbt.c | 4 |
2 files changed, 14 insertions, 12 deletions
diff --git a/drivers/mtd/onenand/onenand_base.c b/drivers/mtd/onenand/onenand_base.c index 88f23e3f3014..2d7c90de3144 100644 --- a/drivers/mtd/onenand/onenand_base.c +++ b/drivers/mtd/onenand/onenand_base.c | |||
@@ -1484,8 +1484,7 @@ static int onenand_bbt_wait(struct mtd_info *mtd, int state) | |||
1484 | { | 1484 | { |
1485 | struct onenand_chip *this = mtd->priv; | 1485 | struct onenand_chip *this = mtd->priv; |
1486 | unsigned long timeout; | 1486 | unsigned long timeout; |
1487 | unsigned int interrupt; | 1487 | unsigned int interrupt, ctrl, ecc, addr1, addr8; |
1488 | unsigned int ctrl; | ||
1489 | 1488 | ||
1490 | /* The 20 msec is enough */ | 1489 | /* The 20 msec is enough */ |
1491 | timeout = jiffies + msecs_to_jiffies(20); | 1490 | timeout = jiffies + msecs_to_jiffies(20); |
@@ -1497,25 +1496,28 @@ static int onenand_bbt_wait(struct mtd_info *mtd, int state) | |||
1497 | /* To get correct interrupt status in timeout case */ | 1496 | /* To get correct interrupt status in timeout case */ |
1498 | interrupt = this->read_word(this->base + ONENAND_REG_INTERRUPT); | 1497 | interrupt = this->read_word(this->base + ONENAND_REG_INTERRUPT); |
1499 | ctrl = this->read_word(this->base + ONENAND_REG_CTRL_STATUS); | 1498 | ctrl = this->read_word(this->base + ONENAND_REG_CTRL_STATUS); |
1499 | addr1 = this->read_word(this->base + ONENAND_REG_START_ADDRESS1); | ||
1500 | addr8 = this->read_word(this->base + ONENAND_REG_START_ADDRESS8); | ||
1500 | 1501 | ||
1501 | if (interrupt & ONENAND_INT_READ) { | 1502 | if (interrupt & ONENAND_INT_READ) { |
1502 | int ecc = onenand_read_ecc(this); | 1503 | ecc = onenand_read_ecc(this); |
1503 | if (ecc & ONENAND_ECC_2BIT_ALL) { | 1504 | if (ecc & ONENAND_ECC_2BIT_ALL) { |
1504 | printk(KERN_WARNING "%s: ecc error = 0x%04x, " | 1505 | printk(KERN_DEBUG "%s: ecc 0x%04x ctrl 0x%04x " |
1505 | "controller error 0x%04x\n", | 1506 | "intr 0x%04x addr1 %#x addr8 %#x\n", |
1506 | __func__, ecc, ctrl); | 1507 | __func__, ecc, ctrl, interrupt, addr1, addr8); |
1507 | return ONENAND_BBT_READ_ECC_ERROR; | 1508 | return ONENAND_BBT_READ_ECC_ERROR; |
1508 | } | 1509 | } |
1509 | } else { | 1510 | } else { |
1510 | printk(KERN_ERR "%s: read timeout! ctrl=0x%04x intr=0x%04x\n", | 1511 | printk(KERN_ERR "%s: read timeout! ctrl 0x%04x " |
1511 | __func__, ctrl, interrupt); | 1512 | "intr 0x%04x addr1 %#x addr8 %#x\n", |
1513 | __func__, ctrl, interrupt, addr1, addr8); | ||
1512 | return ONENAND_BBT_READ_FATAL_ERROR; | 1514 | return ONENAND_BBT_READ_FATAL_ERROR; |
1513 | } | 1515 | } |
1514 | 1516 | ||
1515 | /* Initial bad block case: 0x2400 or 0x0400 */ | 1517 | /* Initial bad block case: 0x2400 or 0x0400 */ |
1516 | if (ctrl & ONENAND_CTRL_ERROR) { | 1518 | if (ctrl & ONENAND_CTRL_ERROR) { |
1517 | printk(KERN_DEBUG "%s: controller error = 0x%04x\n", | 1519 | printk(KERN_DEBUG "%s: ctrl 0x%04x intr 0x%04x addr1 %#x " |
1518 | __func__, ctrl); | 1520 | "addr8 %#x\n", __func__, ctrl, interrupt, addr1, addr8); |
1519 | return ONENAND_BBT_READ_ERROR; | 1521 | return ONENAND_BBT_READ_ERROR; |
1520 | } | 1522 | } |
1521 | 1523 | ||
diff --git a/drivers/mtd/onenand/onenand_bbt.c b/drivers/mtd/onenand/onenand_bbt.c index 905209bf9465..fc2c16a0fd1c 100644 --- a/drivers/mtd/onenand/onenand_bbt.c +++ b/drivers/mtd/onenand/onenand_bbt.c | |||
@@ -101,8 +101,8 @@ static int create_bbt(struct mtd_info *mtd, uint8_t *buf, struct nand_bbt_descr | |||
101 | if (ret || check_short_pattern(&buf[j * scanlen], | 101 | if (ret || check_short_pattern(&buf[j * scanlen], |
102 | scanlen, this->writesize, bd)) { | 102 | scanlen, this->writesize, bd)) { |
103 | bbm->bbt[i >> 3] |= 0x03 << (i & 0x6); | 103 | bbm->bbt[i >> 3] |= 0x03 << (i & 0x6); |
104 | printk(KERN_WARNING "Bad eraseblock %d at 0x%08x\n", | 104 | printk(KERN_INFO "OneNAND eraseblock %d is an " |
105 | i >> 1, (unsigned int) from); | 105 | "initial bad block\n", i >> 1); |
106 | mtd->ecc_stats.badblocks++; | 106 | mtd->ecc_stats.badblocks++; |
107 | break; | 107 | break; |
108 | } | 108 | } |