[PATCH 3/4] mtd: nand: kill the the NAND_MAX_PAGESIZE/NAND_MAX_OOBSIZE for nand_buffers{}
Russell King - ARM Linux
linux at arm.linux.org.uk
Sat Jan 11 18:43:53 EST 2014
On Sat, Jan 11, 2014 at 03:39:37PM -0800, Brian Norris wrote:
> When you move this after nand_scan_ident(), you forgot to move all the code
> that uses dmabuf and dmabuf:
>
> /* Set up DMA address */
> cafe_writel(cafe, cafe->dmaaddr & 0xffffffff, NAND_DMA_ADDR0);
> if (sizeof(cafe->dmaaddr) > 4)
> /* Shift in two parts to shut the compiler up */
> cafe_writel(cafe, (cafe->dmaaddr >> 16) >> 16, NAND_DMA_ADDR1);
> else
> cafe_writel(cafe, 0, NAND_DMA_ADDR1);
>
> cafe_dev_dbg(&cafe->pdev->dev, "Set DMA address to %x (virt %p)\n",
> cafe_readl(cafe, NAND_DMA_ADDR0), cafe->dmabuf);
>
> This code needs to stay after the point where you actually allocate the buffer.
You may wish to evaluate generated code differences between the above and
implementing it like this:
u64 dmaaddr = cafe->dmaaddr;
cafe_writel(cafe, dmaaddr, NAND_DMA_ADDR0);
cafe_writel(cafe, dmaaddr >> 32, NAMD_DMA_ADDR1);
--
FTTC broadband for 0.8mile line: 5.8Mbps down 500kbps up. Estimation
in database were 13.1 to 19Mbit for a good line, about 7.5+ for a bad.
Estimate before purchase was "up to 13.2Mbit".
More information about the linux-mtd
mailing list