aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/arm/plat-samsung/s3c-dma-ops.c13
-rw-r--r--sound/soc/samsung/dma.c7
2 files changed, 18 insertions, 2 deletions
diff --git a/arch/arm/plat-samsung/s3c-dma-ops.c b/arch/arm/plat-samsung/s3c-dma-ops.c
index 0cc40aea3f5a..98b10ba67dc7 100644
--- a/arch/arm/plat-samsung/s3c-dma-ops.c
+++ b/arch/arm/plat-samsung/s3c-dma-ops.c
@@ -82,7 +82,8 @@ static int s3c_dma_config(unsigned ch, struct samsung_dma_config *param)
82static int s3c_dma_prepare(unsigned ch, struct samsung_dma_prep *param) 82static int s3c_dma_prepare(unsigned ch, struct samsung_dma_prep *param)
83{ 83{
84 struct cb_data *data; 84 struct cb_data *data;
85 int len = (param->cap == DMA_CYCLIC) ? param->period : param->len; 85 dma_addr_t pos = param->buf;
86 dma_addr_t end = param->buf + param->len;
86 87
87 list_for_each_entry(data, &dma_list, node) 88 list_for_each_entry(data, &dma_list, node)
88 if (data->ch == ch) 89 if (data->ch == ch)
@@ -94,7 +95,15 @@ static int s3c_dma_prepare(unsigned ch, struct samsung_dma_prep *param)
94 data->fp_param = param->fp_param; 95 data->fp_param = param->fp_param;
95 } 96 }
96 97
97 s3c2410_dma_enqueue(ch, (void *)data, param->buf, len); 98 if (param->cap != DMA_CYCLIC) {
99 s3c2410_dma_enqueue(ch, (void *)data, param->buf, param->len);
100 return 0;
101 }
102
103 while (pos < end) {
104 s3c2410_dma_enqueue(ch, (void *)data, pos, param->period);
105 pos += param->period;
106 }
98 107
99 return 0; 108 return 0;
100} 109}
diff --git a/sound/soc/samsung/dma.c b/sound/soc/samsung/dma.c
index a0c67f60f594..9338d11e9216 100644
--- a/sound/soc/samsung/dma.c
+++ b/sound/soc/samsung/dma.c
@@ -90,6 +90,13 @@ static void dma_enqueue(struct snd_pcm_substream *substream)
90 dma_info.period = prtd->dma_period; 90 dma_info.period = prtd->dma_period;
91 dma_info.len = prtd->dma_period*limit; 91 dma_info.len = prtd->dma_period*limit;
92 92
93 if (dma_info.cap == DMA_CYCLIC) {
94 dma_info.buf = pos;
95 prtd->params->ops->prepare(prtd->params->ch, &dma_info);
96 prtd->dma_loaded += limit;
97 return;
98 }
99
93 while (prtd->dma_loaded < limit) { 100 while (prtd->dma_loaded < limit) {
94 pr_debug("dma_loaded: %d\n", prtd->dma_loaded); 101 pr_debug("dma_loaded: %d\n", prtd->dma_loaded);
95 102