]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
mtd: nand: pxa3xx: Incorrect bitflip return on page read
authorRavi Minnikanti <rminnikanti@marvell.com>
Sat, 27 Apr 2024 16:15:28 +0000 (09:15 -0700)
committerDario Binacchi <dario.binacchi@amarulasolutions.com>
Mon, 17 Jun 2024 07:43:45 +0000 (09:43 +0200)
Once a page is read with higher bitflips all subsequent reads
are returning the same bitflip value even though they have none.
max_bitflip variable is not being reset to 0 across page reads.

This is causing problems like incorrectly
marking erase blocks bad by UBI and causing read failures.

Verified the change with both MTD reads and UBI.
This change is inline with other NFC drivers.

Sample error log where a block is marked bad incorrectly:

ubi0: fixable bit-flip detected at PEB 125
ubi0: run torture test for PEB 125
ubi0: fixable bit-flip detected at PEB 125
ubi0 error: torture_peb: read problems on freshly erased PEB 125,
must be bad
ubi0 error: erase_worker: failed to erase PEB 125, error -5
ubi0: mark PEB 125 as bad

Link: https://lore.kernel.org/all/ea0422cd-a8e6-3c36-f551-a0142893301b@marvell.com
Signed-off-by: rminnikanti <rminnikanti@marvell.com>
Reviewed-by: Chris Packham <judge.packham@gmail.com>
Signed-off-by: rminnikanti <rminnikanti@marvell.com>
Acked-by: Michael Trimarchi <michael@amarulasolutions.com>
Signed-off-by: Dario Binacchi <dario.binacchi@amarulasolutions.com>
drivers/mtd/nand/raw/pxa3xx_nand.c

index 1d9a6d107b17925a89ef706b81210a4993153baf..d2a4faad562dee11a1fb92214018cba0e9db47b0 100644 (file)
@@ -800,6 +800,11 @@ static void prepare_start_command(struct pxa3xx_nand_info *info, int command)
        info->ecc_err_cnt       = 0;
        info->ndcb3             = 0;
        info->need_wait         = 0;
+       /*
+        * Reset max_bitflips to zero. Once command is complete,
+        * max_bitflips for this READ is returned in ecc.read_page()
+        */
+       info->max_bitflips      = 0;
 
        switch (command) {
        case NAND_CMD_READ0: