Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 148202
b: refs/heads/master
c: 6ea31b9
h: refs/heads/master
v: v3
  • Loading branch information
Mark Brown committed Apr 20, 2009
1 parent b9a2ded commit 557b9d9
Show file tree
Hide file tree
Showing 2 changed files with 49 additions and 34 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: cd0f2d4736ae8efabc60e54ecc8f677d0eddce02
refs/heads/master: 6ea31b9f0a0307e16656af27fcda3160e2a64a1b
81 changes: 48 additions & 33 deletions trunk/sound/soc/soc-dapm.c
Original file line number Diff line number Diff line change
Expand Up @@ -594,43 +594,58 @@ 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.
*/
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;

Expand All @@ -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;

Expand All @@ -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);
}
Expand Down

0 comments on commit 557b9d9

Please sign in to comment.