mtd: nand: correct extemded param page error handling

Linux-MTD Mailing List linux-mtd at lists.infradead.org
Wed Nov 13 13:59:02 EST 2013


Gitweb:     http://git.infradead.org/?p=mtd-2.6.git;a=commit;h=4ae7d228d6048d25a16bee209ebea24c5ecde825
Commit:     4ae7d228d6048d25a16bee209ebea24c5ecde825
Parent:     2a3d933a46e9948e01fc34348bed0baec8d8bf2b
Author:     Brian Norris <computersforpeace at gmail.com>
AuthorDate: Mon Sep 16 18:20:21 2013 -0700
Committer:  Brian Norris <computersforpeace at gmail.com>
CommitDate: Sun Oct 27 16:27:04 2013 -0700

    mtd: nand: correct extemded param page error handling
    
    If the ONFI extended parameter page gives codeword_size == 0, the
    extended ECC information is corrupt and should not be used. Currently,
    we (correctly) avoid using the information, but we don't report the
    error to the caller, so the caller doesn't know that we didn't
    initialize ecc_strength_ds and ecc_step_ds. Now the caller can warn the
    user that it does not have sufficient information.
    
    This also removes the false and useless "ONFI extended param page
    detected" debug message (it was printed even on the aforementioned
    corruption, and for the success case, we don't really want a print).
    
    Signed-off-by: Brian Norris <computersforpeace at gmail.com>
    Acked-by: Huang Shijie <b32955 at freescale.com>
---
 drivers/mtd/nand/nand_base.c | 9 +++++----
 1 file changed, 5 insertions(+), 4 deletions(-)

diff --git a/drivers/mtd/nand/nand_base.c b/drivers/mtd/nand/nand_base.c
index 00022b4..0b39d0c 100644
--- a/drivers/mtd/nand/nand_base.c
+++ b/drivers/mtd/nand/nand_base.c
@@ -2912,12 +2912,13 @@ static int nand_flash_detect_ext_param_page(struct mtd_info *mtd,
 	/* get the info we want. */
 	ecc = (struct onfi_ext_ecc_info *)cursor;
 
-	if (ecc->codeword_size) {
-		chip->ecc_strength_ds = ecc->ecc_bits;
-		chip->ecc_step_ds = 1 << ecc->codeword_size;
+	if (!ecc->codeword_size) {
+		pr_debug("Invalid codeword size\n");
+		goto ext_out;
 	}
 
-	pr_info("ONFI extended param page detected.\n");
+	chip->ecc_strength_ds = ecc->ecc_bits;
+	chip->ecc_step_ds = 1 << ecc->codeword_size;
 	ret = 0;
 
 ext_out:



More information about the linux-mtd-cvs mailing list