diff options
-rw-r--r-- | arch/arm/plat-samsung/s3c-dma-ops.c | 13 | ||||
-rw-r--r-- | sound/soc/samsung/dma.c | 7 |
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) | |||
82 | static int s3c_dma_prepare(unsigned ch, struct samsung_dma_prep *param) | 82 | static 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 | ||