Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2509908pxj; Mon, 10 May 2021 04:51:45 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyMH2fIsKfrzpp4wt1TXs2l7DPUCeoUgsbcGJxLCKPibGqeSf65dQAmDwLm1DCJjLFLLA1j X-Received: by 2002:a17:906:c0d6:: with SMTP id bn22mr25613446ejb.267.1620647504819; Mon, 10 May 2021 04:51:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620647504; cv=none; d=google.com; s=arc-20160816; b=jiLA9+KsnmepOLROG60YO81RufaZyvVhTmvAKoy7YbogXk+u2BdXcrQWhLokHlzLX5 6zm6nwV+ezmoqkTfPv5Ce08+8dv7BpxurSHqz6EJTwnMBDY5CH4Tm/KTJSlZNioUw9bH /o+N9EiJAQ3c/cN6ZjyqCzv7rJnXhgObS1THcXKNgdIleY0CPF+dZ8e9/0svl4+40uWp iDp9mjyFJ8uzrJ0Q+u4X4E3Jcmg/OVX9k9/bTzW/BOOrDVTtKr3oGOOboNUgwhbcVg2T fvrxKtL9wB+v+adJwRC/LStsZnTN/NMC4eDr+BBylgD2lAC4CvZWKDABXAlk51mj8ZRn 9hqQ== 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=gXKfouI2IM9ZRo2AeeWTLkgSjpo+r/3Znr8irakDPOuM7CijkhWUTaM+WHC1spG+nq Hq0FlPSI/2wdQO+9Pi+qpRSssHxpGi9bdjzze8YsoQs/rrJbNlOGvjU2WyqByf2d9DlS fgmaU/0aXBLZ2u+9x8X1UgJqhZVvS3Pz7fvM5MxHOwLfu6XSP871ZC+zHHGby4sFPZIk GGIKo+FfNhh/JxnYrI4RJps1dF4FqwHmzf4G/GOhTNm3Je34w3AnojaA0SOvQbM+F5FC 3oiuBfyVZl+QuByQiNZPKRn9K9TLFMU2eanG1uSFcEfBU1jMUGg0n5pjlR6iNZjIicBG nwmw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=G9CR78+d; 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 x16si14459588edd.495.2021.05.10.04.51.20; Mon, 10 May 2021 04:51:44 -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=G9CR78+d; 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 S243215AbhEJLsT (ORCPT + 99 others); Mon, 10 May 2021 07:48:19 -0400 Received: from mail.kernel.org ([198.145.29.99]:36380 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231951AbhEJLBo (ORCPT ); Mon, 10 May 2021 07:01:44 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id F2C9F61C52; Mon, 10 May 2021 10:53:37 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620644018; bh=C0kbrCsgyDr8o88l0aKatdUORPeRqWEa/ybH6nlAdZs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=G9CR78+di83qjzmLCEjhF6pib/ZJukKBB/+O6N9uoqvcZ3xm/HJJrI6JFVSL4z1lJ ZCvK2zRJF8KttVRgQs/cxD28A5YHNYGXIci/LsVTz9edwnwtpcwwXNFQq1c0nVTXeZ U0xC0wXN6XhpIGYBStrMvUD7xBkP0sZecKL0bSJg= 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.11 247/342] ALSA: hda/realtek: fix mic boost on Intel NUC 8 Date: Mon, 10 May 2021 12:20:37 +0200 Message-Id: <20210510102018.244352578@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210510102010.096403571@linuxfoundation.org> References: <20210510102010.096403571@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),