diff options
author | Takashi Iwai <tiwai@suse.de> | 2007-05-29 19:01:37 +0200 |
---|---|---|
committer | Jaroslav Kysela <perex@suse.cz> | 2007-05-31 09:06:04 +0200 |
commit | 897cc188f7f0e402b92a4a6a9e234b45c612eb42 (patch) | |
tree | 7bca2864d67a183c9901f0c0fd1bae6c24e77579 /sound/pci/hda/patch_sigmatel.c | |
parent | f9acba4347ac2145456aa8dedaab3d74761da42a (diff) | |
download | talos-obmc-linux-897cc188f7f0e402b92a4a6a9e234b45c612eb42.tar.gz talos-obmc-linux-897cc188f7f0e402b92a4a6a9e234b45c612eb42.zip |
[ALSA] hda-codec - Fix STAC922x capture boost level
STAC922x provides the capture boost level up to 4, but actually it
works only up to 2. Since the range of the mixer is automatically
defined from amp-capability bits, we need to override the value
beforehand. snd_hda_override_amp_caps() is introduced for this
purpose.
The function patch_stac922x() calls this for NID 0x12 (Mux Capture
Volume). This should fix another recording problem on Intel Macs.
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Signed-off-by: Jaroslav Kysela <perex@suse.cz>
Diffstat (limited to 'sound/pci/hda/patch_sigmatel.c')
-rw-r--r-- | sound/pci/hda/patch_sigmatel.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/sound/pci/hda/patch_sigmatel.c b/sound/pci/hda/patch_sigmatel.c index 33fc7cd00935..e3964fc4c405 100644 --- a/sound/pci/hda/patch_sigmatel.c +++ b/sound/pci/hda/patch_sigmatel.c @@ -2159,6 +2159,13 @@ static int patch_stac927x(struct hda_codec *codec) codec->patch_ops = stac92xx_patch_ops; + /* Fix Mux capture level; max to 2 */ + snd_hda_override_amp_caps(codec, 0x12, HDA_OUTPUT, + (0 << AC_AMPCAP_OFFSET_SHIFT) | + (2 << AC_AMPCAP_NUM_STEPS_SHIFT) | + (0x27 << AC_AMPCAP_STEP_SIZE_SHIFT) | + (0 << AC_AMPCAP_MUTE_SHIFT)); + return 0; } |