summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTakashi Iwai <tiwai@suse.de>2009-07-03 23:06:45 +0200
committerTakashi Iwai <tiwai@suse.de>2009-07-03 23:06:45 +0200
commit70d321e6380f128096429d6e5b678f94ab0cef5d (patch)
tree56286692fb6f3738c87572d29affee6862046b76
parentALSA: hda - Avoid invalid formats and rates with shared SPDIF (diff)
downloadlinux-70d321e6380f128096429d6e5b678f94ab0cef5d.tar.xz
linux-70d321e6380f128096429d6e5b678f94ab0cef5d.zip
ALSA: hda - Call snd_pcm_lib_hw_rates() again after codec open callback
The PCM rates bit field may have been changed by the codec open callback. In that case, we need to reset rate_min and rate_max. So, simply call snd_pcm_lib_hw_rates() again after the codec open callback. Signed-off-by: Takashi Iwai <tiwai@suse.de>
-rw-r--r--sound/pci/hda/hda_intel.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/sound/pci/hda/hda_intel.c b/sound/pci/hda/hda_intel.c
index 4e9ea7080270..b36dc46615a4 100644
--- a/sound/pci/hda/hda_intel.c
+++ b/sound/pci/hda/hda_intel.c
@@ -1454,6 +1454,7 @@ static int azx_pcm_open(struct snd_pcm_substream *substream)
mutex_unlock(&chip->open_mutex);
return err;
}
+ snd_pcm_limit_hw_rates(runtime);
spin_lock_irqsave(&chip->reg_lock, flags);
azx_dev->substream = substream;
azx_dev->running = 0;