aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>2015-01-27 08:58:53 -0500
committerVinod Koul <vinod.koul@intel.com>2015-02-15 23:03:33 -0500
commit6a634808e315a148dfe8db925215cbaaa3ea1831 (patch)
treecb2a3688e7b0500b389c85ff9765b9f987814086
parentf7638c904bf87eac5bd823ef2debaef8251686b8 (diff)
dmaengine: rcar-dmac: Allocate hardware descriptors with DMAC device
When wired to an IOMMU to access data, the DMAC accesses the hardware descriptors through the IOMMU as well. We're using the DMA mapping API to allocate the descriptors, but with a NULL device at the moment, which prevents IOMMU mappings from being created. Fix this by passing the DMAC device instead. Signed-off-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com> Acked-by: Geert Uytterhoeven <geert+renesas@glider.be> Signed-off-by: Vinod Koul <vinod.koul@intel.com>
-rw-r--r--drivers/dma/sh/rcar-dmac.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/drivers/dma/sh/rcar-dmac.c b/drivers/dma/sh/rcar-dmac.c
index 2eb65e1bf938..bb93038c48b9 100644
--- a/drivers/dma/sh/rcar-dmac.c
+++ b/drivers/dma/sh/rcar-dmac.c
@@ -655,8 +655,8 @@ static void rcar_dmac_realloc_hwdesc(struct rcar_dmac_chan *chan,
655 return; 655 return;
656 656
657 if (desc->hwdescs.mem) { 657 if (desc->hwdescs.mem) {
658 dma_free_coherent(NULL, desc->hwdescs.size, desc->hwdescs.mem, 658 dma_free_coherent(chan->chan.device->dev, desc->hwdescs.size,
659 desc->hwdescs.dma); 659 desc->hwdescs.mem, desc->hwdescs.dma);
660 desc->hwdescs.mem = NULL; 660 desc->hwdescs.mem = NULL;
661 desc->hwdescs.size = 0; 661 desc->hwdescs.size = 0;
662 } 662 }
@@ -664,8 +664,8 @@ static void rcar_dmac_realloc_hwdesc(struct rcar_dmac_chan *chan,
664 if (!size) 664 if (!size)
665 return; 665 return;
666 666
667 desc->hwdescs.mem = dma_alloc_coherent(NULL, size, &desc->hwdescs.dma, 667 desc->hwdescs.mem = dma_alloc_coherent(chan->chan.device->dev, size,
668 GFP_NOWAIT); 668 &desc->hwdescs.dma, GFP_NOWAIT);
669 if (!desc->hwdescs.mem) 669 if (!desc->hwdescs.mem)
670 return; 670 return;
671 671