diff options
author | Padmavathi Venna <padma.v@samsung.com> | 2013-01-18 06:47:02 -0500 |
---|---|---|
committer | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2013-01-29 01:28:51 -0500 |
commit | e7ba5f1d0f6292e1b99c63cc4bb74c70232e9065 (patch) | |
tree | 344c79ff4f94d56b537e066fd0c1b4defa6fdd0a /arch | |
parent | 40476f61897933d524b7069a6df65629a469d922 (diff) |
ARM: SAMSUNG: Make dma request compatible to generic dma bindings.
This patch make the dma dev request operation compatible for both
DT and non-DT cases. It takes the all the arguments required for
dma_request_slave_channel and dma_request_channel. If the driver
is initiated via DT or non-DT the corresponding call will be made.
Signed-off-by: Padmavathi Venna <padma.v@samsung.com>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/arm/plat-samsung/dma-ops.c | 10 | ||||
-rw-r--r-- | arch/arm/plat-samsung/include/plat/dma-ops.h | 3 | ||||
-rw-r--r-- | arch/arm/plat-samsung/s3c-dma-ops.c | 3 |
3 files changed, 12 insertions, 4 deletions
diff --git a/arch/arm/plat-samsung/dma-ops.c b/arch/arm/plat-samsung/dma-ops.c index d088afa034e8..71d58ddea9c1 100644 --- a/arch/arm/plat-samsung/dma-ops.c +++ b/arch/arm/plat-samsung/dma-ops.c | |||
@@ -19,7 +19,8 @@ | |||
19 | #include <mach/dma.h> | 19 | #include <mach/dma.h> |
20 | 20 | ||
21 | static unsigned samsung_dmadev_request(enum dma_ch dma_ch, | 21 | static unsigned samsung_dmadev_request(enum dma_ch dma_ch, |
22 | struct samsung_dma_req *param) | 22 | struct samsung_dma_req *param, |
23 | struct device *dev, char *ch_name) | ||
23 | { | 24 | { |
24 | dma_cap_mask_t mask; | 25 | dma_cap_mask_t mask; |
25 | void *filter_param; | 26 | void *filter_param; |
@@ -33,7 +34,12 @@ static unsigned samsung_dmadev_request(enum dma_ch dma_ch, | |||
33 | */ | 34 | */ |
34 | filter_param = (dma_ch == DMACH_DT_PROP) ? | 35 | filter_param = (dma_ch == DMACH_DT_PROP) ? |
35 | (void *)param->dt_dmach_prop : (void *)dma_ch; | 36 | (void *)param->dt_dmach_prop : (void *)dma_ch; |
36 | return (unsigned)dma_request_channel(mask, pl330_filter, filter_param); | 37 | |
38 | if (dev->of_node) | ||
39 | return (unsigned)dma_request_slave_channel(dev, ch_name); | ||
40 | else | ||
41 | return (unsigned)dma_request_channel(mask, pl330_filter, | ||
42 | filter_param); | ||
37 | } | 43 | } |
38 | 44 | ||
39 | static int samsung_dmadev_release(unsigned ch, void *param) | 45 | static int samsung_dmadev_release(unsigned ch, void *param) |
diff --git a/arch/arm/plat-samsung/include/plat/dma-ops.h b/arch/arm/plat-samsung/include/plat/dma-ops.h index f5144cdd3001..114178268b75 100644 --- a/arch/arm/plat-samsung/include/plat/dma-ops.h +++ b/arch/arm/plat-samsung/include/plat/dma-ops.h | |||
@@ -39,7 +39,8 @@ struct samsung_dma_config { | |||
39 | }; | 39 | }; |
40 | 40 | ||
41 | struct samsung_dma_ops { | 41 | struct samsung_dma_ops { |
42 | unsigned (*request)(enum dma_ch ch, struct samsung_dma_req *param); | 42 | unsigned (*request)(enum dma_ch ch, struct samsung_dma_req *param, |
43 | struct device *dev, char *ch_name); | ||
43 | int (*release)(unsigned ch, void *param); | 44 | int (*release)(unsigned ch, void *param); |
44 | int (*config)(unsigned ch, struct samsung_dma_config *param); | 45 | int (*config)(unsigned ch, struct samsung_dma_config *param); |
45 | int (*prepare)(unsigned ch, struct samsung_dma_prep *param); | 46 | int (*prepare)(unsigned ch, struct samsung_dma_prep *param); |
diff --git a/arch/arm/plat-samsung/s3c-dma-ops.c b/arch/arm/plat-samsung/s3c-dma-ops.c index f99448c48d30..0cc40aea3f5a 100644 --- a/arch/arm/plat-samsung/s3c-dma-ops.c +++ b/arch/arm/plat-samsung/s3c-dma-ops.c | |||
@@ -36,7 +36,8 @@ static void s3c_dma_cb(struct s3c2410_dma_chan *channel, void *param, | |||
36 | } | 36 | } |
37 | 37 | ||
38 | static unsigned s3c_dma_request(enum dma_ch dma_ch, | 38 | static unsigned s3c_dma_request(enum dma_ch dma_ch, |
39 | struct samsung_dma_req *param) | 39 | struct samsung_dma_req *param, |
40 | struct device *dev, char *ch_name) | ||
40 | { | 41 | { |
41 | struct cb_data *data; | 42 | struct cb_data *data; |
42 | 43 | ||