[PATCH 1/2 v2] mtd/nand: fixup for fmr initialization of Freescale NAND controller
Liu Shengzhou-B36685
B36685 at freescale.com
Wed Dec 7 01:30:21 EST 2011
> -----Original Message-----
> From: Wood Scott-B07421
> Sent: Wednesday, December 07, 2011 1:16 AM
> To: Liu Shengzhou-B36685
> Cc: linuxppc-dev at lists.ozlabs.org; linux-mtd at lists.infradead.org;
> dwmw2 at infradead.org; Gala Kumar-B11780
> Subject: Re: [PATCH 1/2 v2] mtd/nand: fixup for fmr initialization of
> Freescale NAND controller
>
> On 12/06/2011 02:54 AM, Shengzhou Liu wrote:
> > There was a bug for fmr initialization, which lead to fmr was always
> > 0x100 in fsl_elbc_chip_init() and caused FCM command timeout before
> > calling fsl_elbc_chip_init_tail(), now we initialize CWTO to maximum
> > timeout value and not relying on the setting of bootloader.
> >
> > Signed-off-by: Shengzhou Liu <Shengzhou.Liu at freescale.com>
> > ---
> > v2: make fmr not relying on the setting of bootloader.
> >
> > drivers/mtd/nand/fsl_elbc_nand.c | 10 +++++-----
> > 1 files changed, 5 insertions(+), 5 deletions(-)
> >
> > diff --git a/drivers/mtd/nand/fsl_elbc_nand.c
> > b/drivers/mtd/nand/fsl_elbc_nand.c
> > index eedd8ee..4f405a0 100644
> > --- a/drivers/mtd/nand/fsl_elbc_nand.c
> > +++ b/drivers/mtd/nand/fsl_elbc_nand.c
> > @@ -659,9 +659,7 @@ static int fsl_elbc_chip_init_tail(struct mtd_info
> *mtd)
> > if (chip->pagemask & 0xff000000)
> > al++;
> >
> > - /* add to ECCM mode set in fsl_elbc_init */
> > - priv->fmr |= (12 << FMR_CWTO_SHIFT) | /* Timeout > 12 ms */
> > - (al << FMR_AL_SHIFT);
> > + priv->fmr |= al << FMR_AL_SHIFT;
> >
> > dev_dbg(priv->dev, "fsl_elbc_init: nand->numchips = %d\n",
> > chip->numchips);
> > @@ -764,8 +762,10 @@ static int fsl_elbc_chip_init(struct fsl_elbc_mtd
> *priv)
> > priv->mtd.priv = chip;
> > priv->mtd.owner = THIS_MODULE;
> >
> > - /* Set the ECCM according to the settings in bootloader.*/
> > - priv->fmr = in_be32(&lbc->fmr) & FMR_ECCM;
> > + /* set timeout to maximum */
> > + priv->fmr = 15 << FMR_CWTO_SHIFT;
> > + if (in_be32(&lbc->bank[priv->bank].or) & OR_FCM_PGS)
> > + priv->fmr |= FMR_ECCM;
>
> Please do not change the way ECCM is handled. We probably should have
> done it this way from the start, but at this point it breaks
> compatibility if you have a large page flash and the firmware didn't
> touch NAND.
>
> -Scott
[Shengzhou] This patch doesn't change the way ECCM is handled, it's still same as before, just make sure CWTO timeout is set to maximum.
More information about the linux-mtd
mailing list