Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp2154395ybc; Wed, 20 Nov 2019 09:39:59 -0800 (PST) X-Google-Smtp-Source: APXvYqytHdOaY4jPmzPYclZb+VE1ffOQfX5NpJFDbX2GRWVfUnEpOCyYmxAoJfe0TGYpQyqeESR4 X-Received: by 2002:a19:9116:: with SMTP id t22mr3813451lfd.99.1574271598983; Wed, 20 Nov 2019 09:39:58 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574271598; cv=none; d=google.com; s=arc-20160816; b=kVg6jZo0mTKY9yFm9l9CLNfLXjbT7PYR3jaPUhNObPIJqfaP4k639qJglHR/LpYJYa x5GS3fXtQ+fanpIkGzS7CRbNKMMSoPcXgvkfiGUjEVLBhz2nhkW0E3L2aQx2Byy2hqpr LzftBErmcye2UDqtDnhXBSP3STlJwHEuoufbfJhXsGm/h5borfxRxVwPmRcFGSpImofm k9s/6X+7Zq8H2wGhuQFgCiCNEL1YrDQpHMGv3oqfoIKf+jrFeIn/cGN5K3sIAimZn7Vr VcsWrNlUEHDy9w+ymiTDUZmV92+lTWRAcweQhMHDFElKZDwOLsbwKVl+ggufrvm3RSnY 2hAQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:in-reply-to:subject:cc:to:from :date; bh=l9CD9+THgHSMg9PtQYP0ZqJgRxuToOfueMF6BCHDCn8=; b=C4NhJ+xM+fojtm4KGypje2fQhGpZjcnXe+JkdPFnavQtA2fCaOru8mXhTj9Bsjqxeq D6Jrp6ntlNpUwykkPhaxVHackFJAv/i5mVx4AwcTs49GgOT6qHWurIv2n7/9R3CbQvrU 4geBn+2ITB2zGdsHosjhuCeIZ08UN2AshOe0dhqzh1pDbZ5hRs7JV/p2iAsOMNR6+o3x 3Cy1QI7nBj6Z1vjQu1Lz8HHz02MhudViYScUt2Uq4S+w11unsNr/dhLJdOWXxntSG12A J5Eh4k3DIwmkNlGzfvGDcSPYX3JwZ4TthZEfeG7MY1u/igscajCVs9nWpNxqpnKeKBgY K3lw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f23si28705edj.380.2019.11.20.09.39.29; Wed, 20 Nov 2019 09:39:58 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730317AbfKTRSI (ORCPT + 99 others); Wed, 20 Nov 2019 12:18:08 -0500 Received: from foss.arm.com ([217.140.110.172]:43292 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730001AbfKTRSH (ORCPT ); Wed, 20 Nov 2019 12:18:07 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id BF7781045; Wed, 20 Nov 2019 09:18:06 -0800 (PST) Received: from localhost (unknown [10.37.6.21]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 199333F703; Wed, 20 Nov 2019 09:18:05 -0800 (PST) Date: Wed, 20 Nov 2019 17:18:03 +0000 From: Mark Brown To: Peter Ujfalusi Cc: alsa-devel@alsa-project.org, broonie@kernel.org, devicetree@vger.kernel.org, kuninori.morimoto.gx@renesas.com, lgirdwood@gmail.com, linus.walleij@linaro.org, linux-kernel@vger.kernel.org, Mark Brown , robh+dt@kernel.org Subject: Applied "ASoC: pcm3168a: Update the RST gpio handling to align with documentation" to the asoc tree In-Reply-To: <20191120131753.6831-3-peter.ujfalusi@ti.com> Message-Id: X-Patchwork-Hint: ignore Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The patch ASoC: pcm3168a: Update the RST gpio handling to align with documentation has been applied to the asoc tree at https://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound.git for-5.5 All being well this means that it will be integrated into the linux-next tree (usually sometime in the next 24 hours) and sent to Linus during the next merge window (or sooner if it is a bug fix), however if problems are discovered then the patch may be dropped or reverted. You may get further e-mails resulting from automated or manual testing and review of the tree, please engage with people reporting problems and send followup patches addressing any issues that are reported if needed. If any updates are required or you are submitting further changes they should be sent as incremental updates against current git, existing patches will not be replaced. Please add any relevant lists and maintainers to the CCs when replying to this mail. Thanks, Mark From 4ec48e7cbe6e70352c802b5cb172b00ebd8af8e0 Mon Sep 17 00:00:00 2001 From: Peter Ujfalusi Date: Wed, 20 Nov 2019 15:17:53 +0200 Subject: [PATCH] ASoC: pcm3168a: Update the RST gpio handling to align with documentation The RST (reset-gpios) is low active so the driver must handle it accordingly. Add comments to explain clearly how the line is used. Signed-off-by: Peter Ujfalusi Link: https://lore.kernel.org/r/20191120131753.6831-3-peter.ujfalusi@ti.com Signed-off-by: Mark Brown --- sound/soc/codecs/pcm3168a.c | 20 +++++++++++++++----- 1 file changed, 15 insertions(+), 5 deletions(-) diff --git a/sound/soc/codecs/pcm3168a.c b/sound/soc/codecs/pcm3168a.c index f3475134b519..9711fab296eb 100644 --- a/sound/soc/codecs/pcm3168a.c +++ b/sound/soc/codecs/pcm3168a.c @@ -707,11 +707,15 @@ int pcm3168a_probe(struct device *dev, struct regmap *regmap) dev_set_drvdata(dev, pcm3168a); /* - * Request the RST gpio line as non exclusive as the same reset line - * might be connected to multiple pcm3168a codec + * Request the reset (connected to RST pin) gpio line as non exclusive + * as the same reset line might be connected to multiple pcm3168a codec + * + * The RST is low active, we want the GPIO line to be high initially, so + * request the initial level to LOW which in practice means DEASSERTED: + * The deasserted level of GPIO_ACTIVE_LOW is HIGH. */ - pcm3168a->gpio_rst = devm_gpiod_get_optional(dev, "rst", - GPIOD_OUT_HIGH | + pcm3168a->gpio_rst = devm_gpiod_get_optional(dev, "reset", + GPIOD_OUT_LOW | GPIOD_FLAGS_BIT_NONEXCLUSIVE); if (IS_ERR(pcm3168a->gpio_rst)) { ret = PTR_ERR(pcm3168a->gpio_rst); @@ -814,7 +818,13 @@ void pcm3168a_remove(struct device *dev) { struct pcm3168a_priv *pcm3168a = dev_get_drvdata(dev); - gpiod_set_value_cansleep(pcm3168a->gpio_rst, 0); + /* + * The RST is low active, we want the GPIO line to be low when the + * driver is removed, so set level to 1 which in practice means + * ASSERTED: + * The asserted level of GPIO_ACTIVE_LOW is LOW. + */ + gpiod_set_value_cansleep(pcm3168a->gpio_rst, 1); pm_runtime_disable(dev); #ifndef CONFIG_PM pcm3168a_disable(dev); -- 2.20.1