22 Apr
2015
22 Apr
'15
1 p.m.
On Tue, Apr 21, 2015 at 01:33:55PM +0100, Richard Fitzgerald wrote:
+static int wm8998_in1mux_ev(struct snd_soc_dapm_widget *w,
struct snd_kcontrol *kcontrol,
int event)
+{
- struct snd_soc_codec *codec = snd_soc_dapm_to_codec(w->dapm);
- struct arizona *arizona = dev_get_drvdata(codec->dev->parent);
- unsigned int left_mux, right_mux, in1mode, old;
- switch (event) {
- case SND_SOC_DAPM_PRE_PMU:
/* Validate the mux configuration */
left_mux = snd_soc_read(codec, ARIZONA_ADC_DIGITAL_VOLUME_1L) &
ARIZONA_IN1L_SRC_MASK;
right_mux = snd_soc_read(codec, ARIZONA_ADC_DIGITAL_VOLUME_1R) &
ARIZONA_IN1R_SRC_MASK;
/* Only IN1A can be digital, IN1B is always analogue */
in1mode = (arizona->pdata.inmode[0] & 2)
<< (ARIZONA_IN1_MODE_SHIFT - 1);
if (in1mode != 0) {
/* if IN1A is digital, the only valid mux configs
* are both channels A or both channels B.
*/
if (left_mux != right_mux) {
dev_err(arizona->dev,
"IN1=DMIC and IN1L Mux != IN1R Mux");
return -EINVAL;
}
This (or at least some of it) seems like something we should be doing by registering different widgets and routing at device probe time.
old = snd_soc_read(codec, ARIZONA_IN1L_CONTROL) &
ARIZONA_IN1_MODE_MASK;
if (old != in1mode)
snd_soc_update_bits(codec, ARIZONA_IN1L_CONTROL,
ARIZONA_IN1_MODE_MASK, in1mode);
Why bother with the read into old here? Suppressing redundant updates is part of the point of snd_soc_update_bits().