Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp448911yba; Fri, 12 Apr 2019 06:52:29 -0700 (PDT) X-Google-Smtp-Source: APXvYqxeDW3e9AY4U9bNCiherM3J+AuriuTI7+Dkv2pyjTP8jgfRpIMoE6oVvZLl0nINicfWKUml X-Received: by 2002:a17:902:2ac3:: with SMTP id j61mr57877794plb.112.1555077149086; Fri, 12 Apr 2019 06:52:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1555077149; cv=none; d=google.com; s=arc-20160816; b=05LL7+EDJw0EfIXj77BAwU9pDLSZD54WT9LzBV48lDqlA0Er248ueWDKYFk1RY4XbG QfzVwA0UIWH/PyRwYY5f8IdRPZRu5svEl/qp6ClCXY7GAHUUFh7xIdkvLYTkr4eLEKd4 4fXM2erol91whD5VHVtiqKU3dilTS3gSQbNfqcLplo9bsU+o8/fPwKx623P1L9cVFMBF vDW4Mh09cQXKNDcTfMfE9o5nRggSXG2DeSRGCuv9vcHYMJNFDC7of7tnrsztkdDGijGh jnR6nVqPEzDN8bDaLIEl4TrRtG44OxWEAJrKW5+OXd7rB4fYzw6LZvC/o06RWcy4NQ7a 41dg== 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:dkim-signature; bh=gwNSd5ymAndbjw0CTJFY/i3yz4ClVc3lWoUeN3NBssQ=; b=d+yuE+3N0Z+tly8DGKqmt0gm484SsvbBUI1KOiBAKBbNIs/DGSEfZQOiCN1/inrorY nW1bbHtjjmAPhilb16z5twCYexDkpz8jNVMn2i660oovOKLJ5qkSKyMLOWWSOv1dH3yS YwKk0PJjQpshesbvnqkLAIEkYEjeyzHQBIV7b9HjhGBGTbpapVkeFUQ7sS6H+xIWDmSk VeeTuaTh6jnp3oUF08Z5dtcjwfL69I1NbpnXm6qSEPlMiP2w5Q7gjKjOUy++blUviM4P 7b5Q3egg+ZtaxHUG+ok7rUzgl/YfJRYnWjVT9nue/H80cO6Mfb5PztTAZpDD4KU3ZQOR vSgA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=snjb58zJ; 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 d9si35276221pgp.336.2019.04.12.06.52.13; Fri, 12 Apr 2019 06:52:29 -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; dkim=fail header.i=@gmail.com header.s=20161025 header.b=snjb58zJ; 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 S1727113AbfDLNuM (ORCPT + 99 others); Fri, 12 Apr 2019 09:50:12 -0400 Received: from mail-pf1-f194.google.com ([209.85.210.194]:42206 "EHLO mail-pf1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726780AbfDLNuM (ORCPT ); Fri, 12 Apr 2019 09:50:12 -0400 Received: by mail-pf1-f194.google.com with SMTP id w25so5181359pfi.9; Fri, 12 Apr 2019 06:50:11 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=gwNSd5ymAndbjw0CTJFY/i3yz4ClVc3lWoUeN3NBssQ=; b=snjb58zJYirgyrqzwW4GZVrTrBRog4j23aEBtL2pcva9gxWKVbdqYH/HiYmduzuenQ NxbDdv+po2Ch7w9WfWPDrq/B+MlTYkOw5vOXCpXHDXJJUo7lETQCo1PsJRUMqpaWBN7o 4cSCULZahMMjOf9Cii+YKOVWd4VqIEUZqIMay1OgYSFdZSHjGs3/rhwwaMCBkuLDG5UP t1MzdcgFdzvTSWeo2/6Muq+iN7ZyfI5TTE5cs7NRz3Wbigzm/KOARav3aDzHYJk0y3Sj ZiNsCd+YgP5RE0aRijKzYNvmHiaCNgHai/oB/sKo9DAduZKdKNOm1IeU+hy30tGQwmG4 FRlg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:subject:to:cc:references:from:message-id :date:user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=gwNSd5ymAndbjw0CTJFY/i3yz4ClVc3lWoUeN3NBssQ=; b=Rx0EpYmpzVFMEVqOu+5NPUMF+f4s6vcgXcYd0iIJjZZSO7htbbQcRUb2Fi32agTw5n ho/2s8vc++vOZ9+j8IioikwmX7FEZZHRxUOHrDjWuGByQ+NiVv9cJnWG23wXTlwxoEee 4yb8rFSOzSAA9mQ3W3DHwtbYPMOPqepf+wdeRt5gAFOmScR19FuZlkgidYbokvu01Mrd PTCNgipgqw7Kd9gomd01dHqmO0KGbQuxMx1pN8sM3E6y3nnKE/dRNiM3kcoSW5/QDAWZ wruY/vrf9XyOuJLTTfFmr5zBvsEgbazzSSPoCJtmHkc3hfSeA9Ozq8GVOxdr5b/TIE/k P+fQ== X-Gm-Message-State: APjAAAXnPZwtRHBw0AHC83CE919mKRv9psH66Y+jq8A5SKTKe5b3gTNY 9x72G67AaHicejswhSANGLiYj+eF X-Received: by 2002:a65:5089:: with SMTP id r9mr53403673pgp.14.1555077010828; Fri, 12 Apr 2019 06:50:10 -0700 (PDT) Received: from server.roeck-us.net ([2600:1700:e321:62f0:329c:23ff:fee3:9d7c]) by smtp.gmail.com with ESMTPSA id f6sm40738316pgq.11.2019.04.12.06.50.09 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 12 Apr 2019 06:50:10 -0700 (PDT) Subject: Re: [PATCH V5 3/3] hwmon: pwm-fan: Add RPM support via external interrupt To: Robin Murphy , Stefan Wahren Cc: Kamil Debski , Bartlomiej Zolnierkiewicz , Jean Delvare , Rob Herring , Mark Rutland , linux-hwmon@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org References: <1554989411-23666-1-git-send-email-stefan.wahren@i2se.com> <1554989411-23666-4-git-send-email-stefan.wahren@i2se.com> <20190411165742.GA29395@roeck-us.net> <019733e8-6b12-f5c1-e251-fd7eabe2891b@i2se.com> <77c56129-d3e7-1518-9d1d-a15a20540269@arm.com> From: Guenter Roeck Message-ID: Date: Fri, 12 Apr 2019 06:50:08 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.6.1 MIME-Version: 1.0 In-Reply-To: <77c56129-d3e7-1518-9d1d-a15a20540269@arm.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 4/12/19 4:50 AM, Robin Murphy wrote: > On 12/04/2019 12:07, Stefan Wahren wrote: >> On 11.04.19 18:57, Guenter Roeck wrote: >>> On Thu, Apr 11, 2019 at 03:30:11PM +0200, Stefan Wahren wrote: >>>> >>>> -ATTRIBUTE_GROUPS(pwm_fan); >>>> +static umode_t pwm_fan_attrs_visible(struct kobject *kobj, struct attribute *a, >>>> + int n) >>>> +{ >>>> + struct device *dev = container_of(kobj, struct device, kobj); >>>> + struct pwm_fan_ctx *ctx = dev_get_drvdata(dev); >>>> + struct device_attribute *devattr; >>>> + >>>> + /* Hide fan_input in case no interrupt is available */ >>>> + devattr = container_of(a, struct device_attribute, attr); >>> Field day for static analyzers - devattr is no longer used. >>> No need to resend. I'll let the series rest for a couple of days >>> and then apply to hwmon-next (after removing devattr) unless there are >>> additional comments. >>> >> Thank you > > FWIW you can have a > > Reviewed-by: Robin Murphy > > for the whole series. The only minor comment that springs to mind > isn't actually specific to this patch, so is probably best made as > the follow-up below. > > Robin. > Any chance you can send the patch below as separate patch ? I track patches using patchwork, and attachments don't show up there. Thanks, Guenter > ----->8----- > From: Robin Murphy > Subject: [PATCH] hwmon: pwm-fan: Report probe errors consistently > > Printing the error code for a failure provides a head-start for > debugging, since it's often sufficient to pinpoint the origin of the > failure. We already do this for some probe-failure messages, so let's > make the rest of them consistent. > > Signed-off-by: Robin Murphy > --- > drivers/hwmon/pwm-fan.c | 13 ++++++++----- > 1 file changed, 8 insertions(+), 5 deletions(-) > > diff --git a/drivers/hwmon/pwm-fan.c b/drivers/hwmon/pwm-fan.c > index 8c4c5eefd4ca..556db4bef743 100644 > --- a/drivers/hwmon/pwm-fan.c > +++ b/drivers/hwmon/pwm-fan.c > @@ -330,7 +330,7 @@ static int pwm_fan_probe(struct platform_device *pdev) > > ret = pwm_apply_state(ctx->pwm, &state); > if (ret) { > - dev_err(&pdev->dev, "Failed to configure PWM\n"); > + dev_err(&pdev->dev, "Failed to configure PWM: %d\n", ret); > goto err_reg_disable; > } > > @@ -348,7 +348,8 @@ static int pwm_fan_probe(struct platform_device *pdev) > ret = devm_request_irq(&pdev->dev, ctx->irq, pulse_handler, 0, > pdev->name, ctx); > if (ret) { > - dev_err(&pdev->dev, "Can't get interrupt working.\n"); > + dev_err(&pdev->dev, > + "Failed to request interrupt: %d\n", ret); > goto err_pwm_disable; > } > ctx->sample_start = ktime_get(); > @@ -358,8 +359,9 @@ static int pwm_fan_probe(struct platform_device *pdev) > hwmon = devm_hwmon_device_register_with_groups(&pdev->dev, "pwmfan", > ctx, pwm_fan_groups); > if (IS_ERR(hwmon)) { > - dev_err(&pdev->dev, "Failed to register hwmon device\n"); > ret = PTR_ERR(hwmon); > + dev_err(&pdev->dev, > + "Failed to register hwmon device: %d\n", ret); > goto err_del_timer; > } > > @@ -373,9 +375,10 @@ static int pwm_fan_probe(struct platform_device *pdev) > "pwm-fan", ctx, > &pwm_fan_cooling_ops); > if (IS_ERR(cdev)) { > - dev_err(&pdev->dev, > - "Failed to register pwm-fan as cooling device"); > ret = PTR_ERR(cdev); > + dev_err(&pdev->dev, > + "Failed to register pwm-fan as cooling device: %d\n", > + ret); > goto err_del_timer; > } > ctx->cdev = cdev; >