Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp6702558ybi; Wed, 31 Jul 2019 19:52:08 -0700 (PDT) X-Google-Smtp-Source: APXvYqyFJrd7IqLTJBE2MaRPIQ9BUBZROmSAwlHh4jHCKI8JIGC0c70NN+l9FJVVq88dHfuxW4oA X-Received: by 2002:a63:7a01:: with SMTP id v1mr119295056pgc.310.1564627928416; Wed, 31 Jul 2019 19:52:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1564627928; cv=none; d=google.com; s=arc-20160816; b=AR46TxtmHRnzIePyaxBWxCCLLp9Tt2pgUMfqdxhsa5JYhVPAxk4j99OFTUq5vfyfaM TlsaItp8kvhsf5Vt7RMSfBAla7f/5S4r4RyH7dglA3Jav3LRExAQ9OySSkCgk3O+2Bkt 3ayfurCNgMKGrIQydyU23xl5OGUk9wsAOyjdNdDwghg34Ey+MEYgKDz/f9Sw5uI3MkVR fM9igBSYYixuastyJzUAliFdXBowoAVlvwbycZwoKDlvMNAbrAzH5bpqTWK5qjbqlj4o DBnxpTaGOmqTErIIHrRxXvFyx2rcu2rXL/bOoB/gjRvD20QT5P0MNeRicVxvEgemhJiF Yd7g== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=cQPPnLFtkusgiXUnGFmASdQrhox9kmHgduiBvaP8/S0=; b=NzG5fWBr/3OKLUB3wFjX1/ivMY02LoGcNdxCroPXtKjRHM/vsNQ+jXwtxZRarfDqSd 7nqHSDezGHficwzdgP6X0fHBbJOZ0t/6s+xjFS93FyQI5hpfVuH3yV5WB1bqGD7CCW/v 4/VmPonwaj9SgdGgJiL9FmqMDS4X8OONTAgQm6kKMwQ8L6eZCKG28/+z6lRar3T1avs1 Q+a+PVeJmIhoqpdpBU5hTjL3e7M9WJUfSi6Fa0Fef4RoEU4JW2QHDcLkrZA81J8z35TX Ly9jAMZFFuoWOq+cPBeazIhv/N9XDs2QsSiEd5hB8wI8rSMbpUhN7+wli83Yw8NG4jn8 +h0w== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t23si31100582plr.108.2019.07.31.19.51.53; Wed, 31 Jul 2019 19:52:08 -0700 (PDT) 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727490AbfHAChu (ORCPT + 99 others); Wed, 31 Jul 2019 22:37:50 -0400 Received: from anchovy3.45ru.net.au ([203.30.46.155]:34562 "EHLO anchovy3.45ru.net.au" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726626AbfHAChu (ORCPT ); Wed, 31 Jul 2019 22:37:50 -0400 Received: (qmail 19867 invoked by uid 5089); 1 Aug 2019 02:37:47 -0000 Received: by simscan 1.2.0 ppid: 19739, pid: 19743, t: 0.0566s scanners: regex: 1.2.0 attach: 1.2.0 clamav: 0.88.3/m:40/d:1950 Received: from unknown (HELO ?192.168.0.128?) (preid@electromag.com.au@203.59.235.95) by anchovy2.45ru.net.au with ESMTPA; 1 Aug 2019 02:37:46 -0000 Subject: Re: [PATCH v6 19/57] iio: Remove dev_err() usage after platform_get_irq() To: Stephen Boyd , linux-kernel@vger.kernel.org Cc: Jonathan Cameron , Hartmut Knaack , Lars-Peter Clausen , Peter Meerwald-Stadler , linux-iio@vger.kernel.org, Greg Kroah-Hartman References: <20190730181557.90391-1-swboyd@chromium.org> <20190730181557.90391-20-swboyd@chromium.org> <5d41a66d.1c69fb81.6d372.4c72@mx.google.com> From: Phil Reid Message-ID: <6dc9dbc0-c338-eb21-aeb3-70026bebfd41@electromag.com.au> Date: Thu, 1 Aug 2019 10:37:40 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:60.0) Gecko/20100101 Thunderbird/60.8.0 MIME-Version: 1.0 In-Reply-To: <5d41a66d.1c69fb81.6d372.4c72@mx.google.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-AU Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org G'day Stephen, One comment below. On 31/07/2019 22:32, Stephen Boyd wrote: > Quoting Phil Reid (2019-07-30 23:42:16) >> G'day Stephen, >> >> A comment unrelated to your change. >> >> On 31/07/2019 02:15, Stephen Boyd wrote: >> .... >> >>> diff --git a/drivers/iio/adc/at91_adc.c b/drivers/iio/adc/at91_adc.c >>> index 32f1c4a33b20..abe99856c823 100644 >>> --- a/drivers/iio/adc/at91_adc.c >>> +++ b/drivers/iio/adc/at91_adc.c >>> @@ -1179,10 +1179,8 @@ static int at91_adc_probe(struct platform_device *pdev) >>> idev->info = &at91_adc_info; >>> >>> st->irq = platform_get_irq(pdev, 0); >>> - if (st->irq < 0) { >>> - dev_err(&pdev->dev, "No IRQ ID is designated\n"); >>> + if (st->irq < 0) >>> return -ENODEV; >> Should this be returning st->irq instead of -ENODEV? >> eg: platform_get_irq can return -EPROBE_DEFER >> >> Pattern is repeated in a number of other places. > > Probably? Here's a patch. > > ----8<---- > From: Stephen Boyd > Subject: [PATCH] iio: Return error values from platform_get_irq*() > > Sometimes platform_get_irq*() can return -EPROBE_DEFER, so it's best to > return the actual error value from calling this function instead of > overriding the value to something like -EINVAL or -ENXIO. Except for in > the case when the irq value is 0 and the driver knows that irq 0 isn't > valid. In such a situation, return whatever error value was returned > before this change. > > Reported-by: Phil Reid > Cc: Phil Reid > Cc: Jonathan Cameron > Cc: Hartmut Knaack > Cc: Lars-Peter Clausen > Cc: Peter Meerwald-Stadler > Cc: linux-iio@vger.kernel.org > Cc: Greg Kroah-Hartman > Signed-off-by: Stephen Boyd > --- > drivers/iio/adc/at91_adc.c | 2 +- > drivers/iio/adc/bcm_iproc_adc.c | 2 +- > drivers/iio/adc/fsl-imx25-gcq.c | 4 +--- > drivers/iio/adc/lpc32xx_adc.c | 2 +- > drivers/iio/adc/npcm_adc.c | 2 +- > drivers/iio/adc/spear_adc.c | 2 +- > 6 files changed, 6 insertions(+), 8 deletions(-) > > diff --git a/drivers/iio/adc/at91_adc.c b/drivers/iio/adc/at91_adc.c > index abe99856c823..2c604198c4b7 100644 > --- a/drivers/iio/adc/at91_adc.c > +++ b/drivers/iio/adc/at91_adc.c > @@ -1180,7 +1180,7 @@ static int at91_adc_probe(struct platform_device *pdev) > > st->irq = platform_get_irq(pdev, 0); > if (st->irq < 0) > - return -ENODEV; > + return st->irq; > > res = platform_get_resource(pdev, IORESOURCE_MEM, 0); > > diff --git a/drivers/iio/adc/bcm_iproc_adc.c b/drivers/iio/adc/bcm_iproc_adc.c > index 646ebdc0a8b4..6c05ea510c40 100644 > --- a/drivers/iio/adc/bcm_iproc_adc.c > +++ b/drivers/iio/adc/bcm_iproc_adc.c > @@ -541,7 +541,7 @@ static int iproc_adc_probe(struct platform_device *pdev) > > adc_priv->irqno = platform_get_irq(pdev, 0); > if (adc_priv->irqno <= 0) > - return -ENODEV; > + return adc_priv->irqno; return adc_priv->irqno ? : -ENODEV; > > ret = regmap_update_bits(adc_priv->regmap, IPROC_REGCTL2, > IPROC_ADC_AUXIN_SCAN_ENA, 0); > diff --git a/drivers/iio/adc/fsl-imx25-gcq.c b/drivers/iio/adc/fsl-imx25-gcq.c > index fa71489195c6..ee20ab09abe5 100644 > --- a/drivers/iio/adc/fsl-imx25-gcq.c > +++ b/drivers/iio/adc/fsl-imx25-gcq.c > @@ -340,9 +340,7 @@ static int mx25_gcq_probe(struct platform_device *pdev) > > priv->irq = platform_get_irq(pdev, 0); > if (priv->irq <= 0) { > - ret = priv->irq; > - if (!ret) > - ret = -ENXIO; > + ret = priv->irq ? : -ENXIO; > goto err_clk_unprepare; > } > > diff --git a/drivers/iio/adc/lpc32xx_adc.c b/drivers/iio/adc/lpc32xx_adc.c > index b896f7ff4572..edbb58212fba 100644 > --- a/drivers/iio/adc/lpc32xx_adc.c > +++ b/drivers/iio/adc/lpc32xx_adc.c > @@ -173,7 +173,7 @@ static int lpc32xx_adc_probe(struct platform_device *pdev) > > irq = platform_get_irq(pdev, 0); > if (irq <= 0) > - return -ENXIO; > + return irq ? : -ENXIO; > > retval = devm_request_irq(&pdev->dev, irq, lpc32xx_adc_isr, 0, > LPC32XXAD_NAME, st); > diff --git a/drivers/iio/adc/npcm_adc.c b/drivers/iio/adc/npcm_adc.c > index 910f3585fa54..1e54a64a4534 100644 > --- a/drivers/iio/adc/npcm_adc.c > +++ b/drivers/iio/adc/npcm_adc.c > @@ -225,7 +225,7 @@ static int npcm_adc_probe(struct platform_device *pdev) > > irq = platform_get_irq(pdev, 0); > if (irq <= 0) { > - ret = -EINVAL; > + ret = irq ? : -EINVAL; > goto err_disable_clk; > } > > diff --git a/drivers/iio/adc/spear_adc.c b/drivers/iio/adc/spear_adc.c > index 592b97c464da..9b16717ac7e7 100644 > --- a/drivers/iio/adc/spear_adc.c > +++ b/drivers/iio/adc/spear_adc.c > @@ -301,7 +301,7 @@ static int spear_adc_probe(struct platform_device *pdev) > > irq = platform_get_irq(pdev, 0); > if (irq <= 0) { > - ret = -EINVAL; > + ret = irq ? : -EINVAL; > goto errout2; > } > > -- Regards Phil Reid