[PATCH 1/2 v2] mtd/nand: fixup for fmr initialization of Freescale NAND controller
Liu Shengzhou-B36685
B36685 at freescale.com
Wed Dec 7 22:36:19 EST 2011
> -----Original Message-----
> From: Wood Scott-B07421
> Sent: Thursday, December 08, 2011 1:17 AM
> To: Liu Shengzhou-B36685
> Cc: Wood Scott-B07421; 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/07/2011 12:30 AM, Liu Shengzhou-B36685 wrote:
> >
> >> -----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.
>
> It does change it. It used to use the existing value in FMR, and now it
> sets it based on ORn[PGS].
>
> -Scott
[Shengzhou]
In u-boot:
#ifdef CONFIG_FSL_ELBC_FMR
priv->fmr = CONFIG_FSL_ELBC_FMR;
#else
priv->fmr = (15 << FMR_CWTO_SHIFT) | (2 << FMR_AL_SHIFT);
or = in_be32(&elbc_ctrl->regs->bank[priv->bank].or);
if (or & OR_FCM_PGS)
priv->fmr |= FMR_ECCM;
#endif
In kernel: It used to be " priv->fmr = in_be32(&lbc->fmr) & FMR_ECCM ", so fmr was always 0x100(or 0,depend on ORn[PGS]), CWTO was 0(timeout was minimum). In this patch, for not relying on bootloader, fmr is initialized as what u-boot does, except FMR_AL_SHIFT is handled in fsl_elbc_chip_init_tail and without definition of CONFIG_FSL_ELBC_FMR.
So, it doesn't change it. Do we still need CONFIG_FSL_ELBC_FMR in kernel?
More information about the linux-mtd
mailing list