]> 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)
commit45b8bb0ca47e840e76d91b084ba5f281fe3c84a3
tree8d8b39fe1c77a937174b9d604f8cc554d18d4366
parent61540ae4e6374ba2bac1f9c72ad02736ba394640
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