ASoC: dapm: Move snd_soc_dapm_update from dapm context to card
authorLars-Peter Clausen <lars@metafoo.de>
Mon, 29 Jul 2013 15:13:55 +0000 (17:13 +0200)
committerMark Brown <broonie@linaro.org>
Mon, 29 Jul 2013 17:40:59 +0000 (18:40 +0100)
The update field of a DAPM context is only assigned while the card's dapm_mutex
is locked, the field is also cleared again while the mutex is stil locked. So
there will only ever be one DAPM context at a time with a non-NULL update field.
So it is safe to move the update field from the DAPM context struct to the card
struct. Doing so will allow further cleanups in this area.

Signed-off-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Mark Brown <broonie@linaro.org>
include/sound/soc-dapm.h
include/sound/soc.h
sound/soc/soc-dapm.c

index e77c6f5a83901032967a9bf84c398392ebd17454..3397292d94c8ee41f79f3ff61dab05e2c050019b 100644 (file)
@@ -575,8 +575,6 @@ struct snd_soc_dapm_context {
        struct delayed_work delayed_work;
        unsigned int idle_bias_off:1; /* Use BIAS_OFF instead of STANDBY */
 
-       struct snd_soc_dapm_update *update;
-
        void (*seq_notifier)(struct snd_soc_dapm_context *,
                             enum snd_soc_dapm_type, int);
 
index 6eabee7ec15a90197ff3024f827d47cfaad91095..b1e1f967ae1edcbd0127ed7b8e5b64a7792f8cdb 100644 (file)
@@ -1042,6 +1042,7 @@ struct snd_soc_card {
        /* Generic DAPM context for the card */
        struct snd_soc_dapm_context dapm;
        struct snd_soc_dapm_stats dapm_stats;
+       struct snd_soc_dapm_update *update;
 
 #ifdef CONFIG_DEBUG_FS
        struct dentry *debugfs_card_root;
index 366daef006ed354ca9639aaeded27c5043ef1e4a..7449e27bf13381564cb8e44db6a8bf82dd31a2ef 100644 (file)
@@ -1425,7 +1425,7 @@ static void dapm_seq_run(struct snd_soc_dapm_context *dapm,
 
 static void dapm_widget_update(struct snd_soc_dapm_context *dapm)
 {
-       struct snd_soc_dapm_update *update = dapm->update;
+       struct snd_soc_dapm_update *update = dapm->card->update;
        struct snd_soc_dapm_widget_list *wlist;
        struct snd_soc_dapm_widget *w = NULL;
        unsigned int wi;
@@ -1959,9 +1959,9 @@ int snd_soc_dapm_mux_update_power(struct snd_soc_dapm_context *dapm,
        int ret;
 
        mutex_lock_nested(&card->dapm_mutex, SND_SOC_DAPM_CLASS_RUNTIME);
-       dapm->update = update;
+       card->update = update;
        ret = soc_dapm_mux_update_power(dapm, kcontrol, mux, e);
-       dapm->update = NULL;
+       card->update = NULL;
        mutex_unlock(&card->dapm_mutex);
        if (ret > 0)
                soc_dpcm_runtime_update(card);
@@ -2002,9 +2002,9 @@ int snd_soc_dapm_mixer_update_power(struct snd_soc_dapm_context *dapm,
        int ret;
 
        mutex_lock_nested(&card->dapm_mutex, SND_SOC_DAPM_CLASS_RUNTIME);
-       dapm->update = update;
+       card->update = update;
        ret = soc_dapm_mixer_update_power(dapm, kcontrol, connect);
-       dapm->update = NULL;
+       card->update = NULL;
        mutex_unlock(&card->dapm_mutex);
        if (ret > 0)
                soc_dpcm_runtime_update(card);
@@ -2693,11 +2693,11 @@ int snd_soc_dapm_put_volsw(struct snd_kcontrol *kcontrol,
                update.mask = mask;
                update.val = val;
 
-               widget->dapm->update = &update;
+               card->update = &update;
 
                soc_dapm_mixer_update_power(widget->dapm, kcontrol, connect);
 
-               widget->dapm->update = NULL;
+               card->update = NULL;
        }
 
        mutex_unlock(&card->dapm_mutex);
@@ -2775,11 +2775,11 @@ int snd_soc_dapm_put_enum_double(struct snd_kcontrol *kcontrol,
                update.reg = e->reg;
                update.mask = mask;
                update.val = val;
-               widget->dapm->update = &update;
+               card->update = &update;
 
                soc_dapm_mux_update_power(widget->dapm, kcontrol, mux, e);
 
-               widget->dapm->update = NULL;
+               card->update = NULL;
        }
 
        mutex_unlock(&card->dapm_mutex);
@@ -2928,11 +2928,11 @@ int snd_soc_dapm_put_value_enum_double(struct snd_kcontrol *kcontrol,
                update.reg = e->reg;
                update.mask = mask;
                update.val = val;
-               widget->dapm->update = &update;
+               card->update = &update;
 
                soc_dapm_mux_update_power(widget->dapm, kcontrol, mux, e);
 
-               widget->dapm->update = NULL;
+               card->update = NULL;
        }
 
        mutex_unlock(&card->dapm_mutex);