Huang Shijie
2013-10-24 08:14:44 UTC
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 <***@freescale.com>
Cc: ***@vger.kernel.org
---
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)
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 <***@freescale.com>
Cc: ***@vger.kernel.org
---
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
1.7.2.rc3