Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2491736pxj; Mon, 10 May 2021 04:23:55 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwv0sFgr1p2oofF5a3Jf6PsAHp2ERPZtmHe/gC2gaUvVX0G0wpqk+hl89OBIk3zslgFbRpi X-Received: by 2002:aa7:c845:: with SMTP id g5mr29017132edt.219.1620645714030; Mon, 10 May 2021 04:21:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620645714; cv=none; d=google.com; s=arc-20160816; b=v0rKdduxWrX1k9PqCP3ZDSAwh3IjYiusWItJTuXgUTPpWx63AmCcoW8BE9dtNHBqAk GpRhVEEFWo2gm/XWyYdfT9WsFuIwF5KB2nswLJkhx432o9kIYTGCR9DokM0MHjRk/zHb P1cI025AqgT1rJi8xeqFLcwbQsJ8IpzxFjvSnefzN32snA1P6nnqXRbbGLVPLt5JQe3x VMp0Gj70MZF0SlYo+UFC9LeJCIH0+lHzYBaJIC46Q3uxBzmCEYS/UYE2U+x4Ru8YU9LD om+OVveHWHev48HTQZ9rKJPJ++0mSjGSbH/mTx5puZLbPnqYhAOj0O5iPYVkWAHmmkNP k9ng== 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=P0EYV2qvcNm83Lf18/lVoVM7PO8n7i1O1dP41dn/crQdLqazfZIus6x744ATy8OL6k 9F2jDILXUaNSi2wc8TxYcuE5SN7SLLED2ZAWnsgYp9qIp7gATvL8DVzbvhL9jEo7XdkZ baMV0q/C0hA1A07Nps/9wzXwO599Sk0PdJ40+3kpakoxrusIPb5NNhm6iWIX2dy+Me3f 7eIWS5MHbANx72vkYfzKzf97Mer+F/bnYBqNJGN3PHAAjhRZgi2GwkH1aC1bmMkpbQg4 8UfeT6i01wTL6vr1dWIA4Fp4aJqiffH1X7wpNrLrjAnxFQQF4HDg5xDHQc0Lz1rGZXq4 4sLg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=N4Q6jCpf; 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 a20si12806686edx.287.2021.05.10.04.21.30; Mon, 10 May 2021 04:21:54 -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=N4Q6jCpf; 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 S237374AbhEJLOu (ORCPT + 99 others); Mon, 10 May 2021 07:14:50 -0400 Received: from mail.kernel.org ([198.145.29.99]:32908 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233709AbhEJKuc (ORCPT ); Mon, 10 May 2021 06:50:32 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id BDEAD61951; Mon, 10 May 2021 10:39:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620643195; bh=C0kbrCsgyDr8o88l0aKatdUORPeRqWEa/ybH6nlAdZs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=N4Q6jCpf5YJENUjLJ4BKLbmLw8HxUu8wAIeIVYEfllCgT/vSshpR73S1dGNTXqWAT hvKvVPbzY91tAJ0JB52NA8/fT07pO0J2FnxfesYUW00R6QMxkkETM/0/rPVCXck323 uyZhycif5T1iIBtm4Hs89yjtxvKfx5x+3BPrHVm4= 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.10 216/299] ALSA: hda/realtek: fix mic boost on Intel NUC 8 Date: Mon, 10 May 2021 12:20:13 +0200 Message-Id: <20210510102012.078190135@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210510102004.821838356@linuxfoundation.org> References: <20210510102004.821838356@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),