Received: by 2002:a25:23cc:0:0:0:0:0 with SMTP id j195csp38131ybj; Fri, 8 May 2020 06:05:03 -0700 (PDT) X-Google-Smtp-Source: APiQypImtw+CAk0boMreeqWcB+qig4cB/E0SbqHyWHdn4a0yX46HedQVBa8gbl7Fks6NCfzTJpN9 X-Received: by 2002:aa7:d653:: with SMTP id v19mr1983814edr.383.1588943103702; Fri, 08 May 2020 06:05:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588943103; cv=none; d=google.com; s=arc-20160816; b=blTo5ilQH3vPvFbXtbPaMT4iqdwFNQM52E1JmfVMAziNN8/NLBcAtaeUw+i7QtXWDb SkPHpvSDv3rLQpfbo2qE6cBJGuZqcflc67qVcMthcU5TQBpTbqFBrIFdqs43Qk2ZgTul H02EYbtIjRXPtpCfO7zNmQyMI4vw8gbuWthOSAgXsS9HXmRTghYySZ9Kj2ufeb3f509f O0G6O3mEqgJJ8LODSzRByfi4RCbJs3G6148DJ4PptjAS7gXqAuRsdPcmk7eaVs16RQuS MGqu33jjVaNpONXhvW7yKAFXSOd5eSHpcIjfqWIvSEJSPW0rMugxq37fhKICG5acMWR4 8+Vg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=X72Mf5sTfbYfl5daXilSZhhzpNZ2s+OqDnbafz/FO2U=; b=Z2pwq/2l1iOVrwDnAQDKU6SHUb3k71vWdYexogAANH6k6DTMrTFntMNaL6/2iFClRV COHu6MYzhK2DWRLGmYYxeRPY48YZ10xWQGsco+swc6rq0mXng8mWcj8LjVHCgUOL9oJv dHHvW6XOG7TJhF8V28ljvVyQbb9DH9JUhrYT2HhJwzPyI/8YA04Xg2pfuN2oK4q9t6dT 3kGGVyLXvwjOadP7ibJm6dIzkq+w8ZE3ZKsm6aHJk0MAhqlpNrdLXLxS3rthL49WW+ZF ePhLGcfybZjym63CK32oKZqlOjTP9FwGRE4d6mFQYlj5hN4qSOyZC1YOT2AFgPi7g05X Bq9g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=d37ZXudM; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f16si973224eds.152.2020.05.08.06.04.22; Fri, 08 May 2020 06:05:03 -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=default header.b=d37ZXudM; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729815AbgEHMwT (ORCPT + 99 others); Fri, 8 May 2020 08:52:19 -0400 Received: from mail.kernel.org ([198.145.29.99]:32904 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729502AbgEHMvx (ORCPT ); Fri, 8 May 2020 08:51:53 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 3939A218AC; Fri, 8 May 2020 12:51:52 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1588942312; bh=hdhau5x237LBx7BVJYuRDozB3xA1U7LTwu5kqngl8TY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=d37ZXudMAtG7cbwrQji6niJhmVDV2GxDpUalgpVjNdNbRzk2k7pD0qeqD3BS/4ZZL 1fYBc/wjiHdQgXwWRStzyQ4gAi5B5z0pJyRhzZv0OyyB9B5LU8YbwY1DZufJQU70V8 bVCGbyZ2wHTMQBOVQnSPfFqWOKeWJquGBcl96edc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Sebastian Reichel , Fabio Estevam , Mark Brown , Sasha Levin Subject: [PATCH 4.19 05/32] ASoC: sgtl5000: Fix VAG power-on handling Date: Fri, 8 May 2020 14:35:18 +0200 Message-Id: <20200508123035.505300470@linuxfoundation.org> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200508123034.886699170@linuxfoundation.org> References: <20200508123034.886699170@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Sebastian Reichel [ Upstream commit aa7812737f2877e192d57626cbe8825cc7cf6de9 ] As mentioned slightly out of patch context in the code, there is no reset routine for the chip. On boards where the chip is supplied by a fixed regulator, it might not even be resetted during (e.g. watchdog) reboot and can be in any state. If the device is probed with VAG enabled, the driver's probe routine will generate a loud pop sound when ANA_POWER is being programmed. Avoid this by properly disabling just the VAG bit and waiting the required power down time. Signed-off-by: Sebastian Reichel Reviewed-by: Fabio Estevam Link: https://lore.kernel.org/r/20200414181140.145825-1-sebastian.reichel@collabora.com Signed-off-by: Mark Brown Signed-off-by: Sasha Levin --- sound/soc/codecs/sgtl5000.c | 34 ++++++++++++++++++++++++++++++++++ sound/soc/codecs/sgtl5000.h | 1 + 2 files changed, 35 insertions(+) diff --git a/sound/soc/codecs/sgtl5000.c b/sound/soc/codecs/sgtl5000.c index 896412d11a31c..7c0a06b487f74 100644 --- a/sound/soc/codecs/sgtl5000.c +++ b/sound/soc/codecs/sgtl5000.c @@ -1633,6 +1633,40 @@ static int sgtl5000_i2c_probe(struct i2c_client *client, dev_err(&client->dev, "Error %d initializing CHIP_CLK_CTRL\n", ret); + /* Mute everything to avoid pop from the following power-up */ + ret = regmap_write(sgtl5000->regmap, SGTL5000_CHIP_ANA_CTRL, + SGTL5000_CHIP_ANA_CTRL_DEFAULT); + if (ret) { + dev_err(&client->dev, + "Error %d muting outputs via CHIP_ANA_CTRL\n", ret); + goto disable_clk; + } + + /* + * If VAG is powered-on (e.g. from previous boot), it would be disabled + * by the write to ANA_POWER in later steps of the probe code. This + * may create a loud pop even with all outputs muted. The proper way + * to circumvent this is disabling the bit first and waiting the proper + * cool-down time. + */ + ret = regmap_read(sgtl5000->regmap, SGTL5000_CHIP_ANA_POWER, &value); + if (ret) { + dev_err(&client->dev, "Failed to read ANA_POWER: %d\n", ret); + goto disable_clk; + } + if (value & SGTL5000_VAG_POWERUP) { + ret = regmap_update_bits(sgtl5000->regmap, + SGTL5000_CHIP_ANA_POWER, + SGTL5000_VAG_POWERUP, + 0); + if (ret) { + dev_err(&client->dev, "Error %d disabling VAG\n", ret); + goto disable_clk; + } + + msleep(SGTL5000_VAG_POWERDOWN_DELAY); + } + /* Follow section 2.2.1.1 of AN3663 */ ana_pwr = SGTL5000_ANA_POWER_DEFAULT; if (sgtl5000->num_supplies <= VDDD) { diff --git a/sound/soc/codecs/sgtl5000.h b/sound/soc/codecs/sgtl5000.h index 18cae08bbd3a6..066517e352a70 100644 --- a/sound/soc/codecs/sgtl5000.h +++ b/sound/soc/codecs/sgtl5000.h @@ -233,6 +233,7 @@ /* * SGTL5000_CHIP_ANA_CTRL */ +#define SGTL5000_CHIP_ANA_CTRL_DEFAULT 0x0133 #define SGTL5000_LINE_OUT_MUTE 0x0100 #define SGTL5000_HP_SEL_MASK 0x0040 #define SGTL5000_HP_SEL_SHIFT 6 -- 2.20.1