Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp3708013pxb; Sun, 24 Oct 2021 09:04:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz+uDt4PfQokSfccwwWwNunbNU+Ys2lrraZlQ4/Zn1AdKxSdctI/CRsJj8JC87EBU92ZhLJ X-Received: by 2002:a17:903:2c2:b029:101:9c88:d928 with SMTP id s2-20020a17090302c2b02901019c88d928mr11819187plk.62.1635091483939; Sun, 24 Oct 2021 09:04:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1635091483; cv=none; d=google.com; s=arc-20160816; b=bwrg38yEKxFS3z6sjHGAqqQKCsd97aLNxxkq2I0BGLedqi0Z19KvBwxrHU8tyIMqcS rtPxXvfwsnnRIer0hGtYvdnTY1bCmZERQHJMAWE9ikc9uNGpYoUJfimvfT+/jvzv+elj RTwsORDU82Uh8dHt2vIXC9fOMBHn/dFVL+66o9TjepkW3PT8Csh9BKcFjHht9GzvmV0d udatFBLXIBWX5zQnTgtVjO2zfmE3OUVNGMq6HcvklWLju99SD+rxs66jmmvGaKl3+NKF S/dAM0CPuDpD3z51GW155ixNE73IeTIOVUlbowDzSO1MxrIiPeltgAb+faFmr8DAku5i tkZA== 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 :references:in-reply-to:message-id:subject:cc:to:from:date; bh=k34KuD1uzv99RgQZk2xxiBtQlN+6lAKUbMu45iayfXs=; b=c5a1CbRlV/SQpYhYuJrZAH3tARxrmuRabqOPqVuL/7SLZiFb0eA+HAGneD7iScn9Oe NrvEGIN0kX1z8zLbJmCkWwMUVfXnW4WUN1z/ESJSBtys8hziHOK1/MXxjvBydUTwTOJw x3PS+wtR9g8adOHLHWMR+Np9Us+Mrdhp5bK5s0U7YXGn7AgnqZ+ZfOdVWVScI8l2NnoC MhN2TG924CE1PO0Ib7nZ7irMowP7luCjEeHq0Bxy+6GoFNxJT5+imaWQLjjz8DiTIPDp 2ZfOEmDmylYwf5ClpMwPi9SiE7zPhOzdUAtLzGFwnYLepTNu7m+nJ3UFffNhsO5elARt Mp1Q== ARC-Authentication-Results: i=1; mx.google.com; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id c11si484269pgw.200.2021.10.24.09.04.30; Sun, 24 Oct 2021 09:04:43 -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; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229930AbhJXQFy (ORCPT + 99 others); Sun, 24 Oct 2021 12:05:54 -0400 Received: from mail.kernel.org ([198.145.29.99]:56104 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229755AbhJXQFu (ORCPT ); Sun, 24 Oct 2021 12:05:50 -0400 Received: from jic23-huawei (cpc108967-cmbg20-2-0-cust86.5-4.cable.virginm.net [81.101.6.87]) (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 CBA7360F9C; Sun, 24 Oct 2021 16:03:27 +0000 (UTC) Date: Sun, 24 Oct 2021 17:07:49 +0100 From: Jonathan Cameron To: Olivier MOYSAN Cc: Fabrice Gasnier , , , , , Subject: Re: [PATCH] iio: adc: stm32: fix a leak by resetting pcsel before disabling vdda Message-ID: <20211024170749.44c0d81f@jic23-huawei> In-Reply-To: <77f3593a-0e94-f5ab-f102-86ba8d0f1a3b@foss.st.com> References: <1634905169-23762-1-git-send-email-fabrice.gasnier@foss.st.com> <77f3593a-0e94-f5ab-f102-86ba8d0f1a3b@foss.st.com> X-Mailer: Claws Mail 4.0.0 (GTK+ 3.24.30; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 22 Oct 2021 14:38:52 +0200 Olivier MOYSAN wrote: I'll probably reword the description here as 'leak' tends to mean memory leak rather than current. > Hi Fabrice, > > On 10/22/21 2:19 PM, Fabrice Gasnier wrote: > > Some I/Os are connected to ADC input channels, when the corresponding bit > > in PCSEL register are set on STM32H7 and STM32MP15. This is done in the > > prepare routine of stm32-adc driver. > > There are constraints here, as PCSEL shouldn't be set when VDDA supply > > is disabled. Enabling/disabling of VDDA supply in done via stm32-adc-core > > runtime PM routines (before/after ADC is enabled/disabled). > > > > Currently, PCSEL remains set when disabling ADC. Later on, PM runtime > > can disable the VDDA supply. This creates some conditions on I/Os that > > can start to leak current. > > So PCSEL needs to be cleared when disabling the ADC. > > > > Fixes: 95e339b6e85d ("iio: adc: stm32: add support for STM32H7") > > No line break here as Fixes forms part of the tag block. > > Signed-off-by: Fabrice Gasnier Given timing wrt to being too near merge window, I'll let this it on list a while longer as it'll be post rc1 material now anyway. I can fix the above whilst applying if nothing else comes up. Jonathan > > --- > > drivers/iio/adc/stm32-adc.c | 1 + > > 1 file changed, 1 insertion(+) > > > > diff --git a/drivers/iio/adc/stm32-adc.c b/drivers/iio/adc/stm32-adc.c > > index 5088de8..e3e7541 100644 > > --- a/drivers/iio/adc/stm32-adc.c > > +++ b/drivers/iio/adc/stm32-adc.c > > @@ -975,6 +975,7 @@ static void stm32h7_adc_unprepare(struct iio_dev *indio_dev) > > { > > struct stm32_adc *adc = iio_priv(indio_dev); > > > > + stm32_adc_writel(adc, STM32H7_ADC_PCSEL, 0); > > stm32h7_adc_disable(indio_dev); > > stm32h7_adc_enter_pwr_down(adc); > > } > > > > Reviewed-by: Olivier Moysan > > Thanks > Olivier