Hi Pekon,

On Fri, Feb 14, 2014 at 10:31:46PM +0530, Pekon Gupta wrote:
> 1) In current implementation, ecclayout->oobfree->offset is calculated with
>  respect to ecclayout->eccpos[0] which is incorrect because ECC bytes may not
>  be stored contiguously in OOB.
>  So, this patch calculates ecclayout->oobfree->offset with respect to last
>  ECC byte-position 'eccpos[ecclayout->eccbytes-1]'.
> 
> 2) ECC layout of some ecc-schemes expects reserved-markers at specific 
> eccpos[]
>  which should not be over-written by any file-system metadata.
>  So this patch aligns oobfree->offset taking into account of such markers.

This is a much better description, and this series is looking a lot more
straightforward now. Thanks. A quick comment below, and I'll spend some
more time looking later.

(BTW, can you mark these for -stable, version 3.13+ if/when you resend?
Or else I'll mark it myself, I think.)

> Tested-by: Enric Balletbo i Serra <eballe...@gmail.com>
> Tested-by: Stefan Roese <s...@denx.de>
> Signed-off-by: Pekon Gupta <pe...@ti.com>
> ---
>  drivers/mtd/nand/omap2.c | 25 +++++++++++++++----------
>  1 file changed, 15 insertions(+), 10 deletions(-)
> 
> diff --git a/drivers/mtd/nand/omap2.c b/drivers/mtd/nand/omap2.c
> index ef4190a..874fd9d 100644
> --- a/drivers/mtd/nand/omap2.c
> +++ b/drivers/mtd/nand/omap2.c
> @@ -1829,8 +1829,9 @@ static int omap_nand_probe(struct platform_device *pdev)
>                       ecclayout->eccpos[0]    = BADBLOCK_MARKER_LENGTH;
>               else
>                       ecclayout->eccpos[0]    = 1;
> -             ecclayout->oobfree->offset      = ecclayout->eccpos[0] +
> -                                                     ecclayout->eccbytes;
> +             /* no reserved-marker in ecclayout for this ecc-scheme */
> +             ecclayout->oobfree->offset      =
> +                             ecclayout->eccpos[ecclayout->eccbytes - 1] + 1;

Thanks for adjusting for 'eccbytes - 1'. This diff *would* be correct,
except that you're only initializing eccpos[1 .. eccbytes-1] in a for
loop after the switch-case block. It seems like this first patch
actually depends on patch 3, where you move the initialization of the
entire eccpos[] array into each 'case' block. e.g.:

@@ -1826,9 +1827,11 @@ static int omap_nand_probe(struct platform_device *pdev)
                                                        (mtd->writesize /
                                                        nand_chip->ecc.size);
                if (nand_chip->options & NAND_BUSWIDTH_16)
-                       ecclayout->eccpos[0]    = BADBLOCK_MARKER_LENGTH;
+                       oob_index               = BADBLOCK_MARKER_LENGTH;
                else
-                       ecclayout->eccpos[0]    = 1;
+                       oob_index               = 1;
+               for (i = 0; i < ecclayout->eccbytes; i++, oob_index++)
+                       ecclayout->eccpos[i]    = oob_index;

So, can you rearrange this series so patch 3 comes first?

> @@ -1848,8 +1849,9 @@ static int omap_nand_probe(struct platform_device *pdev)
>                                                       (mtd->writesize /
>                                                       nand_chip->ecc.size);
>               ecclayout->eccpos[0]            = BADBLOCK_MARKER_LENGTH;
> -             ecclayout->oobfree->offset      = ecclayout->eccpos[0] +
> -                                                     ecclayout->eccbytes;
> +             /* include reserved-marker in ecclayout->oobfree calculation */
> +             ecclayout->oobfree->offset      = 1 +
> +                             ecclayout->eccpos[ecclayout->eccbytes - 1] + 1;
>               /* software bch library is used for locating errors */
>               nand_chip->ecc.priv             = nand_bch_init(mtd,
>                                                       nand_chip->ecc.size,
> @@ -1884,8 +1886,9 @@ static int omap_nand_probe(struct platform_device *pdev)
>                                                       (mtd->writesize /
>                                                       nand_chip->ecc.size);
>               ecclayout->eccpos[0]            = BADBLOCK_MARKER_LENGTH;
> -             ecclayout->oobfree->offset      = ecclayout->eccpos[0] +
> -                                                     ecclayout->eccbytes;
> +             /* reserved marker already included in ecclayout->eccbytes */
> +             ecclayout->oobfree->offset      =
> +                             ecclayout->eccpos[ecclayout->eccbytes - 1] + 1;
>               /* This ECC scheme requires ELM H/W block */
>               if (is_elm_present(info, pdata->elm_of_node, BCH4_ECC) < 0) {
>                       pr_err("nand: error: could not initialize ELM\n");
> @@ -1914,8 +1917,9 @@ static int omap_nand_probe(struct platform_device *pdev)
>                                                       (mtd->writesize /
>                                                       nand_chip->ecc.size);
>               ecclayout->eccpos[0]            = BADBLOCK_MARKER_LENGTH;
> -             ecclayout->oobfree->offset      = ecclayout->eccpos[0] +
> -                                                     ecclayout->eccbytes;
> +             /* include reserved-marker in ecclayout->oobfree calculation */
> +             ecclayout->oobfree->offset      = 1 +
> +                             ecclayout->eccpos[ecclayout->eccbytes - 1] + 1;
>               /* software bch library is used for locating errors */
>               nand_chip->ecc.priv             = nand_bch_init(mtd,
>                                                       nand_chip->ecc.size,
> @@ -1957,8 +1961,9 @@ static int omap_nand_probe(struct platform_device *pdev)
>                                                       (mtd->writesize /
>                                                       nand_chip->ecc.size);
>               ecclayout->eccpos[0]            = BADBLOCK_MARKER_LENGTH;
> -             ecclayout->oobfree->offset      = ecclayout->eccpos[0] +
> -                                                     ecclayout->eccbytes;
> +             /* reserved marker already included in ecclayout->eccbytes */
> +             ecclayout->oobfree->offset      =
> +                             ecclayout->eccpos[ecclayout->eccbytes - 1] + 1;
>               break;
>  #else
>               pr_err("nand: error: CONFIG_MTD_NAND_OMAP_BCH not enabled\n");

Brian
_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
http://lists.denx.de/mailman/listinfo/u-boot

Reply via email to