[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