diff options
author | Takashi Iwai <tiwai@suse.de> | 2016-05-10 04:24:02 -0400 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2016-05-10 04:30:13 -0400 |
commit | addacd801e1638f41d659cb53b9b73fc14322cb1 (patch) | |
tree | b32244e256cfee9a5a62740ba393d1d95e0ca978 | |
parent | 2da2dc9ead232f25601404335cca13c0f722d41b (diff) |
ALSA: hda - Fix broken reconfig
The HD-audio reconfig function got broken in the recent kernels,
typically resulting in a failure like:
snd_hda_intel 0000:00:1b.0: control 3:0:0:Playback Channel Map:0 is already present
This is because of the code restructuring to move the PCM and control
instantiation into the codec drive probe, by the commit [bcd96557bd0a:
ALSA: hda - Build PCMs and controls at codec driver probe]. Although
the commit above removed the calls of snd_hda_codec_build_pcms() and
*_build_controls() at the controller driver probe, the similar calls
in the reconfig were still left forgotten. This caused the
conflicting and duplicated PCMs and controls.
The fix is trivial: just remove these superfluous calls from
reconfig_codec().
Fixes: bcd96557bd0a ('ALSA: hda - Build PCMs and controls at codec driver probe')
Reported-by: Jochen Henneberg <jh@henneberg-systemdesign.com>
Cc: <stable@vger.kernel.org> # v4.1+
Signed-off-by: Takashi Iwai <tiwai@suse.de>
-rw-r--r-- | sound/pci/hda/hda_sysfs.c | 8 |
1 files changed, 0 insertions, 8 deletions
diff --git a/sound/pci/hda/hda_sysfs.c b/sound/pci/hda/hda_sysfs.c index 64e0d1d81ca5..9739fce9e032 100644 --- a/sound/pci/hda/hda_sysfs.c +++ b/sound/pci/hda/hda_sysfs.c | |||
@@ -141,14 +141,6 @@ static int reconfig_codec(struct hda_codec *codec) | |||
141 | err = snd_hda_codec_configure(codec); | 141 | err = snd_hda_codec_configure(codec); |
142 | if (err < 0) | 142 | if (err < 0) |
143 | goto error; | 143 | goto error; |
144 | /* rebuild PCMs */ | ||
145 | err = snd_hda_codec_build_pcms(codec); | ||
146 | if (err < 0) | ||
147 | goto error; | ||
148 | /* rebuild mixers */ | ||
149 | err = snd_hda_codec_build_controls(codec); | ||
150 | if (err < 0) | ||
151 | goto error; | ||
152 | err = snd_card_register(codec->card); | 144 | err = snd_card_register(codec->card); |
153 | error: | 145 | error: |
154 | snd_hda_power_down(codec); | 146 | snd_hda_power_down(codec); |