diff options
author | Lars-Peter Clausen <lars@metafoo.de> | 2014-03-05 07:17:43 -0500 |
---|---|---|
committer | Mark Brown <broonie@linaro.org> | 2014-03-06 04:04:55 -0500 |
commit | 24894b76468ed250d03f9718ddfe77b902995cbd (patch) | |
tree | 6e8391d1b22f78f568559773182dd9dc633d5e8e /sound/soc/soc-compress.c | |
parent | 208a1589db3e30767223d97e39e13237328e8a6e (diff) |
ASoC: Add helper functions for PCM runtime 'active' management
We have the same code that increments and decrements the active field of the
various PCM runtime components (all with the same bugs). Factor this out into
common helper functions.
Signed-off-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Mark Brown <broonie@linaro.org>
Diffstat (limited to 'sound/soc/soc-compress.c')
-rw-r--r-- | sound/soc/soc-compress.c | 62 |
1 files changed, 12 insertions, 50 deletions
diff --git a/sound/soc/soc-compress.c b/sound/soc/soc-compress.c index ef585af4081b..91083e6a6b38 100644 --- a/sound/soc/soc-compress.c +++ b/sound/soc/soc-compress.c | |||
@@ -30,8 +30,6 @@ static int soc_compr_open(struct snd_compr_stream *cstream) | |||
30 | { | 30 | { |
31 | struct snd_soc_pcm_runtime *rtd = cstream->private_data; | 31 | struct snd_soc_pcm_runtime *rtd = cstream->private_data; |
32 | struct snd_soc_platform *platform = rtd->platform; | 32 | struct snd_soc_platform *platform = rtd->platform; |
33 | struct snd_soc_dai *cpu_dai = rtd->cpu_dai; | ||
34 | struct snd_soc_dai *codec_dai = rtd->codec_dai; | ||
35 | int ret = 0; | 33 | int ret = 0; |
36 | 34 | ||
37 | mutex_lock_nested(&rtd->pcm_mutex, rtd->pcm_subclass); | 35 | mutex_lock_nested(&rtd->pcm_mutex, rtd->pcm_subclass); |
@@ -52,17 +50,7 @@ static int soc_compr_open(struct snd_compr_stream *cstream) | |||
52 | } | 50 | } |
53 | } | 51 | } |
54 | 52 | ||
55 | if (cstream->direction == SND_COMPRESS_PLAYBACK) { | 53 | snd_soc_runtime_activate(rtd, cstream->direction); |
56 | cpu_dai->playback_active++; | ||
57 | codec_dai->playback_active++; | ||
58 | } else { | ||
59 | cpu_dai->capture_active++; | ||
60 | codec_dai->capture_active++; | ||
61 | } | ||
62 | |||
63 | cpu_dai->active++; | ||
64 | codec_dai->active++; | ||
65 | rtd->codec->active++; | ||
66 | 54 | ||
67 | mutex_unlock(&rtd->pcm_mutex); | 55 | mutex_unlock(&rtd->pcm_mutex); |
68 | 56 | ||
@@ -81,8 +69,6 @@ static int soc_compr_open_fe(struct snd_compr_stream *cstream) | |||
81 | struct snd_soc_pcm_runtime *fe = cstream->private_data; | 69 | struct snd_soc_pcm_runtime *fe = cstream->private_data; |
82 | struct snd_pcm_substream *fe_substream = fe->pcm->streams[0].substream; | 70 | struct snd_pcm_substream *fe_substream = fe->pcm->streams[0].substream; |
83 | struct snd_soc_platform *platform = fe->platform; | 71 | struct snd_soc_platform *platform = fe->platform; |
84 | struct snd_soc_dai *cpu_dai = fe->cpu_dai; | ||
85 | struct snd_soc_dai *codec_dai = fe->codec_dai; | ||
86 | struct snd_soc_dpcm *dpcm; | 72 | struct snd_soc_dpcm *dpcm; |
87 | struct snd_soc_dapm_widget_list *list; | 73 | struct snd_soc_dapm_widget_list *list; |
88 | int stream; | 74 | int stream; |
@@ -140,17 +126,7 @@ static int soc_compr_open_fe(struct snd_compr_stream *cstream) | |||
140 | fe->dpcm[stream].state = SND_SOC_DPCM_STATE_OPEN; | 126 | fe->dpcm[stream].state = SND_SOC_DPCM_STATE_OPEN; |
141 | fe->dpcm[stream].runtime_update = SND_SOC_DPCM_UPDATE_NO; | 127 | fe->dpcm[stream].runtime_update = SND_SOC_DPCM_UPDATE_NO; |
142 | 128 | ||
143 | if (cstream->direction == SND_COMPRESS_PLAYBACK) { | 129 | snd_soc_runtime_activate(fe, stream); |
144 | cpu_dai->playback_active++; | ||
145 | codec_dai->playback_active++; | ||
146 | } else { | ||
147 | cpu_dai->capture_active++; | ||
148 | codec_dai->capture_active++; | ||
149 | } | ||
150 | |||
151 | cpu_dai->active++; | ||
152 | codec_dai->active++; | ||
153 | fe->codec->active++; | ||
154 | 130 | ||
155 | mutex_unlock(&fe->card->mutex); | 131 | mutex_unlock(&fe->card->mutex); |
156 | 132 | ||
@@ -202,23 +178,18 @@ static int soc_compr_free(struct snd_compr_stream *cstream) | |||
202 | struct snd_soc_platform *platform = rtd->platform; | 178 | struct snd_soc_platform *platform = rtd->platform; |
203 | struct snd_soc_dai *cpu_dai = rtd->cpu_dai; | 179 | struct snd_soc_dai *cpu_dai = rtd->cpu_dai; |
204 | struct snd_soc_dai *codec_dai = rtd->codec_dai; | 180 | struct snd_soc_dai *codec_dai = rtd->codec_dai; |
205 | struct snd_soc_codec *codec = rtd->codec; | 181 | int stream; |
206 | 182 | ||
207 | mutex_lock_nested(&rtd->pcm_mutex, rtd->pcm_subclass); | 183 | mutex_lock_nested(&rtd->pcm_mutex, rtd->pcm_subclass); |
208 | 184 | ||
209 | if (cstream->direction == SND_COMPRESS_PLAYBACK) { | 185 | if (cstream->direction == SND_COMPRESS_PLAYBACK) |
210 | cpu_dai->playback_active--; | 186 | stream = SNDRV_PCM_STREAM_PLAYBACK; |
211 | codec_dai->playback_active--; | 187 | else |
212 | } else { | 188 | stream = SNDRV_PCM_STREAM_CAPTURE; |
213 | cpu_dai->capture_active--; | ||
214 | codec_dai->capture_active--; | ||
215 | } | ||
216 | 189 | ||
217 | snd_soc_dai_digital_mute(codec_dai, 1, cstream->direction); | 190 | snd_soc_runtime_deactivate(rtd, stream); |
218 | 191 | ||
219 | cpu_dai->active--; | 192 | snd_soc_dai_digital_mute(codec_dai, 1, cstream->direction); |
220 | codec_dai->active--; | ||
221 | codec->active--; | ||
222 | 193 | ||
223 | if (!cpu_dai->active) | 194 | if (!cpu_dai->active) |
224 | cpu_dai->rate = 0; | 195 | cpu_dai->rate = 0; |
@@ -260,26 +231,17 @@ static int soc_compr_free_fe(struct snd_compr_stream *cstream) | |||
260 | { | 231 | { |
261 | struct snd_soc_pcm_runtime *fe = cstream->private_data; | 232 | struct snd_soc_pcm_runtime *fe = cstream->private_data; |
262 | struct snd_soc_platform *platform = fe->platform; | 233 | struct snd_soc_platform *platform = fe->platform; |
263 | struct snd_soc_dai *cpu_dai = fe->cpu_dai; | ||
264 | struct snd_soc_dai *codec_dai = fe->codec_dai; | ||
265 | struct snd_soc_dpcm *dpcm; | 234 | struct snd_soc_dpcm *dpcm; |
266 | int stream, ret; | 235 | int stream, ret; |
267 | 236 | ||
268 | mutex_lock_nested(&fe->card->mutex, SND_SOC_CARD_CLASS_RUNTIME); | 237 | mutex_lock_nested(&fe->card->mutex, SND_SOC_CARD_CLASS_RUNTIME); |
269 | 238 | ||
270 | if (cstream->direction == SND_COMPRESS_PLAYBACK) { | 239 | if (cstream->direction == SND_COMPRESS_PLAYBACK) |
271 | stream = SNDRV_PCM_STREAM_PLAYBACK; | 240 | stream = SNDRV_PCM_STREAM_PLAYBACK; |
272 | cpu_dai->playback_active--; | 241 | else |
273 | codec_dai->playback_active--; | ||
274 | } else { | ||
275 | stream = SNDRV_PCM_STREAM_CAPTURE; | 242 | stream = SNDRV_PCM_STREAM_CAPTURE; |
276 | cpu_dai->capture_active--; | ||
277 | codec_dai->capture_active--; | ||
278 | } | ||
279 | 243 | ||
280 | cpu_dai->active--; | 244 | snd_soc_runtime_deactivate(fe, stream); |
281 | codec_dai->active--; | ||
282 | fe->codec->active--; | ||
283 | 245 | ||
284 | fe->dpcm[stream].runtime_update = SND_SOC_DPCM_UPDATE_FE; | 246 | fe->dpcm[stream].runtime_update = SND_SOC_DPCM_UPDATE_FE; |
285 | 247 | ||