From patchwork Mon Aug 16 13:01:18 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Greg KH X-Patchwork-Id: 497657 Delivered-To: patch@linaro.org Received: by 2002:a02:6f15:0:0:0:0:0 with SMTP id x21csp82895jab; Mon, 16 Aug 2021 06:13:58 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyP+Wu8phpztJiJQlQTrodRqCWpQehpA3aJS8eIm/xDMJWBq0KuUIrb9Ue5fQFG7mVKgO9C X-Received: by 2002:a05:600c:3b08:: with SMTP id m8mr11605108wms.32.1629119512437; Mon, 16 Aug 2021 06:11:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629119512; cv=none; d=google.com; s=arc-20160816; b=skl78OnqIR+GzH1ZyWkBtK924mj1oqqQG+lcelCySMgxuD8c6Z6dyxl6OwH+hVMruC QuQmYqt5ToR0WfcdTu5taHK0A3T0IZiAbJRuPcDUxTOqu6VHkkfRswdcCv4wzv/M7UmQ eJ5ID/G4MZomQZUjSOi8UbsqEtKIPHqOUih6gXa/JbRrZkG7TXXbG7WlRI7y8NfB96/2 3jqhLrMWAyIr2wkVkq9hZRri3JJ3UnQFeuqqA4Q1ehYj353h8n/E2lPZ76AC0L91ddUo 2bzPre3TLl+A1LEo55U7206/ct5HJEy9rgzY9f82Bot9q+BmNrui6Z2vdNhbKbVKUUW1 7jPQ== 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=OL/APeZdtq69v2xZPsqudixbKiNZJNK6dhaGXUJeU6Q=; b=d5B+USPIPdHVL489rKbtI9rQzT+LAr824+kfR56u5GKag21iI1KoAeu/egxRzI55Z8 DqF4dPiOTigcHQqcj5vO8GpD72SqiZAdEQ9O19oP9JQgJpg55roiPaY5ZNTTSU/3skyL 2rQnTJKKzSVlO/lNDaokMjDQrkF9SERH3wCZU3nX6jyhyzJVT5ZXeSn38EkuqhFi68jR YB4/PZcH9QGNJ9gDAmVZ7cEAX9mZlaXKssLtTCmKWTgA+IeiWMpETE5OhAqg0IrYMKTq VM+47plRucVoQyqz0uvM6M79TPR5btw4TBWLEjw29SUAMdat3zzBBhXUmD+846v/gltx 2mlA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=lfMF7O7A; spf=pass (google.com: domain of stable-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=stable-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 j5si9945154ejm.413.2021.08.16.06.11.52; Mon, 16 Aug 2021 06:11:52 -0700 (PDT) Received-SPF: pass (google.com: domain of stable-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=lfMF7O7A; spf=pass (google.com: domain of stable-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=stable-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 S238852AbhHPNMU (ORCPT + 12 others); Mon, 16 Aug 2021 09:12:20 -0400 Received: from mail.kernel.org ([198.145.29.99]:58014 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238609AbhHPNHq (ORCPT ); Mon, 16 Aug 2021 09:07:46 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 00CCF6329B; Mon, 16 Aug 2021 13:06:53 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1629119214; bh=9xYWXLy5eqswbbVVDGKdKmia3sEo3pev6hYkG3bAWP0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=lfMF7O7AGQP4QG+zGYgC8ToAyRFTWDdngiIZ8gbxvbvoA30Agl4SQc058w89ogUHH SkgqELxeideDJZ+sWd7PeoXM8xAX7nlEraW/30ekcWMJLL0m7re0l5cRuSDHUUSxRh kXWNa3pVnxH6hddiIgnDZO6N+ztzaOpOyYxCFwzc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Mark Brown Subject: [PATCH 5.10 08/96] ASoC: tlv320aic31xx: Fix jack detection after suspend Date: Mon, 16 Aug 2021 15:01:18 +0200 Message-Id: <20210816125435.209378501@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210816125434.948010115@linuxfoundation.org> References: <20210816125434.948010115@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: stable@vger.kernel.org From: Mark Brown commit 2c39ca6885a2ec03e5c9e7c12a4da2aa8926605a upstream. The tlv320aic31xx driver relies on regcache_sync() to restore the register contents after going to _BIAS_OFF, for example during system suspend. This does not work for the jack detection configuration since that is configured via the same register that status is read back from so the register is volatile and not cached. This can also cause issues during init if the jack detection ends up getting set up before the CODEC is initially brought out of _BIAS_OFF, we will reset the CODEC and resync the cache as part of that process. Fix this by explicitly reapplying the jack detection configuration after resyncing the register cache during power on. This issue was found by an engineer working off-list on a product kernel, I just wrote up the upstream fix. Signed-off-by: Mark Brown Link: https://lore.kernel.org/r/20210723180200.25105-1-broonie@kernel.org Cc: stable@vger.kernel.org Signed-off-by: Greg Kroah-Hartman --- sound/soc/codecs/tlv320aic31xx.c | 10 ++++++++++ 1 file changed, 10 insertions(+) --- a/sound/soc/codecs/tlv320aic31xx.c +++ b/sound/soc/codecs/tlv320aic31xx.c @@ -35,6 +35,9 @@ #include "tlv320aic31xx.h" +static int aic31xx_set_jack(struct snd_soc_component *component, + struct snd_soc_jack *jack, void *data); + static const struct reg_default aic31xx_reg_defaults[] = { { AIC31XX_CLKMUX, 0x00 }, { AIC31XX_PLLPR, 0x11 }, @@ -1256,6 +1259,13 @@ static int aic31xx_power_on(struct snd_s return ret; } + /* + * The jack detection configuration is in the same register + * that is used to report jack detect status so is volatile + * and not covered by the cache sync, restore it separately. + */ + aic31xx_set_jack(component, aic31xx->jack, NULL); + return 0; }