summaryrefslogtreecommitdiff
path: root/sound/soc/soc-dapm.c
diff options
context:
space:
mode:
authorMark Brown <broonie@opensource.wolfsonmicro.com>2009-04-20 17:15:41 +0100
committerMark Brown <broonie@opensource.wolfsonmicro.com>2009-04-20 18:09:41 +0100
commit6ea31b9f0a0307e16656af27fcda3160e2a64a1b (patch)
tree9f7ace6b793a4eff0936dc5ff7d81afb2c0a87c9 /sound/soc/soc-dapm.c
parentcd0f2d4736ae8efabc60e54ecc8f677d0eddce02 (diff)
downloadlwn-6ea31b9f0a0307e16656af27fcda3160e2a64a1b.tar.gz
lwn-6ea31b9f0a0307e16656af27fcda3160e2a64a1b.zip
ASoC: Factor out DAPM power checks for DACs and ADCs
This also switches us to using a switch statement for the widget type in dapm_power_widget(). Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Diffstat (limited to 'sound/soc/soc-dapm.c')
-rw-r--r--sound/soc/soc-dapm.c81
1 files changed, 48 insertions, 33 deletions
diff --git a/sound/soc/soc-dapm.c b/sound/soc/soc-dapm.c
index 28e6e324ccfb..22522e2d83a4 100644
--- a/sound/soc/soc-dapm.c
+++ b/sound/soc/soc-dapm.c
@@ -594,6 +594,34 @@ static int dapm_generic_check_power(struct snd_soc_dapm_widget *w)
return out != 0 && in != 0;
}
+/* Check to see if an ADC has power */
+static int dapm_adc_check_power(struct snd_soc_dapm_widget *w)
+{
+ int in;
+
+ if (w->active) {
+ in = is_connected_input_ep(w);
+ dapm_clear_walk(w->codec);
+ return in != 0;
+ } else {
+ return dapm_generic_check_power(w);
+ }
+}
+
+/* Check to see if a DAC has power */
+static int dapm_dac_check_power(struct snd_soc_dapm_widget *w)
+{
+ int out;
+
+ if (w->active) {
+ out = is_connected_output_ep(w);
+ dapm_clear_walk(w->codec);
+ return out != 0;
+ } else {
+ return dapm_generic_check_power(w);
+ }
+}
+
/*
* Scan a single DAPM widget for a complete audio path and update the
* power status appropriately.
@@ -601,36 +629,23 @@ static int dapm_generic_check_power(struct snd_soc_dapm_widget *w)
static int dapm_power_widget(struct snd_soc_codec *codec, int event,
struct snd_soc_dapm_widget *w)
{
- int in, out, power_change, power, ret;
+ int power, ret;
- /* vmid - no action */
- if (w->id == snd_soc_dapm_vmid)
+ /* Work out the new power state */
+ switch (w->id) {
+ case snd_soc_dapm_vmid:
+ /* No action required */
return 0;
- /* active ADC */
- if (w->id == snd_soc_dapm_adc && w->active) {
- in = is_connected_input_ep(w);
- dapm_clear_walk(w->codec);
- power = (in != 0) ? 1 : 0;
- if (power == w->power)
- return 0;
- w->power = power;
- return dapm_generic_apply_power(w);
- }
+ case snd_soc_dapm_adc:
+ power = dapm_adc_check_power(w);
+ break;
- /* active DAC */
- if (w->id == snd_soc_dapm_dac && w->active) {
- out = is_connected_output_ep(w);
- dapm_clear_walk(w->codec);
- power = (out != 0) ? 1 : 0;
- if (power == w->power)
- return 0;
- w->power = power;
- return dapm_generic_apply_power(w);
- }
+ case snd_soc_dapm_dac:
+ power = dapm_dac_check_power(w);
+ break;
- /* pre and post event widgets */
- if (w->id == snd_soc_dapm_pre) {
+ case snd_soc_dapm_pre:
if (!w->event)
return 0;
@@ -646,8 +661,8 @@ static int dapm_power_widget(struct snd_soc_codec *codec, int event,
return ret;
}
return 0;
- }
- if (w->id == snd_soc_dapm_post) {
+
+ case snd_soc_dapm_post:
if (!w->event)
return 0;
@@ -663,15 +678,15 @@ static int dapm_power_widget(struct snd_soc_codec *codec, int event,
return ret;
}
return 0;
- }
- /* all other widgets */
- power = dapm_generic_check_power(w);
- power_change = (w->power == power) ? 0 : 1;
- w->power = power;
+ default:
+ power = dapm_generic_check_power(w);
+ break;
+ }
- if (!power_change)
+ if (w->power == power)
return 0;
+ w->power = power;
return dapm_generic_apply_power(w);
}