mtd: nand: omap_gpmc: fix error handling
authorGuido Martínez <guido@vanguardiasur.com.ar>
Fri, 2 Jan 2015 17:49:10 +0000 (14:49 -0300)
committerTom Rini <trini@ti.com>
Mon, 5 Jan 2015 21:40:18 +0000 (16:40 -0500)
"err" was an unsigned variable, causing negative error codes to turn
into positive values, which are interpreted as an amount of succesfully
corrected bitflips (and thus not an error).

In particular, this resulted in that if the elm reports uncorrectable
errors (-EBADMSG), the MTD layer (and UBI) falsely succeeded.

Signed-off-by: Guido Martínez <guido@vanguardiasur.com.ar>
Reviewed-by: Stefan Roese <sr@denx.de>
drivers/mtd/nand/omap_gpmc.c

index 93829a40b6dc698b25fa1193326e1df80393516f..459904d81c21a2356e353c642ef065151006c257 100644 (file)
@@ -368,8 +368,9 @@ static int omap_correct_data_bch(struct mtd_info *mtd, uint8_t *dat,
        uint32_t error_loc[ELM_MAX_ERROR_COUNT];
        enum bch_level bch_type;
        uint32_t i, ecc_flag = 0;
-       uint8_t count, err = 0;
+       uint8_t count;
        uint32_t byte_pos, bit_pos;
+       int err = 0;
 
        /* check calculated ecc */
        for (i = 0; i < ecc->bytes && !ecc_flag; i++) {