[PATCH] mtd: rawnand: stm32_fmc2: fix broken ECC
Christophe Kerello
christophe.kerello at st.com
Fri Oct 30 04:31:25 EDT 2020
Hi Miquel,
On 10/30/20 9:19 AM, Miquel Raynal wrote:
> Hi Christophe,
>
> Christophe Kerello <christophe.kerello at st.com> wrote on Thu, 29 Oct
> 2020 17:38:12 +0100:
>
>> Since commit d7157ff49a5b ("mtd: rawnand: Use the ECC framework user
>> input parsing bits"), ECC are broken in FMC2 driver in case of
>> nand-ecc-step-size and nand-ecc-strength are not set in the device tree.
>> The default user configuration set in FMC2 driver is lost when
>> rawnand_dt_init function is called. To avoid to lose the default user
>> configuration, it is needed to move it in the new user_conf structure.
>>
>> Signed-off-by: Christophe Kerello <christophe.kerello at st.com>
>> Fixes: d7157ff49a5b ("mtd: rawnand: Use the ECC framework user input parsing bits")
>> ---
>> drivers/mtd/nand/raw/stm32_fmc2_nand.c | 8 +++++---
>> 1 file changed, 5 insertions(+), 3 deletions(-)
>>
>> diff --git a/drivers/mtd/nand/raw/stm32_fmc2_nand.c b/drivers/mtd/nand/raw/stm32_fmc2_nand.c
>> index b31a581..dc86ac9 100644
>> --- a/drivers/mtd/nand/raw/stm32_fmc2_nand.c
>> +++ b/drivers/mtd/nand/raw/stm32_fmc2_nand.c
>> @@ -1846,6 +1846,7 @@ static int stm32_fmc2_nfc_probe(struct platform_device *pdev)
>> struct resource *res;
>> struct mtd_info *mtd;
>> struct nand_chip *chip;
>> + struct nand_device *nanddev;
>> struct resource cres;
>> int chip_cs, mem_region, ret, irq;
>> int start_region = 0;
>> @@ -1952,10 +1953,11 @@ static int stm32_fmc2_nfc_probe(struct platform_device *pdev)
>> chip->options |= NAND_BUSWIDTH_AUTO | NAND_NO_SUBPAGE_WRITE |
>> NAND_USES_DMA;
>>
>> - /* Default ECC settings */
>> + /* Default ECC user settings */
>> chip->ecc.engine_type = NAND_ECC_ENGINE_TYPE_ON_HOST;
>> - chip->ecc.size = FMC2_ECC_STEP_SIZE;
>> - chip->ecc.strength = FMC2_ECC_BCH8;
>> + nanddev = mtd_to_nanddev(mtd);
>> + nanddev->ecc.user_conf.step_size = FMC2_ECC_STEP_SIZE;
>> + nanddev->ecc.user_conf.strength = FMC2_ECC_BCH8;
>>
>> /* Scan to find existence of the device */
>> ret = nand_scan(chip, nand->ncs);
>
> Sorry for breaking the driver with this change, but now I think we
> should have all ECC related bits in ->attach() instead of ->probe().
> The ->attach() hook is called during the nand_scan() operation and at
> this point the chip's requirements/layout are known (not before). I
> know that certain controllers don't really care about that, here your
> simply hardcode these two fields and you don't need to know anything
> about the chip's properties. But as a bid to harmonize all drivers with
> the target of a generic ECC engine in mind, I think it's now time to
> move these three lines (chip->ecc.* = ...) at the top of ->attach().
> Also, these fields should have been populated by the core so perhaps
> the best approach is to check if the user requirements are synced with
> the controller's capabilities and error out otherwise?
>
> We plan to send a fixes PR for -rc2, if the v2 arrives today I'll
> integrate it.
Ok. Issue is that the controller is initialized when
stm32_fmc2_nfc_select_chip is called. This function will be called
before the ->attach() hook, when the first command will be sent to the
NAND device (reset command). So, moving the default ECC initialization
needs probably more modifications in the driver.
I will try to send a v2 today.
Regards,
Christophe Kerello.
>
> Thanks,
> Miquèl
>
More information about the linux-mtd
mailing list