Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3063729pxf; Mon, 5 Apr 2021 02:07:10 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxaE0QyvvrOJdR0h6Wre70FyEKHDjS0E7TP8W/d7p5Rp53+ZRR2uMYvNwgicXFScrLns5uj X-Received: by 2002:a05:6e02:e52:: with SMTP id l18mr18947969ilk.217.1617613630505; Mon, 05 Apr 2021 02:07:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617613630; cv=none; d=google.com; s=arc-20160816; b=G8epqHeSqA+1bEXx5SsHaLMhiFyOrp6V27r/74q0QSNr6F4EcS4wkccJjNTy3n8u++ maCI+U3flvV4+cXav8+s7/mdJI1FnE8pzaFN0/u0I1qrkmuns8lUn+4ogE6Vo8All/2t QmapFEGqbl0iKRdWQ73+OQWt3+fmYsGgRqTpB7dZk84EdyNFMgRlYemsmX7u1A3IxVx3 OAnEM1aZQrHzq1eYsAsAzgvNZJU6MNRNILubF6eeVqNxi9ZRJjc/e+14PUdbnfMTKtHV TPNe4U2raFz164RV2eOokda0Du+lmQjhC4kDQ73dxMv1h1+myl/SzZk17it1OP0aIChB b8Og== 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=XIZrXXencUluA1shj86KZMSUuEhhubW2tL9JrX//JWk=; b=dND7CYHH3i+q3v2kwCINuqGa1hqe1yRKhLbXfWmbvyjLiQv41wCT3twVGIBkXXpeiw aI5KKEd01LM/zUZdqi3rSZ46OiZ/v0Qkkvf5oOptnzTQ0Psk5PzCZ1xd0Eqpoh443iLI mxmEgGakkEWG77l+dYlaiFriLDf4UFmMF0LhPiMOrRvM+lz7mzf99qdpFC4rHoaRBJoG lkDl09hsUNAIosK5Pr0IUjkADANUGt5NTeN9p4pUXZNTJ64ujTpoTHw+8QI4RPRflP6x CLuAOqqG2jeONhvG6lHcs6d1q1fBg1f++l6NcpxMDmnf++LcQdXwQXTBsbH9IqHzIHoK 7xFw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=ddn0wn0Q; 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 l3si14196681ilv.80.2021.04.05.02.06.57; Mon, 05 Apr 2021 02:07:10 -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=ddn0wn0Q; 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 S238724AbhDEJGG (ORCPT + 99 others); Mon, 5 Apr 2021 05:06:06 -0400 Received: from mail.kernel.org ([198.145.29.99]:47982 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238140AbhDEJEa (ORCPT ); Mon, 5 Apr 2021 05:04:30 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 2476561002; Mon, 5 Apr 2021 09:04:23 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1617613464; bh=5IxbLfMfAzxJUCCm2QG0PWeYtdItXDQJK0p/zM1e95U=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ddn0wn0Qw3yMMKYFqwVwXoUfJXT9rovljK1/CeOtT5pAfBA6rWz77feSlB4r2eXFK tC+Cm2H3+TjemyP0mAWnUs+pS29aLScN1Y5D4YEfk0PES79fVPYr/K16v+Hz39bAVF oPTKCTZXR8/mIDxyNt6IE4WsxjhFVpFJHlT4xnjQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Hui Wang , Takashi Iwai Subject: [PATCH 5.4 45/74] ALSA: hda/realtek: call alc_update_headset_mode() in hp_automute_hook Date: Mon, 5 Apr 2021 10:54:09 +0200 Message-Id: <20210405085026.198424950@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210405085024.703004126@linuxfoundation.org> References: <20210405085024.703004126@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: Hui Wang commit e54f30befa7990b897189b44a56c1138c6bfdbb5 upstream. We found the alc_update_headset_mode() is not called on some machines when unplugging the headset, as a result, the mode of the ALC_HEADSET_MODE_UNPLUGGED can't be set, then the current_headset_type is not cleared, if users plug a differnt type of headset next time, the determine_headset_type() will not be called and the audio jack is set to the headset type of previous time. On the Dell machines which connect the dmic to the PCH, if we open the gnome-sound-setting and unplug the headset, this issue will happen. Those machines disable the auto-mute by ucm and has no internal mic in the input source, so the update_headset_mode() will not be called by cap_sync_hook or automute_hook when unplugging, and because the gnome-sound-setting is opened, the codec will not enter the runtime_suspend state, so the update_headset_mode() will not be called by alc_resume when unplugging. In this case the hp_automute_hook is called when unplugging, so add update_headset_mode() calling to this function. Cc: Signed-off-by: Hui Wang Link: https://lore.kernel.org/r/20210320091542.6748-2-hui.wang@canonical.com Signed-off-by: Takashi Iwai Signed-off-by: Greg Kroah-Hartman --- sound/pci/hda/patch_realtek.c | 1 + 1 file changed, 1 insertion(+) --- a/sound/pci/hda/patch_realtek.c +++ b/sound/pci/hda/patch_realtek.c @@ -5376,6 +5376,7 @@ static void alc_update_headset_jack_cb(s struct hda_jack_callback *jack) { snd_hda_gen_hp_automute(codec, jack); + alc_update_headset_mode(codec); } static void alc_probe_headset_mode(struct hda_codec *codec)