diff options
Diffstat (limited to 'sound/soc/fsl')
-rw-r--r-- | sound/soc/fsl/mpc5200_dma.c | 28 | ||||
-rw-r--r-- | sound/soc/fsl/mpc5200_dma.h | 8 |
2 files changed, 11 insertions, 25 deletions
diff --git a/sound/soc/fsl/mpc5200_dma.c b/sound/soc/fsl/mpc5200_dma.c index 6096d22283e..986d3c8ab6e 100644 --- a/sound/soc/fsl/mpc5200_dma.c +++ b/sound/soc/fsl/mpc5200_dma.c | |||
@@ -58,13 +58,11 @@ static void psc_dma_bcom_enqueue_next_buffer(struct psc_dma_stream *s) | |||
58 | /* Prepare and enqueue the next buffer descriptor */ | 58 | /* Prepare and enqueue the next buffer descriptor */ |
59 | bd = bcom_prepare_next_buffer(s->bcom_task); | 59 | bd = bcom_prepare_next_buffer(s->bcom_task); |
60 | bd->status = s->period_bytes; | 60 | bd->status = s->period_bytes; |
61 | bd->data[0] = s->period_next_pt; | 61 | bd->data[0] = s->runtime->dma_addr + (s->period_next * s->period_bytes); |
62 | bcom_submit_next_buffer(s->bcom_task, NULL); | 62 | bcom_submit_next_buffer(s->bcom_task, NULL); |
63 | 63 | ||
64 | /* Update for next period */ | 64 | /* Update for next period */ |
65 | s->period_next_pt += s->period_bytes; | 65 | s->period_next = (s->period_next + 1) % s->runtime->periods; |
66 | if (s->period_next_pt >= s->period_end) | ||
67 | s->period_next_pt = s->period_start; | ||
68 | } | 66 | } |
69 | 67 | ||
70 | static void psc_dma_bcom_enqueue_tx(struct psc_dma_stream *s) | 68 | static void psc_dma_bcom_enqueue_tx(struct psc_dma_stream *s) |
@@ -79,7 +77,7 @@ static void psc_dma_bcom_enqueue_tx(struct psc_dma_stream *s) | |||
79 | if (bcom_queue_full(s->bcom_task)) | 77 | if (bcom_queue_full(s->bcom_task)) |
80 | return; | 78 | return; |
81 | 79 | ||
82 | s->appl_ptr += s->period_size; | 80 | s->appl_ptr += s->runtime->period_size; |
83 | 81 | ||
84 | psc_dma_bcom_enqueue_next_buffer(s); | 82 | psc_dma_bcom_enqueue_next_buffer(s); |
85 | } | 83 | } |
@@ -91,7 +89,7 @@ static void psc_dma_bcom_enqueue_tx(struct psc_dma_stream *s) | |||
91 | if (bcom_queue_full(s->bcom_task)) | 89 | if (bcom_queue_full(s->bcom_task)) |
92 | return; | 90 | return; |
93 | 91 | ||
94 | s->appl_ptr += s->period_size; | 92 | s->appl_ptr += s->runtime->period_size; |
95 | 93 | ||
96 | psc_dma_bcom_enqueue_next_buffer(s); | 94 | psc_dma_bcom_enqueue_next_buffer(s); |
97 | } | 95 | } |
@@ -108,9 +106,7 @@ static irqreturn_t psc_dma_bcom_irq_tx(int irq, void *_psc_dma_stream) | |||
108 | while (bcom_buffer_done(s->bcom_task)) { | 106 | while (bcom_buffer_done(s->bcom_task)) { |
109 | bcom_retrieve_buffer(s->bcom_task, NULL, NULL); | 107 | bcom_retrieve_buffer(s->bcom_task, NULL, NULL); |
110 | 108 | ||
111 | s->period_current_pt += s->period_bytes; | 109 | s->period_current = (s->period_current+1) % s->runtime->periods; |
112 | if (s->period_current_pt >= s->period_end) | ||
113 | s->period_current_pt = s->period_start; | ||
114 | } | 110 | } |
115 | psc_dma_bcom_enqueue_tx(s); | 111 | psc_dma_bcom_enqueue_tx(s); |
116 | spin_unlock(&s->psc_dma->lock); | 112 | spin_unlock(&s->psc_dma->lock); |
@@ -133,9 +129,7 @@ static irqreturn_t psc_dma_bcom_irq_rx(int irq, void *_psc_dma_stream) | |||
133 | while (bcom_buffer_done(s->bcom_task)) { | 129 | while (bcom_buffer_done(s->bcom_task)) { |
134 | bcom_retrieve_buffer(s->bcom_task, NULL, NULL); | 130 | bcom_retrieve_buffer(s->bcom_task, NULL, NULL); |
135 | 131 | ||
136 | s->period_current_pt += s->period_bytes; | 132 | s->period_current = (s->period_current+1) % s->runtime->periods; |
137 | if (s->period_current_pt >= s->period_end) | ||
138 | s->period_current_pt = s->period_start; | ||
139 | 133 | ||
140 | psc_dma_bcom_enqueue_next_buffer(s); | 134 | psc_dma_bcom_enqueue_next_buffer(s); |
141 | } | 135 | } |
@@ -185,12 +179,8 @@ static int psc_dma_trigger(struct snd_pcm_substream *substream, int cmd) | |||
185 | case SNDRV_PCM_TRIGGER_START: | 179 | case SNDRV_PCM_TRIGGER_START: |
186 | s->period_bytes = frames_to_bytes(runtime, | 180 | s->period_bytes = frames_to_bytes(runtime, |
187 | runtime->period_size); | 181 | runtime->period_size); |
188 | s->period_start = virt_to_phys(runtime->dma_area); | 182 | s->period_next = 0; |
189 | s->period_end = s->period_start + | 183 | s->period_current = 0; |
190 | (s->period_bytes * runtime->periods); | ||
191 | s->period_next_pt = s->period_start; | ||
192 | s->period_current_pt = s->period_start; | ||
193 | s->period_size = runtime->period_size; | ||
194 | s->active = 1; | 184 | s->active = 1; |
195 | 185 | ||
196 | /* track appl_ptr so that we have a better chance of detecting | 186 | /* track appl_ptr so that we have a better chance of detecting |
@@ -343,7 +333,7 @@ psc_dma_pointer(struct snd_pcm_substream *substream) | |||
343 | else | 333 | else |
344 | s = &psc_dma->playback; | 334 | s = &psc_dma->playback; |
345 | 335 | ||
346 | count = s->period_current_pt - s->period_start; | 336 | count = s->period_current * s->period_bytes; |
347 | 337 | ||
348 | return bytes_to_frames(substream->runtime, count); | 338 | return bytes_to_frames(substream->runtime, count); |
349 | } | 339 | } |
diff --git a/sound/soc/fsl/mpc5200_dma.h b/sound/soc/fsl/mpc5200_dma.h index 8d396bb9d9f..529f7a09447 100644 --- a/sound/soc/fsl/mpc5200_dma.h +++ b/sound/soc/fsl/mpc5200_dma.h | |||
@@ -13,7 +13,6 @@ | |||
13 | * @psc_dma: pointer back to parent psc_dma data structure | 13 | * @psc_dma: pointer back to parent psc_dma data structure |
14 | * @bcom_task: bestcomm task structure | 14 | * @bcom_task: bestcomm task structure |
15 | * @irq: irq number for bestcomm task | 15 | * @irq: irq number for bestcomm task |
16 | * @period_start: physical address of start of DMA region | ||
17 | * @period_end: physical address of end of DMA region | 16 | * @period_end: physical address of end of DMA region |
18 | * @period_next_pt: physical address of next DMA buffer to enqueue | 17 | * @period_next_pt: physical address of next DMA buffer to enqueue |
19 | * @period_bytes: size of DMA period in bytes | 18 | * @period_bytes: size of DMA period in bytes |
@@ -27,12 +26,9 @@ struct psc_dma_stream { | |||
27 | struct bcom_task *bcom_task; | 26 | struct bcom_task *bcom_task; |
28 | int irq; | 27 | int irq; |
29 | struct snd_pcm_substream *stream; | 28 | struct snd_pcm_substream *stream; |
30 | dma_addr_t period_start; | 29 | int period_next; |
31 | dma_addr_t period_end; | 30 | int period_current; |
32 | dma_addr_t period_next_pt; | ||
33 | dma_addr_t period_current_pt; | ||
34 | int period_bytes; | 31 | int period_bytes; |
35 | int period_size; | ||
36 | }; | 32 | }; |
37 | 33 | ||
38 | /** | 34 | /** |