Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2545555pxj; Mon, 10 May 2021 05:37:31 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxISQxfSuDd7WwL3uZfvb/wABwN1KwKKVwyKRvfFMXeInIoWsAGdnsoxjnvj1CTn3NFpVdv X-Received: by 2002:a17:906:9141:: with SMTP id y1mr26631783ejw.111.1620650251555; Mon, 10 May 2021 05:37:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620650251; cv=none; d=google.com; s=arc-20160816; b=YYMr0ZLgzVJN19K/fm4ZU2t6ryn13S2r3Le3IXXFrbXvenlj5i7IbAbRCIKqLOfL7a KlXD3gwF5XpMhOoPq9ipQjGqdkiagmquOLyVJ+LncLwhtOUWxHntJnrlKoH4hafg1MNq vzaA5aYZqcaqjAUqsE084i+xABD9e5LfVi3uyxTnRKu5Favr3IB+LT0NbJUph2IRc7mk kDmue6vPrxnYVa3b58AD06Lp2qr8gK3u2px+9De6Pkm6WeXLSTNmCqq+7Iax04Ac00Vx q/5OwPw32fvq81xW3J+OojdnxpAUz83ZZDeQlyV+Mfu5WOVRwYdI8vRrd+MCFdhCbIUz iyhw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=fEBplo6YJbu4ob15yAKevH07rSVRtTop4io2v3z287U=; b=cSYcuK5RYkg7swRe0AQCQkYTtR8/7+HwyrnshN7sAZsw/sEziZMJBrctr1h3K/1hDk emmUwY+rqXURqid4WVM2hOlTMZEl5h7wqnjxoAI+BUVnAwf5I/3iTRfJqyTXqRfOyKK5 xhsUFVwIhnPdXUjjfr38zdF7KJxh8Zddu4hR586VUtUyafG84qcgfvmwQ1Hwa4suvXVb M45ZU78ltTBSUHWOHC1MPQmIe9gjslIwiNiTEIhxjRUk5bNtvri+ZDqOh5wlyfE+RT7a cEiQngQCljAkGCH50fD1BjsNEQPWPsU/Ss1x8cuJYNVVJqvmtnRK8987eMeCWnFdq5E0 uj5g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=zF8nZac5; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id mh7si13367695ejb.585.2021.05.10.05.37.06; Mon, 10 May 2021 05:37:31 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=zF8nZac5; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238790AbhEJM30 (ORCPT + 99 others); Mon, 10 May 2021 08:29:26 -0400 Received: from mail.kernel.org ([198.145.29.99]:46276 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237287AbhEJLLs (ORCPT ); Mon, 10 May 2021 07:11:48 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 1A6CD6192D; Mon, 10 May 2021 11:08:37 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620644918; bh=C0kbrCsgyDr8o88l0aKatdUORPeRqWEa/ybH6nlAdZs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=zF8nZac5pk14n+xpzn/HcXZxNgyUYXst6+Jlf5Ef2R7/XBeIlBQztlzU8VMHETKy5 0BSKdi64lBMi3L09XpioO4mfQNwxcUUldqSFP8jCHNjMLBZcCTtdppukHuneJLLQzs rrY5fU2XpGTkhtN2rnX/snOXtWbOtFlK8OWaNz1s= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Phil Calvin , Takashi Iwai Subject: [PATCH 5.12 278/384] ALSA: hda/realtek: fix mic boost on Intel NUC 8 Date: Mon, 10 May 2021 12:21:07 +0200 Message-Id: <20210510102023.992246430@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210510102014.849075526@linuxfoundation.org> References: <20210510102014.849075526@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Phil Calvin commit d1ee66c5d3c5a0498dd5e3f2af5b8c219a98bba5 upstream. Fix two bugs with the Intel HDA Realtek ALC233 sound codec present in Intel NUC NUC8i7BEH and probably a few other similar NUC models. These codecs advertise a 4-level microphone input boost amplifier on pin 0x19, but the highest two boost settings do not work correctly, and produce only low analog noise that does not seem to contain any discernible signal. There is an existing fixup for this exact problem but for a different PCI subsystem ID, so we re-use that logic. Changing the boost level also triggers a DC spike in the input signal that bleeds off over about a second and overwhelms any input during that time. Thankfully, the existing fixup has the side effect of making the boost control show up in userspace as a mute/unmute switch, and this keeps (e.g.) PulseAudio from fiddling with it during normal input volume adjustments. Finally, the NUC hardware has built-in inverted stereo mics. This patch also enables the usual fixup for this so the two channels cancel noise instead of the actual signal. [ Re-ordered the quirk entry point by tiwai ] Signed-off-by: Phil Calvin Cc: Link: https://lore.kernel.org/r/80dc5663-7734-e7e5-25ef-15b5df24511a@philcalvin.com Signed-off-by: Takashi Iwai Signed-off-by: Greg Kroah-Hartman --- sound/pci/hda/patch_realtek.c | 13 +++++++++++++ 1 file changed, 13 insertions(+) --- a/sound/pci/hda/patch_realtek.c +++ b/sound/pci/hda/patch_realtek.c @@ -6435,6 +6435,8 @@ enum { ALC269_FIXUP_LEMOTE_A1802, ALC269_FIXUP_LEMOTE_A190X, ALC256_FIXUP_INTEL_NUC8_RUGGED, + ALC233_FIXUP_INTEL_NUC8_DMIC, + ALC233_FIXUP_INTEL_NUC8_BOOST, ALC256_FIXUP_INTEL_NUC10, ALC255_FIXUP_XIAOMI_HEADSET_MIC, ALC274_FIXUP_HP_MIC, @@ -7156,6 +7158,16 @@ static const struct hda_fixup alc269_fix .type = HDA_FIXUP_FUNC, .v.func = alc233_fixup_lenovo_line2_mic_hotkey, }, + [ALC233_FIXUP_INTEL_NUC8_DMIC] = { + .type = HDA_FIXUP_FUNC, + .v.func = alc_fixup_inv_dmic, + .chained = true, + .chain_id = ALC233_FIXUP_INTEL_NUC8_BOOST, + }, + [ALC233_FIXUP_INTEL_NUC8_BOOST] = { + .type = HDA_FIXUP_FUNC, + .v.func = alc269_fixup_limit_int_mic_boost + }, [ALC255_FIXUP_DELL_SPK_NOISE] = { .type = HDA_FIXUP_FUNC, .v.func = alc_fixup_disable_aamix, @@ -8305,6 +8317,7 @@ static const struct snd_pci_quirk alc269 SND_PCI_QUIRK(0x10ec, 0x118c, "Medion EE4254 MD62100", ALC256_FIXUP_MEDION_HEADSET_NO_PRESENCE), SND_PCI_QUIRK(0x1c06, 0x2013, "Lemote A1802", ALC269_FIXUP_LEMOTE_A1802), SND_PCI_QUIRK(0x1c06, 0x2015, "Lemote A190X", ALC269_FIXUP_LEMOTE_A190X), + SND_PCI_QUIRK(0x8086, 0x2074, "Intel NUC 8", ALC233_FIXUP_INTEL_NUC8_DMIC), SND_PCI_QUIRK(0x8086, 0x2080, "Intel NUC 8 Rugged", ALC256_FIXUP_INTEL_NUC8_RUGGED), SND_PCI_QUIRK(0x8086, 0x2081, "Intel NUC 10", ALC256_FIXUP_INTEL_NUC10),