]> git.baikalelectronics.ru Git - kernel.git/commit
ARM: OMAP2+: DMA: Workaround for invalid source position
authorPeter Ujfalusi <peter.ujfalusi@ti.com>
Fri, 9 Dec 2011 21:38:00 +0000 (13:38 -0800)
committerTony Lindgren <tony@atomide.com>
Fri, 9 Dec 2011 21:38:00 +0000 (13:38 -0800)
commitc8464a1cb6209184120df2af85fbe749ecc9b688
tree8d8b39fe1c77a937174b9d604f8cc554d18d4366
parent5f37fd77fc10ff97c75733690f229345798c5c36
ARM: OMAP2+: DMA: Workaround for invalid source position

If the DMA source position has been asked before the
first actual data transfer has been done, the CSAC
register does not contain valid information.
We can identify this situation by checking the CDAC
register:
CDAC != 0 indicates that the DMA transfer on the channel has
been started already.
When CDAC == 0 we can not trust the CSAC value since it has
not been updated, and can contain random number.
Return the start address in case the DMA has not jet started.

Note: The CDAC register has been initialized to 0 at dma_start
time.

Signed-off-by: Peter Ujfalusi <peter.ujfalusi@ti.com>
Reviewed-by: Jarkko Nikula <jarkko.nikula@bitmer.com>
Signed-off-by: Tony Lindgren <tony@atomide.com>
arch/arm/plat-omap/dma.c