ASoC: Force all DAPM contexts into the same bias state
authorMark Brown <broonie@opensource.wolfsonmicro.com>
Mon, 4 Apr 2011 12:05:11 +0000 (21:05 +0900)
committerMark Brown <broonie@opensource.wolfsonmicro.com>
Sat, 9 Apr 2011 02:24:08 +0000 (11:24 +0900)
Currently we allow all DAPM contexts to determine their own bias level.
While this should in general work in most situations and will deliver the
lowest possible power it causes problems for our integration with the
card bias level as we're calling the card bias level functions for each
DAPM context even though they're card wide but don't say which CODEC
we're calling them for. Mitigate against this by forcing everything to
be in the same state.

Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Acked-by: Liam Girdwood <lrg@ti.com>
sound/soc/soc-dapm.c

index 567645c0308bd405e8a349b9ecfccfd634cf3f0e..68879209b315607dfc6b72a02696445897fa9e17 100644 (file)
@@ -1101,6 +1101,15 @@ static int dapm_power_widgets(struct snd_soc_dapm_context *dapm, int event)
                }
        }
 
+       /* Force all contexts in the card to the same bias state */
+       power = 0;
+       list_for_each_entry(d, &card->dapm_list, list)
+               if (d->dev_power)
+                       power = 1;
+       list_for_each_entry(d, &card->dapm_list, list)
+               d->dev_power = power;
+
+
        /* Run all the bias changes in parallel */
        list_for_each_entry(d, &dapm->card->dapm_list, list)
                async_schedule_domain(dapm_pre_sequence_async, d,