From patchwork Mon Aug 16 13:00:40 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Greg KH X-Patchwork-Id: 497656 Delivered-To: patch@linaro.org Received: by 2002:a02:6f15:0:0:0:0:0 with SMTP id x21csp80915jab; Mon, 16 Aug 2021 06:11:56 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwdPTSuQWuNWn/A+GJ6Cdi94v/uZXz3lq5/JBtmg8iyANHF53IlWUhUy9pYcL8IOIkgs8D1 X-Received: by 2002:a17:906:6815:: with SMTP id k21mr16073178ejr.371.1629119516485; Mon, 16 Aug 2021 06:11:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629119516; cv=none; d=google.com; s=arc-20160816; b=DPMzKLf46t2KgUrJIn+neAQ/5pywMXLioRduBclHXMrdbxmXRObblL4ldpJxHEUoxK vcOB5jp8D7glosmP/cjY4zc7NQRL8lMA4hw868G3P8JQqLo5ZQRT+TVjA4OvUArH3tHp OenBeK7Y49dXAZFaIEqJHeyLvYvA8vt/FbZr46RnKQC0RgFV45Wa0bo+ZQATw8oMZzZc PMIl+w5Q5qa7oiL2D1Kl+zoWV+KVG+j4upu/BVjSWHDhkd56n3sYWhUwEQvELcyOu932 +PJv7+bg8XWxYzk1PYSIOoKf0s3+QrU7pn+/aA0sx7mT6A7KZ+Fy0irK5NKFPRQHvKMz I/ng== 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=QNaMnNU3S7/8kwHzhsPbkTRGy1tq85SWgze1gkzSOUr3Do8I1KoPIUQzRLCKZxrWY0 AZzMT3sGpHtonxrd814LoHK2HrgYdBgZa5ofmLk68GRRXEPGZi5Kld60RYYLsuzBobXt 0qEmYFUh52m2t/8klsQgaQ5Q/g+m1FGIrbGk0FtNhWa0idvqhUbIEMo0UEEqoQNX5qFz bl7sNeUigSLgHDBY3PF5/hZfsaMvR9w7Re+zacuTThXQRPr3mVRV5ywbcuLCbHyuy00K lnJWPo2KOSTXmXRNcmnQSdfGMpoawax0uictyW13VLnGJHV5G+z6iDq8nEYlhWws1kgy j5Fg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=ZqJ+gDKg; 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.56; Mon, 16 Aug 2021 06:11:56 -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=ZqJ+gDKg; 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 S236276AbhHPNMW (ORCPT + 12 others); Mon, 16 Aug 2021 09:12:22 -0400 Received: from mail.kernel.org ([198.145.29.99]:35886 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236696AbhHPNK1 (ORCPT ); Mon, 16 Aug 2021 09:10:27 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 6053563299; Mon, 16 Aug 2021 13:09:55 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1629119395; bh=9xYWXLy5eqswbbVVDGKdKmia3sEo3pev6hYkG3bAWP0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ZqJ+gDKgqEW8awM+4iYOsDDE6ODYekVY2+vdGnkm54Ov8K2Jbbw2zdUK8IxsC9irD YPiNCzvSs/YNLic+BBTrugw7PYTbkcgrqW41CFzsUzqrGlXSC0jnkiJzV4a4ejZc+h lCxUVudM2EHUsP0MxceaKGJoY2CPF1gCMnzp6Gi4= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Mark Brown Subject: [PATCH 5.13 010/151] ASoC: tlv320aic31xx: Fix jack detection after suspend Date: Mon, 16 Aug 2021 15:00:40 +0200 Message-Id: <20210816125444.419150843@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210816125444.082226187@linuxfoundation.org> References: <20210816125444.082226187@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; }