The legacy ecc layout is to use all the OOB area by computing the ecc strength and ecc step size ourselves. The patch "2febcdf mtd: gpmi: set the BCHs geometry with the ecc info" makes the gpmi to use the ECC info(ecc strength and ecc step size) provided by the MTD code, and creates a different NAND ecc layout for the BCH , and use the new ecc layout, this brings a regression to us: We can not mount the ubifs which was created by the old NAND ecc layout. This patch fixes this issue by use the legacy ecc layout firstly, if it fails we try to use the new ecc layout. Signed-off-by: Huang Shijie <b32955@xxxxxxxxxxxxx> Cc: stable@xxxxxxxxxxxxxxx --- v1 --> v2: [0] remove the DT binding. --- drivers/mtd/nand/gpmi-nand/gpmi-nand.c | 2 +- 1 files changed, 1 insertions(+), 1 deletions(-) diff --git a/drivers/mtd/nand/gpmi-nand/gpmi-nand.c b/drivers/mtd/nand/gpmi-nand/gpmi-nand.c index 6807d7c..f9ee7e5 100644 --- a/drivers/mtd/nand/gpmi-nand/gpmi-nand.c +++ b/drivers/mtd/nand/gpmi-nand/gpmi-nand.c @@ -352,7 +352,7 @@ static int legacy_set_geometry(struct gpmi_nand_data *this) int common_nfc_set_geometry(struct gpmi_nand_data *this) { - return set_geometry_by_ecc_info(this) ? 0 : legacy_set_geometry(this); + return legacy_set_geometry(this) ? set_geometry_by_ecc_info(this) : 0; } struct dma_chan *get_dma_chan(struct gpmi_nand_data *this) -- 1.7.2.rc3 -- To unsubscribe from this list: send the line "unsubscribe stable" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html