Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp379350pxb; Mon, 25 Oct 2021 10:03:15 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzJwRDOoRfTHc9/LZkqwejT20Vcno7z8BEVDVAwqG0FbwNoInClVCm+zYR8fQntW6S37Fv9 X-Received: by 2002:a17:906:140b:: with SMTP id p11mr23747946ejc.116.1635181395283; Mon, 25 Oct 2021 10:03:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1635181395; cv=none; d=google.com; s=arc-20160816; b=SJMIIp4QoV1LOckENjFy6qp4J8pdKwBuzcGag/Ah5W7kGJ5BzZk4Fw42OmOCXspnW/ Sb5MvzdMn96TAgGjVl50fjIds/kVVutLYeyB+06nist2U2koZx4SUoZ4zOAZ8g6yiFXt V00gcC5mGHVMczYw47tsMzFgJXlMHjaBYme/jtiEoyBExz6b6z2R8d5zgoHTBsJG4FXz zKx9iHJDpWJiEmAbxtCLsIFTBEr9UaO9I0Ex45q3aW43WQgTLKSAUA/zhuNlfBc7NmoR 20d3Vb1ogKrDdCxHDIZfabsjhO8pZgVWocqhrRZXr5QCK72twXV2Bv2rKvMWnhwBJWv5 Ldxw== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=gMuktMQtyU3A4k6DVbyuDWCU9/rS0+EmVtb05HiHGmI=; b=ltuCaslUkBM2YmhP3srBH8nBYxkGP5AhR7SQN9huGMYvL1aCFwC0iCzP2HnHqf4EOI P7ADnbise9/MxGsJPVNCB3YX2o7aasxXo+BfFSIiT6SaMUW0AwcBKPHI0b7inAMAfZqG Ynze4k6NXExBRHQ2PNfrC2y6MADxb9Err5VnIoNwY53AxWxFR4tj3HedrLwOO+Q+hJ4Y XDAT9TxMSvNdIWgisYkWcknExZFds31VGrxEt5Y8B7q5Anz9y2shFUN90CngMGQgW0lc UG2+eguhJvlb2CvL4oSCZ0hE9o+qCZ8v0fwaA4bMxfbLeBYgk1BXtHwYkZkGediswCE8 btiw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=YJXeIOTX; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i10si35041727edc.196.2021.10.25.10.02.44; Mon, 25 Oct 2021 10:03:15 -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=@kernel.org header.s=k20201202 header.b=YJXeIOTX; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234190AbhJYRCR (ORCPT + 99 others); Mon, 25 Oct 2021 13:02:17 -0400 Received: from mail.kernel.org ([198.145.29.99]:54594 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234197AbhJYRCN (ORCPT ); Mon, 25 Oct 2021 13:02:13 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 60BE560E97; Mon, 25 Oct 2021 16:59:49 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1635181191; bh=hmxSbDvM4ZcRl+Fcq6W66HT1l11XXxkQzDz0t4FTSg0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=YJXeIOTXtPPwMyjnEUzFcmRAfZEv8k7J4SRiq2jK11GC4R5P4JOrQRLD0z7Ai5sdD jLNagpW5ddBEzu5J3WS2I/xJ5z5SIkJNttTvVy8IZfUTaMX2zI9TZN/27zMV+3Y/Tw Exrayqzx8hclzm5we8WF8ZSC/NdmjWDz8TsrsAWlGvZCkmjTqQX7XJ3421SAWxEbYV cr8DViF8FdtlwfObMTCwk0+6e5cG8vKl0GuukLqYO6sIP3clQ+Uj/YDW+dQxCu0Yya 5FFm/Zfq2gPFLzEKZ4XXGRI2n3Gb3DafDsDhpyRo7is7xTHB3e74PJfdEanBnzx/Kn 63bqPFEKz2GGw== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Davide Baldo , Takashi Iwai , Sasha Levin , perex@perex.cz, tiwai@suse.com, jeremy.szu@canonical.com, kailang@realtek.com, hui.wang@canonical.com, chris.chiu@canonical.com, cam@neo-zeon.de, pshou@realtek.com, wse@tuxedocomputers.com, sami@loone.fi, eliadevito@gmail.com, alsa-devel@alsa-project.org Subject: [PATCH AUTOSEL 5.14 05/18] ALSA: hda/realtek: Fixes HP Spectre x360 15-eb1xxx speakers Date: Mon, 25 Oct 2021 12:59:18 -0400 Message-Id: <20211025165939.1393655-5-sashal@kernel.org> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20211025165939.1393655-1-sashal@kernel.org> References: <20211025165939.1393655-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Davide Baldo [ Upstream commit d94befbb5ae379f6dfd4fa6d460eacc09fa7b9c3 ] In laptop 'HP Spectre x360 Convertible 15-eb1xxx/8811' both front and rear speakers are silent, this patch fixes that by overriding the pin layout and by initializing the amplifier which needs a GPIO pin to be set to 1 then 0, similar to the existing HP Spectre x360 14 model. In order to have volume control, both front and rear speakers were forced to use the DAC1. This patch also correctly map the mute LED but since there is no microphone on/off switch exposed by the alsa subsystem it never turns on by itself. There are still known audio issues in this laptop: headset microphone doesn't work, the button to mute/unmute microphone is not yet mapped, the LED of the mute/unmute speakers doesn't seems to be exposed via GPIO and never turns on. BugLink: https://bugzilla.kernel.org/show_bug.cgi?id=213953 Signed-off-by: Davide Baldo Link: https://lore.kernel.org/r/20211015072121.5287-1-davide@baldo.me Signed-off-by: Takashi Iwai Signed-off-by: Sasha Levin --- sound/pci/hda/patch_realtek.c | 46 +++++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c index 8e6ff50f0f94..a628b2c050bd 100644 --- a/sound/pci/hda/patch_realtek.c +++ b/sound/pci/hda/patch_realtek.c @@ -6418,6 +6418,44 @@ static void alc_fixup_no_int_mic(struct hda_codec *codec, } } +/* GPIO1 = amplifier on/off + * GPIO3 = mic mute LED + */ +static void alc285_fixup_hp_spectre_x360_eb1(struct hda_codec *codec, + const struct hda_fixup *fix, int action) +{ + static const hda_nid_t conn[] = { 0x02 }; + + struct alc_spec *spec = codec->spec; + static const struct hda_pintbl pincfgs[] = { + { 0x14, 0x90170110 }, /* front/high speakers */ + { 0x17, 0x90170130 }, /* back/bass speakers */ + { } + }; + + //enable micmute led + alc_fixup_hp_gpio_led(codec, action, 0x00, 0x04); + + switch (action) { + case HDA_FIXUP_ACT_PRE_PROBE: + spec->micmute_led_polarity = 1; + /* needed for amp of back speakers */ + spec->gpio_mask |= 0x01; + spec->gpio_dir |= 0x01; + snd_hda_apply_pincfgs(codec, pincfgs); + /* share DAC to have unified volume control */ + snd_hda_override_conn_list(codec, 0x14, ARRAY_SIZE(conn), conn); + snd_hda_override_conn_list(codec, 0x17, ARRAY_SIZE(conn), conn); + break; + case HDA_FIXUP_ACT_INIT: + /* need to toggle GPIO to enable the amp of back speakers */ + alc_update_gpio_data(codec, 0x01, true); + msleep(100); + alc_update_gpio_data(codec, 0x01, false); + break; + } +} + static void alc285_fixup_hp_spectre_x360(struct hda_codec *codec, const struct hda_fixup *fix, int action) { @@ -6570,6 +6608,7 @@ enum { ALC269_FIXUP_HP_DOCK_GPIO_MIC1_LED, ALC280_FIXUP_HP_9480M, ALC245_FIXUP_HP_X360_AMP, + ALC285_FIXUP_HP_SPECTRE_X360_EB1, ALC288_FIXUP_DELL_HEADSET_MODE, ALC288_FIXUP_DELL1_MIC_NO_PRESENCE, ALC288_FIXUP_DELL_XPS_13, @@ -8263,6 +8302,10 @@ static const struct hda_fixup alc269_fixups[] = { .type = HDA_FIXUP_FUNC, .v.func = alc285_fixup_hp_spectre_x360, }, + [ALC285_FIXUP_HP_SPECTRE_X360_EB1] = { + .type = HDA_FIXUP_FUNC, + .v.func = alc285_fixup_hp_spectre_x360_eb1 + }, [ALC287_FIXUP_IDEAPAD_BASS_SPK_AMP] = { .type = HDA_FIXUP_FUNC, .v.func = alc285_fixup_ideapad_s740_coef, @@ -8597,6 +8640,8 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = { SND_PCI_QUIRK(0x103c, 0x87f7, "HP Spectre x360 14", ALC245_FIXUP_HP_X360_AMP), SND_PCI_QUIRK(0x103c, 0x8805, "HP ProBook 650 G8 Notebook PC", ALC236_FIXUP_HP_GPIO_LED), SND_PCI_QUIRK(0x103c, 0x880d, "HP EliteBook 830 G8 Notebook PC", ALC285_FIXUP_HP_GPIO_LED), + SND_PCI_QUIRK(0x103c, 0x8811, "HP Spectre x360 15-eb1xxx", ALC285_FIXUP_HP_SPECTRE_X360_EB1), + SND_PCI_QUIRK(0x103c, 0x8812, "HP Spectre x360 15-eb1xxx", ALC285_FIXUP_HP_SPECTRE_X360_EB1), SND_PCI_QUIRK(0x103c, 0x8846, "HP EliteBook 850 G8 Notebook PC", ALC285_FIXUP_HP_GPIO_LED), SND_PCI_QUIRK(0x103c, 0x8847, "HP EliteBook x360 830 G8 Notebook PC", ALC285_FIXUP_HP_GPIO_LED), SND_PCI_QUIRK(0x103c, 0x884b, "HP EliteBook 840 Aero G8 Notebook PC", ALC285_FIXUP_HP_GPIO_LED), @@ -9018,6 +9063,7 @@ static const struct hda_model_fixup alc269_fixup_models[] = { {.id = ALC245_FIXUP_HP_X360_AMP, .name = "alc245-hp-x360-amp"}, {.id = ALC295_FIXUP_HP_OMEN, .name = "alc295-hp-omen"}, {.id = ALC285_FIXUP_HP_SPECTRE_X360, .name = "alc285-hp-spectre-x360"}, + {.id = ALC285_FIXUP_HP_SPECTRE_X360_EB1, .name = "alc285-hp-spectre-x360-eb1"}, {.id = ALC287_FIXUP_IDEAPAD_BASS_SPK_AMP, .name = "alc287-ideapad-bass-spk-amp"}, {.id = ALC623_FIXUP_LENOVO_THINKSTATION_P340, .name = "alc623-lenovo-thinkstation-p340"}, {.id = ALC255_FIXUP_ACER_HEADPHONE_AND_MIC, .name = "alc255-acer-headphone-and-mic"}, -- 2.33.0