mirror of
https://github.com/torvalds/linux.git
synced 2024-11-27 22:51:35 +00:00
dmaengine: omap-dma: port_window support correction for both direction
When the port_window support was verified it was done on setup where only
the MEM_TO_DEV direction was enabled. This got un-noticed and thus only
this direction worked.
Now that I have managed to get a setup to verify both direction it turned
out that the setup was incorrect:
omap_desc members are settings for the slave port while the omap_sg members
apply to the memory side of the sDMA setup.
Fixes: 527a275913
("dmaengine: omap-dma: Fix the port_window support")
Signed-off-by: Peter Ujfalusi <peter.ujfalusi@ti.com>
Cc: Russell King <linux@armlinux.org.uk>
Cc: dmaengine@vger.kernel.org
Cc: dan.j.williams@intel.com
Cc: vinod.koul@intel.com
Tested-by: Tony Lindgren <tony@atomide.com>
Acked-by: Vinod Koul <vinod.koul@intel.com>
Signed-off-by: Bin Liu <b-liu@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
a70df14602
commit
9816c09e2c
@ -916,12 +916,6 @@ static struct dma_async_tx_descriptor *omap_dma_prep_slave_sg(
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* When the port_window is used, one frame must cover the window */
|
|
||||||
if (port_window) {
|
|
||||||
burst = port_window;
|
|
||||||
port_window_bytes = port_window * es_bytes[es];
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Now allocate and setup the descriptor. */
|
/* Now allocate and setup the descriptor. */
|
||||||
d = kzalloc(sizeof(*d) + sglen * sizeof(d->sg[0]), GFP_ATOMIC);
|
d = kzalloc(sizeof(*d) + sglen * sizeof(d->sg[0]), GFP_ATOMIC);
|
||||||
if (!d)
|
if (!d)
|
||||||
@ -931,6 +925,21 @@ static struct dma_async_tx_descriptor *omap_dma_prep_slave_sg(
|
|||||||
d->dev_addr = dev_addr;
|
d->dev_addr = dev_addr;
|
||||||
d->es = es;
|
d->es = es;
|
||||||
|
|
||||||
|
/* When the port_window is used, one frame must cover the window */
|
||||||
|
if (port_window) {
|
||||||
|
burst = port_window;
|
||||||
|
port_window_bytes = port_window * es_bytes[es];
|
||||||
|
|
||||||
|
d->ei = 1;
|
||||||
|
/*
|
||||||
|
* One frame covers the port_window and by configure
|
||||||
|
* the source frame index to be -1 * (port_window - 1)
|
||||||
|
* we instruct the sDMA that after a frame is processed
|
||||||
|
* it should move back to the start of the window.
|
||||||
|
*/
|
||||||
|
d->fi = -(port_window_bytes - 1);
|
||||||
|
}
|
||||||
|
|
||||||
d->ccr = c->ccr | CCR_SYNC_FRAME;
|
d->ccr = c->ccr | CCR_SYNC_FRAME;
|
||||||
if (dir == DMA_DEV_TO_MEM) {
|
if (dir == DMA_DEV_TO_MEM) {
|
||||||
d->csdp = CSDP_DST_BURST_64 | CSDP_DST_PACKED;
|
d->csdp = CSDP_DST_BURST_64 | CSDP_DST_PACKED;
|
||||||
@ -955,14 +964,6 @@ static struct dma_async_tx_descriptor *omap_dma_prep_slave_sg(
|
|||||||
d->ccr |= CCR_SRC_AMODE_POSTINC;
|
d->ccr |= CCR_SRC_AMODE_POSTINC;
|
||||||
if (port_window) {
|
if (port_window) {
|
||||||
d->ccr |= CCR_DST_AMODE_DBLIDX;
|
d->ccr |= CCR_DST_AMODE_DBLIDX;
|
||||||
d->ei = 1;
|
|
||||||
/*
|
|
||||||
* One frame covers the port_window and by configure
|
|
||||||
* the source frame index to be -1 * (port_window - 1)
|
|
||||||
* we instruct the sDMA that after a frame is processed
|
|
||||||
* it should move back to the start of the window.
|
|
||||||
*/
|
|
||||||
d->fi = -(port_window_bytes - 1);
|
|
||||||
|
|
||||||
if (port_window_bytes >= 64)
|
if (port_window_bytes >= 64)
|
||||||
d->csdp |= CSDP_DST_BURST_64;
|
d->csdp |= CSDP_DST_BURST_64;
|
||||||
@ -1018,16 +1019,6 @@ static struct dma_async_tx_descriptor *omap_dma_prep_slave_sg(
|
|||||||
osg->addr = sg_dma_address(sgent);
|
osg->addr = sg_dma_address(sgent);
|
||||||
osg->en = en;
|
osg->en = en;
|
||||||
osg->fn = sg_dma_len(sgent) / frame_bytes;
|
osg->fn = sg_dma_len(sgent) / frame_bytes;
|
||||||
if (port_window && dir == DMA_DEV_TO_MEM) {
|
|
||||||
osg->ei = 1;
|
|
||||||
/*
|
|
||||||
* One frame covers the port_window and by configure
|
|
||||||
* the source frame index to be -1 * (port_window - 1)
|
|
||||||
* we instruct the sDMA that after a frame is processed
|
|
||||||
* it should move back to the start of the window.
|
|
||||||
*/
|
|
||||||
osg->fi = -(port_window_bytes - 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (d->using_ll) {
|
if (d->using_ll) {
|
||||||
osg->t2_desc = dma_pool_alloc(od->desc_pool, GFP_ATOMIC,
|
osg->t2_desc = dma_pool_alloc(od->desc_pool, GFP_ATOMIC,
|
||||||
|
Loading…
Reference in New Issue
Block a user