diff options
author | Daniel Mack <daniel@caiaq.de> | 2010-03-19 10:52:55 -0400 |
---|---|---|
committer | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2010-03-19 15:37:29 -0400 |
commit | fd23b7dee5e4d369f620979cb120f53629389355 (patch) | |
tree | bbfa4637b0b97662b8ee63922eccb01913baaf1d /sound/soc/s3c24xx/s3c2412-i2s.c | |
parent | 093208f5d03980d7216b706e3c54432d0f299e26 (diff) |
ASoC: move dma_data from snd_soc_dai to snd_soc_pcm_stream
This fixes a memory corruption when ASoC devices are used in
full-duplex mode. Specifically for pxa-ssp code, where this pointer
is dynamically allocated for each direction and destroyed upon each
stream start.
All other platforms are fixed blindly, I couldn't even compile-test
them. Sorry for any breakage I may have caused.
Reported-by: Sven Neumann <s.neumann@raumfeld.com>
Reported-by: Michael Hirsch <m.hirsch@raumfeld.com>
Signed-off-by: Daniel Mack <daniel@caiaq.de>
Acked-by: Peter Ujfalusi <peter.ujfalusi@nokia.com>
Acked-by: Jarkko Nikula <jhnikula@gmail.com>
Acked-by: Liam Girdwood <lrg@slimlogic.co.uk>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Diffstat (limited to 'sound/soc/s3c24xx/s3c2412-i2s.c')
-rw-r--r-- | sound/soc/s3c24xx/s3c2412-i2s.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/sound/soc/s3c24xx/s3c2412-i2s.c b/sound/soc/s3c24xx/s3c2412-i2s.c index a5b21f63261f..f3148f98b419 100644 --- a/sound/soc/s3c24xx/s3c2412-i2s.c +++ b/sound/soc/s3c24xx/s3c2412-i2s.c | |||
@@ -151,14 +151,17 @@ static int s3c2412_i2s_hw_params(struct snd_pcm_substream *substream, | |||
151 | struct snd_soc_dai *cpu_dai) | 151 | struct snd_soc_dai *cpu_dai) |
152 | { | 152 | { |
153 | struct s3c_i2sv2_info *i2s = to_info(cpu_dai); | 153 | struct s3c_i2sv2_info *i2s = to_info(cpu_dai); |
154 | struct s3c_dma_params *dma_data; | ||
154 | u32 iismod; | 155 | u32 iismod; |
155 | 156 | ||
156 | pr_debug("Entered %s\n", __func__); | 157 | pr_debug("Entered %s\n", __func__); |
157 | 158 | ||
158 | if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) | 159 | if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) |
159 | cpu_dai->dma_data = i2s->dma_playback; | 160 | dma_data = i2s->dma_playback; |
160 | else | 161 | else |
161 | cpu_dai->dma_data = i2s->dma_capture; | 162 | dma_data = i2s->dma_capture; |
163 | |||
164 | snd_soc_dai_set_dma_data(cpu_dai, substream, dma_data); | ||
162 | 165 | ||
163 | iismod = readl(i2s->regs + S3C2412_IISMOD); | 166 | iismod = readl(i2s->regs + S3C2412_IISMOD); |
164 | pr_debug("%s: r: IISMOD: %x\n", __func__, iismod); | 167 | pr_debug("%s: r: IISMOD: %x\n", __func__, iismod); |