[alsa-devel] [PATCH 2/2] ALSA: hda - Add workarounds for pop-noise on Chromebook with ALC283
David Henningsson
david.henningsson at canonical.com
Thu Aug 22 11:45:57 CEST 2013
On 08/22/2013 10:21 AM, Takashi Iwai wrote:
> From: Kailang Yang <kailang at realtek.com>
>
> The headphone automute on this machine triggers annoying pop noises.
> It seems that only the first DAC can be used, the secondary DAC always
> results in this problem. This patch disables the secondary DAC with
> a few additional workarounds.
Interesting. I have not heard of any such problems on the ALC283
machines we have been dealing with. But a secondary DAC problem does
sound like something codec specific rather than machine specific...
Also a nitpick: It's probably Chromebook, not ChromeBook or Chrome_book.
>
> Signed-off-by: Kailang Yang <kailang at realtek.com>
> Signed-off-by: Takashi Iwai <tiwai at suse.de>
> ---
> sound/pci/hda/patch_realtek.c | 45 +++++++++++++++++++++++++++++++++++++++++++
> 1 file changed, 45 insertions(+)
>
> diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c
> index 4bdccd1..a97dbba 100644
> --- a/sound/pci/hda/patch_realtek.c
> +++ b/sound/pci/hda/patch_realtek.c
> @@ -3394,6 +3394,45 @@ static void alc269_fixup_limit_int_mic_boost(struct hda_codec *codec,
> }
> }
>
> +static void alc283_hp_automute_hook(struct hda_codec *codec,
> + struct hda_jack_tbl *jack)
> +{
> + struct alc_spec *spec = codec->spec;
> + int vref;
> +
> + msleep(200);
> + snd_hda_gen_hp_automute(codec, jack);
> +
> + vref = spec->gen.hp_jack_present ? PIN_VREF80 : 0;
> +
> + msleep(600);
> + snd_hda_codec_write(codec, 0x19, 0, AC_VERB_SET_PIN_WIDGET_CONTROL,
> + vref);
> +}
> +
> +static void alc283_chromebook_caps(struct hda_codec *codec)
> +{
> + snd_hda_override_wcaps(codec, 0x03, 0);
> +}
> +
> +static void alc283_fixup_chromebook(struct hda_codec *codec,
> + const struct hda_fixup *fix, int action)
> +{
> + struct alc_spec *spec = codec->spec;
> + int val;
> +
> + switch (action) {
> + case HDA_FIXUP_ACT_PRE_PROBE:
> + alc283_chromebook_caps(codec);
> + spec->gen.hp_automute_hook = alc283_hp_automute_hook;
> + /* MIC2-VREF control */
> + /* Set to manual mode */
> + val = alc_read_coef_idx(codec, 0x06);
> + alc_write_coef_idx(codec, 0x06, val & ~0x000c);
> + break;
> + }
> +}
> +
> enum {
> ALC269_FIXUP_SONY_VAIO,
> ALC275_FIXUP_SONY_VAIO_GPIO2,
> @@ -3430,6 +3469,7 @@ enum {
> ALC269_FIXUP_ACER_AC700,
> ALC269_FIXUP_LIMIT_INT_MIC_BOOST,
> ALC269VB_FIXUP_ORDISSIMO_EVE2,
> + ALC283_FIXUP_CHROME_BOOK,
> };
>
> static const struct hda_fixup alc269_fixups[] = {
> @@ -3681,6 +3721,10 @@ static const struct hda_fixup alc269_fixups[] = {
> { }
> },
> },
> + [ALC283_FIXUP_CHROME_BOOK] = {
> + .type = HDA_FIXUP_FUNC,
> + .v.func = alc283_fixup_chromebook,
> + },
> };
>
> static const struct snd_pci_quirk alc269_fixup_tbl[] = {
> @@ -3729,6 +3773,7 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = {
> SND_PCI_QUIRK(0x103c, 0x1973, "HP Pavilion", ALC269_FIXUP_HP_MUTE_LED_MIC1),
> SND_PCI_QUIRK(0x103c, 0x1983, "HP Pavilion", ALC269_FIXUP_HP_MUTE_LED_MIC1),
> SND_PCI_QUIRK_VENDOR(0x103c, "HP", ALC269_FIXUP_HP_MUTE_LED),
> + SND_PCI_QUIRK(0x103c, 0x21ed, "HP Falco ChromeBook", ALC283_FIXUP_CHROME_BOOK),
> SND_PCI_QUIRK(0x1043, 0x106d, "Asus K53BE", ALC269_FIXUP_LIMIT_INT_MIC_BOOST),
> SND_PCI_QUIRK(0x1043, 0x115d, "Asus 1015E", ALC269_FIXUP_LIMIT_INT_MIC_BOOST),
> SND_PCI_QUIRK(0x1043, 0x1427, "Asus Zenbook UX31E", ALC269VB_FIXUP_DMIC),
>
--
David Henningsson, Canonical Ltd.
https://launchpad.net/~diwic
More information about the Alsa-devel
mailing list