[PATCH] mtd: atmel_nand: NFC: fix mtd_nandbiterrs.ko test fail when using sram write
Josh Wu
josh.wu at atmel.com
Tue Aug 5 03:41:37 PDT 2014
On 8/5/2014 5:22 AM, Brian Norris wrote:
> On Tue, Jul 22, 2014 at 05:25:38PM +0800, Josh Wu wrote:
>> diff --git a/drivers/mtd/nand/atmel_nand.c b/drivers/mtd/nand/atmel_nand.c
>> index 33826a0..012d687 100644
>> --- a/drivers/mtd/nand/atmel_nand.c
>> +++ b/drivers/mtd/nand/atmel_nand.c
>> @@ -1913,15 +1913,13 @@ static int nfc_sram_write_page(struct mtd_info *mtd, struct nand_chip *chip,
>> if (offset || (data_len < mtd->writesize))
>> return -EINVAL;
>>
>> - cfg = nfc_readl(host->nfc->hsmc_regs, CFG);
>> - len = mtd->writesize;
>> -
>> - if (unlikely(raw)) {
>> - len += mtd->oobsize;
>> - nfc_writel(host->nfc->hsmc_regs, CFG, cfg | NFC_CFG_WSPARE);
>> - } else
>> - nfc_writel(host->nfc->hsmc_regs, CFG, cfg & ~NFC_CFG_WSPARE);
>> + if (data_len > mtd->writesize) {
>> + dev_err(host->dev, "data_len: %d should not bigger than mtd->writesize: %d!\n",
> "should not be"
>
>> + data_len, mtd->writesize);
>> + return -EINVAL;
>> + }
> The NAND layer guarantees that 'write_page' will never have to write
> more than 1 page (mtd->writesize), so the above block seems unnecessary.
> Drop it?
you are right. I sent a v2 version which drops this check. Thanks.
Best Regards,
Josh Wu
>
>>
>> + len = mtd->writesize;
>> /* Copy page data to sram that will write to nand via NFC */
>> if (use_dma) {
>> if (atmel_nand_dma_op(mtd, (void *)buf, len, 0) != 0)
>> @@ -1931,6 +1929,15 @@ static int nfc_sram_write_page(struct mtd_info *mtd, struct nand_chip *chip,
>> memcpy32_toio(sram, buf, len);
>> }
>>
>> + cfg = nfc_readl(host->nfc->hsmc_regs, CFG);
>> + if (unlikely(raw) && oob_required) {
>> + memcpy32_toio(sram + len, chip->oob_poi, mtd->oobsize);
>> + len += mtd->oobsize;
>> + nfc_writel(host->nfc->hsmc_regs, CFG, cfg | NFC_CFG_WSPARE);
>> + } else {
>> + nfc_writel(host->nfc->hsmc_regs, CFG, cfg & ~NFC_CFG_WSPARE);
>> + }
>> +
>> if (chip->ecc.mode == NAND_ECC_HW && host->has_pmecc)
>> /*
>> * When use NFC sram, need set up PMECC before send
> Brian
More information about the linux-mtd
mailing list