Commit a836dbf6 authored by Takashi Iwai's avatar Takashi Iwai

ALSA: hda - Fix missing call of cmd flush in capture volume put callback

The capture volume put callback may call the node selection change,
and its actual call won't be triggered unless flushed.  In general,
we always need to call both snd_hda_codec_flush_amp_cache() and
snd_hda_codec_flush_cmd_cache() at the same place...
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent 4bd01e93
...@@ -2840,6 +2840,7 @@ static int cap_put_caller(struct snd_kcontrol *kcontrol, ...@@ -2840,6 +2840,7 @@ static int cap_put_caller(struct snd_kcontrol *kcontrol,
codec->cached_write = 0; codec->cached_write = 0;
mutex_unlock(&codec->control_mutex); mutex_unlock(&codec->control_mutex);
snd_hda_codec_flush_amp_cache(codec); /* flush the updates */ snd_hda_codec_flush_amp_cache(codec); /* flush the updates */
snd_hda_codec_flush_cmd_cache(codec);
if (err >= 0 && spec->cap_sync_hook) if (err >= 0 && spec->cap_sync_hook)
spec->cap_sync_hook(codec, ucontrol); spec->cap_sync_hook(codec, ucontrol);
return err; return err;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment