From: Álvaro Fernández Rojas Date: Tue, 12 May 2020 07:57:32 +0000 (+0200) Subject: mtd: rawnand: brcmnand: fix hamming oob layout X-Git-Tag: rel_imx_5.10.35_2.0.0-somdevices.0~1957^2~5^2~111 X-Git-Url: https://git.somdevices.com/?a=commitdiff_plain;h=130bbde4809b011faf64f99dddc14b4b01f440c3;p=linux.git mtd: rawnand: brcmnand: fix hamming oob layout First 2 bytes are used in large-page nand. Fixes: ef5eeea6e911 ("mtd: nand: brcm: switch to mtd_ooblayout_ops") Cc: stable@vger.kernel.org Signed-off-by: Álvaro Fernández Rojas Signed-off-by: Miquel Raynal Link: https://lore.kernel.org/linux-mtd/20200512075733.745374-2-noltari@gmail.com --- diff --git a/drivers/mtd/nand/raw/brcmnand/brcmnand.c b/drivers/mtd/nand/raw/brcmnand/brcmnand.c index fe7cd3aa0cd6..cfd22023cfcb 100644 --- a/drivers/mtd/nand/raw/brcmnand/brcmnand.c +++ b/drivers/mtd/nand/raw/brcmnand/brcmnand.c @@ -1115,11 +1115,14 @@ static int brcmnand_hamming_ooblayout_free(struct mtd_info *mtd, int section, if (!section) { /* * Small-page NAND use byte 6 for BBI while large-page - * NAND use byte 0. + * NAND use bytes 0 and 1. */ - if (cfg->page_size > 512) - oobregion->offset++; - oobregion->length--; + if (cfg->page_size > 512) { + oobregion->offset += 2; + oobregion->length -= 2; + } else { + oobregion->length--; + } } }