[PATCH] mtd: atmel_nand: NFC: fix mtd_nandbiterrs.ko test fail when using sram write

Brian Norris computersforpeace at gmail.com
Mon Aug 4 14:22:59 PDT 2014


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?

>  
> +	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