aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/dma/pl330.c
diff options
context:
space:
mode:
authorPadmavathi Venna <padma.v@samsung.com>2013-02-13 22:40:05 -0500
committerVinod Koul <vinod.koul@intel.com>2013-02-14 09:34:27 -0500
commit34d19355b84adde9eebc1d6771231c15dff891e6 (patch)
treea1de3edb01cc8591032833ed934bcd4a1e16ce64 /drivers/dma/pl330.c
parenta72208733f7866972bcba7995f7e598ad07f1158 (diff)
DMA: PL330: Add new pl330 filter for DT case.
This patch adds a new pl330_dt_filter for DT case to filter the required channel based on the new filter params and modifies the old filter only for non-DT case as suggested by Arnd Bergmann. Signed-off-by: Padmavathi Venna <padma.v@samsung.com> Acked-by: Arnd Bergmann <arnd@arndb.de> Signed-off-by: Vinod Koul <vinod.koul@intel.com>
Diffstat (limited to 'drivers/dma/pl330.c')
-rw-r--r--drivers/dma/pl330.c29
1 files changed, 15 insertions, 14 deletions
diff --git a/drivers/dma/pl330.c b/drivers/dma/pl330.c
index f7edb6f0ee87..40e97528244b 100644
--- a/drivers/dma/pl330.c
+++ b/drivers/dma/pl330.c
@@ -606,6 +606,11 @@ struct dma_pl330_desc {
606 struct dma_pl330_chan *pchan; 606 struct dma_pl330_chan *pchan;
607}; 607};
608 608
609struct dma_pl330_filter_args {
610 struct dma_pl330_dmac *pdmac;
611 unsigned int chan_id;
612};
613
609static inline void _callback(struct pl330_req *r, enum pl330_op_err err) 614static inline void _callback(struct pl330_req *r, enum pl330_op_err err)
610{ 615{
611 if (r && r->xfer_cb) 616 if (r && r->xfer_cb)
@@ -2352,6 +2357,16 @@ static void dma_pl330_rqcb(void *token, enum pl330_op_err err)
2352 tasklet_schedule(&pch->task); 2357 tasklet_schedule(&pch->task);
2353} 2358}
2354 2359
2360static bool pl330_dt_filter(struct dma_chan *chan, void *param)
2361{
2362 struct dma_pl330_filter_args *fargs = param;
2363
2364 if (chan->device != &fargs->pdmac->ddma)
2365 return false;
2366
2367 return (chan->chan_id == fargs->chan_id);
2368}
2369
2355bool pl330_filter(struct dma_chan *chan, void *param) 2370bool pl330_filter(struct dma_chan *chan, void *param)
2356{ 2371{
2357 u8 *peri_id; 2372 u8 *peri_id;
@@ -2359,20 +2374,6 @@ bool pl330_filter(struct dma_chan *chan, void *param)
2359 if (chan->device->dev->driver != &pl330_driver.drv) 2374 if (chan->device->dev->driver != &pl330_driver.drv)
2360 return false; 2375 return false;
2361 2376
2362#ifdef CONFIG_OF
2363 if (chan->device->dev->of_node) {
2364 const __be32 *prop_value;
2365 phandle phandle;
2366 struct device_node *node;
2367
2368 prop_value = ((struct property *)param)->value;
2369 phandle = be32_to_cpup(prop_value++);
2370 node = of_find_node_by_phandle(phandle);
2371 return ((chan->private == node) &&
2372 (chan->chan_id == be32_to_cpup(prop_value)));
2373 }
2374#endif
2375
2376 peri_id = chan->private; 2377 peri_id = chan->private;
2377 return *peri_id == (unsigned)param; 2378 return *peri_id == (unsigned)param;
2378} 2379}