Hi Stefan,

On 11/04/2018 18:04, Stefan Agner wrote:
> From: Stefan Agner <stefan.ag...@toradex.com>
> 
> Add support for minimum ECC strength supported by the NAND chip.
> This aligns with the behavior when using the fsl,use-minimum-ecc
> device tree property in Linux.
> 
> Signed-off-by: Stefan Agner <stefan.ag...@toradex.com>
> ---
> 
> Changes in v3: None
> Changes in v2: None
> 
>  drivers/mtd/nand/Kconfig    |  8 +++++
>  drivers/mtd/nand/mxs_nand.c | 71 +++++++++++++++++++++++++++++--------
>  2 files changed, 65 insertions(+), 14 deletions(-)
> 
> diff --git a/drivers/mtd/nand/Kconfig b/drivers/mtd/nand/Kconfig
> index 4db259fcb2..c039b9cc60 100644
> --- a/drivers/mtd/nand/Kconfig
> +++ b/drivers/mtd/nand/Kconfig
> @@ -152,6 +152,14 @@ config NAND_MXS
>         This enables NAND driver for the NAND flash controller on the
>         MXS processors.
>  
> +if NAND_MXS
> +
> +config NAND_MXS_USE_MINIMUM_ECC
> +     bool "Use minimum ECC strength supported by the controller"
> +     default false
> +
> +endif
> +
>  config NAND_ZYNQ
>       bool "Support for Zynq Nand controller"
>       select SYS_NAND_SELF_INIT
> diff --git a/drivers/mtd/nand/mxs_nand.c b/drivers/mtd/nand/mxs_nand.c
> index 2696b543ef..8305bf2302 100644
> --- a/drivers/mtd/nand/mxs_nand.c
> +++ b/drivers/mtd/nand/mxs_nand.c
> @@ -211,11 +211,52 @@ static inline int mxs_nand_calc_mark_offset(struct 
> bch_geometry *geo,
>       return 0;
>  }
>  
> +static inline unsigned int mxs_nand_max_ecc_strength_supported(void)
> +{
> +     /* Refer to Chapter 17 for i.MX6DQ, Chapter 18 for i.MX6SX */
> +     if (is_mx6sx() || is_mx7())
> +             return 62;
> +     else
> +             return 40;
> +}
> +
> +static inline int mxs_nand_calc_ecc_layout_by_info(struct bch_geometry *geo,
> +                                                struct mtd_info *mtd)
> +{
> +     struct nand_chip *chip = mtd_to_nand(mtd);
> +
> +     if (!(chip->ecc_strength_ds > 0 && chip->ecc_step_ds > 0))
> +             return -ENOTSUPP;
> +
> +     switch (chip->ecc_step_ds) {
> +     case SZ_512:
> +             geo->gf_len = 13;
> +             break;
> +     case SZ_1K:
> +             geo->gf_len = 14;
> +             break;
> +     default:
> +             return -EINVAL;
> +     }
> +
> +     geo->ecc_chunk_size = chip->ecc_step_ds;
> +     geo->ecc_strength = round_up(chip->ecc_strength_ds, 2);
> +
> +     /* Keep the C >= O */
> +     if (geo->ecc_chunk_size < mtd->oobsize)
> +             return -EINVAL;
> +
> +     if (geo->ecc_strength > mxs_nand_max_ecc_strength_supported())
> +             return -EINVAL;
> +
> +     geo->ecc_chunk_count = mtd->writesize / geo->ecc_chunk_size;
> +
> +     return 0;
> +}
> +
>  static inline int mxs_nand_calc_ecc_layout(struct bch_geometry *geo,
>                                          struct mtd_info *mtd)
>  {
> -     unsigned int max_ecc_strength_supported;
> -
>       /* The default for the length of Galois Field. */
>       geo->gf_len = 13;
>  
> @@ -235,12 +276,6 @@ static inline int mxs_nand_calc_ecc_layout(struct 
> bch_geometry *geo,
>  
>       geo->ecc_chunk_count = mtd->writesize / geo->ecc_chunk_size;
>  
> -     /* Refer to Chapter 17 for i.MX6DQ, Chapter 18 for i.MX6SX */
> -     if (is_mx6sx() || is_mx7())
> -             max_ecc_strength_supported = 62;
> -     else
> -             max_ecc_strength_supported = 40;
> -
>       /*
>        * Determine the ECC layout with the formula:
>        *      ECC bits per chunk = (total page spare data bits) /
> @@ -252,10 +287,8 @@ static inline int mxs_nand_calc_ecc_layout(struct 
> bch_geometry *geo,
>       geo->ecc_strength = ((mtd->oobsize - MXS_NAND_METADATA_SIZE) * 8)
>                       / (geo->gf_len * geo->ecc_chunk_count);
>  
> -     geo->ecc_strength = min(round_down(geo->ecc_strength, 2), 
> max_ecc_strength_supported);
> -
> -     if (mxs_nand_calc_mark_offset(geo, mtd->writesize) < 0)
> -             return -EINVAL;
> +     geo->ecc_strength = min(round_down(geo->ecc_strength, 2),
> +                             mxs_nand_max_ecc_strength_supported());
>  
>       return 0;
>  }
> @@ -1006,9 +1039,19 @@ static int mxs_nand_setup_ecc(struct mtd_info *mtd)
>       struct bch_geometry *geo = &nand_info->bch_geometry;
>       struct mxs_bch_regs *bch_regs = (struct mxs_bch_regs *)MXS_BCH_BASE;
>       uint32_t tmp;
> +     int ret = -ENOTSUPP;
>  
> -     if (mxs_nand_calc_ecc_layout(geo, mtd))
> -             return -EINVAL;
> +#ifdef CONFIG_NAND_MXS_USE_MINIMUM_ECC
> +     ret = mxs_nand_calc_ecc_layout_by_info(geo, mtd);
> +#endif
> +
> +     if (ret == -ENOTSUPP)
> +             ret = mxs_nand_calc_ecc_layout(geo, mtd);
> +
> +     if (ret)
> +             return ret;
> +
> +     mxs_nand_calc_mark_offset(geo, mtd->writesize);
>  
>       /* Configure BCH and set NFC geometry */
>       mxs_reset_block(&bch_regs->hw_bch_ctrl_reg);
> 

This is not completely clear to me - is this series replaced by :

        http://patchwork.ozlabs.org/patch/902010/

Regards,
Stefano

-- 
=====================================================================
DENX Software Engineering GmbH,      Managing Director: Wolfgang Denk
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: +49-8142-66989-53 Fax: +49-8142-66989-80 Email: sba...@denx.de
=====================================================================
_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
https://lists.denx.de/listinfo/u-boot

Reply via email to