diff options
author | Andy Shevchenko <andriy.shevchenko@linux.intel.com> | 2012-09-03 13:46:19 +0300 |
---|---|---|
committer | Vinod Koul <vinod.koul@linux.intel.com> | 2012-09-14 08:29:46 +0530 |
commit | 8fccc5bfd7f83fd321db42bcad36e2d9fe13d65b (patch) | |
tree | 2b3e2169e830b6b1d02cf361323e22b72ad123a5 /drivers/dma/dw_dmac.c | |
parent | f1a7757008b810217b2380d01b740244f21c09bd (diff) | |
download | kernel_goldelico_gta04-8fccc5bfd7f83fd321db42bcad36e2d9fe13d65b.zip kernel_goldelico_gta04-8fccc5bfd7f83fd321db42bcad36e2d9fe13d65b.tar.gz kernel_goldelico_gta04-8fccc5bfd7f83fd321db42bcad36e2d9fe13d65b.tar.bz2 |
dw_dmac: utilize slave_id to pass request line
There is slave_id field in the generic slave config structure that is dedicated
for the uniq slave number. In our case we have the request lines wired to the
certain hardware. Therefore the number of the request line is uniq and could be
used as slave_id. It allows us in some cases to drop out the usage of the
custom slave config structure.
Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Acked-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Vinod Koul <vinod.koul@linux.intel.com>
Diffstat (limited to 'drivers/dma/dw_dmac.c')
-rw-r--r-- | drivers/dma/dw_dmac.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/drivers/dma/dw_dmac.c b/drivers/dma/dw_dmac.c index 4f4ff13..efbd16a 100644 --- a/drivers/dma/dw_dmac.c +++ b/drivers/dma/dw_dmac.c @@ -177,6 +177,11 @@ static void dwc_initialize(struct dw_dma_chan *dwc) cfghi = dws->cfg_hi; cfglo |= dws->cfg_lo & ~DWC_CFGL_CH_PRIOR_MASK; + } else { + if (dwc->dma_sconfig.direction == DMA_MEM_TO_DEV) + cfghi = DWC_CFGH_DST_PER(dwc->dma_sconfig.slave_id); + else if (dwc->dma_sconfig.direction == DMA_DEV_TO_MEM) + cfghi = DWC_CFGH_SRC_PER(dwc->dma_sconfig.slave_id); } channel_writel(dwc, CFG_LO, cfglo); |