diff options
author | Lars-Peter Clausen <lars@metafoo.de> | 2013-07-24 09:27:38 -0400 |
---|---|---|
committer | Mark Brown <broonie@linaro.org> | 2013-07-24 09:56:19 -0400 |
commit | 6b3fc03b3b614ced09df96ca60ab6f627d8c240c (patch) | |
tree | 0c8dcd214e033bf050a70fa10cce10bbaacf40e7 /include/sound | |
parent | ce6cfaf1de136cd3e6ed7c0ed984be8d003a58c1 (diff) |
ASoC: dapm: Add a update parameter to snd_soc_dapm_{mux,mixer}_update_power
In order to avoid race conditions the assignment of dapm->update should happen
while card->dapm_mutex is being held. To allow CODEC drivers to run a register
update when using snd_soc_dapm_mux_update_power() or
snd_soc_dapm_mixer_update_power() add a update parameter to these two functions.
The update parameter will be assigned to dapm->update while card->dapm_mutex is
locked.
Signed-off-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Mark Brown <broonie@linaro.org>
Diffstat (limited to 'include/sound')
-rw-r--r-- | include/sound/soc-dapm.h | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/include/sound/soc-dapm.h b/include/sound/soc-dapm.h index 3717ad089486..e77c6f5a8390 100644 --- a/include/sound/soc-dapm.h +++ b/include/sound/soc-dapm.h | |||
@@ -333,6 +333,7 @@ struct snd_soc_dapm_route; | |||
333 | struct snd_soc_dapm_context; | 333 | struct snd_soc_dapm_context; |
334 | struct regulator; | 334 | struct regulator; |
335 | struct snd_soc_dapm_widget_list; | 335 | struct snd_soc_dapm_widget_list; |
336 | struct snd_soc_dapm_update; | ||
336 | 337 | ||
337 | int dapm_reg_event(struct snd_soc_dapm_widget *w, | 338 | int dapm_reg_event(struct snd_soc_dapm_widget *w, |
338 | struct snd_kcontrol *kcontrol, int event); | 339 | struct snd_kcontrol *kcontrol, int event); |
@@ -392,9 +393,11 @@ void snd_soc_dapm_shutdown(struct snd_soc_card *card); | |||
392 | 393 | ||
393 | /* external DAPM widget events */ | 394 | /* external DAPM widget events */ |
394 | int snd_soc_dapm_mixer_update_power(struct snd_soc_dapm_context *dapm, | 395 | int snd_soc_dapm_mixer_update_power(struct snd_soc_dapm_context *dapm, |
395 | struct snd_kcontrol *kcontrol, int connect); | 396 | struct snd_kcontrol *kcontrol, int connect, |
397 | struct snd_soc_dapm_update *update); | ||
396 | int snd_soc_dapm_mux_update_power(struct snd_soc_dapm_context *dapm, | 398 | int snd_soc_dapm_mux_update_power(struct snd_soc_dapm_context *dapm, |
397 | struct snd_kcontrol *kcontrol, int mux, struct soc_enum *e); | 399 | struct snd_kcontrol *kcontrol, int mux, struct soc_enum *e, |
400 | struct snd_soc_dapm_update *update); | ||
398 | 401 | ||
399 | /* dapm sys fs - used by the core */ | 402 | /* dapm sys fs - used by the core */ |
400 | int snd_soc_dapm_sys_add(struct device *dev); | 403 | int snd_soc_dapm_sys_add(struct device *dev); |