Received: by 10.223.185.116 with SMTP id b49csp6254457wrg; Wed, 28 Feb 2018 06:31:22 -0800 (PST) X-Google-Smtp-Source: AH8x224S9QY6DmcQq584WSJRYHf0nqcx5MgdD2aOoL4LU4YMo2ZpZb/C0xzB2EIA+fCpU8+BAhLH X-Received: by 10.98.152.86 with SMTP id q83mr17845173pfd.218.1519828282231; Wed, 28 Feb 2018 06:31:22 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519828282; cv=none; d=google.com; s=arc-20160816; b=jLJ8JpQHUcLydJSQkU1calfXSCVA8Qfr/XUxCl/fZFx/vIgjGl7/+Q6Vss8kYNmvI2 2xj5LHCaeKZt4GlbhFsFPhWD4aHjAmNXEr0vWxYrd/GZGUwPZB6EkgxUkzAiwYItHPxU QVpuzNbdj/sXvh6Qjwsd1eUU/WF5uCpZMW/1+ME+9KzYLCzq099q2bgoqgXpdNqsO2SV ixTs2YxuM2jAjPQ94cCaNQLQXwcFtCSEBYC+9paIGr9B9wAABw6bCzYd+kzTYvA74SNb C5B1KOdjHmvSng6uOX9HoIuSzjlLoI0wWtp1EoHO5ZpaKaphxGlu0I2A0BlnepaQ6jLq vSJQ== 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 :arc-authentication-results; bh=XIMtixO7X9aPr9qCorf1+mIsEV2X49kpj5LakXL5pUM=; b=VYM6X0Eu77F9hqK6Pzk52JA0teTOpVMq/DnWqx61FRcVj4KuijVWOsIl5TYzHkIK10 syYRAQTONh6oOx/J3ogG+gE4KNSP3IzVphc+eEMDhqKgc1Rcz/edR4NSW+lwrfihhVBy 8/DMp6rTCEJf5WLBX/0rjEm0H+cuD81hcGAWEmFkkP0/f4zDJEMVnYsl8iF0rVmn/09+ 6qf8KPKz/gdyZtZfeS9ECnX5AUZGGDUQd3EuYominDLg7kbR/qZkNys1FwF8QjRf3L25 T50cz4bFCQpKrZq2fjbGf7RmBWerf1txJ0leVn+Ar8b7rlrVq/BP1EkSQlOkqDl8ISqi c2Rg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=GJVgmcB/; 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 m24si1085799pgd.763.2018.02.28.06.31.02; Wed, 28 Feb 2018 06:31:22 -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; dkim=fail header.i=@gmail.com header.s=20161025 header.b=GJVgmcB/; 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 S932182AbeB1O3a (ORCPT + 99 others); Wed, 28 Feb 2018 09:29:30 -0500 Received: from mail-pg0-f67.google.com ([74.125.83.67]:45726 "EHLO mail-pg0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752420AbeB1O31 (ORCPT ); Wed, 28 Feb 2018 09:29:27 -0500 Received: by mail-pg0-f67.google.com with SMTP id i133so987360pgc.12; Wed, 28 Feb 2018 06:29:26 -0800 (PST) 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=XIMtixO7X9aPr9qCorf1+mIsEV2X49kpj5LakXL5pUM=; b=GJVgmcB/qbNOsCAqc+Oes76FoiKKoIwK6eMcFGc1nLtB5LCtvtZ2HdZ7NUXdZxhCTE OgtamuIN/tZ+cnoh+BkMSmem5ZnClB4MxWRbDgtRxc9W1T9yfVVRmpSP013yw/AWZ36m 5HYJnzfBiGBxctjCoCq+sDE/oujZUoVmQ+Z02fJt6P1ThnphNwbgY/qXc0OG8vZ4mcJI NxbjjhAfY8vQuP0id652qpuHlbiWLOClNppUHLSNDtuLha7B/okTEfgcxmohPKwdZ0tT AVhSoLtNGZ++8ArrKc3m7ByrwQxW732hUgXLPePLBeDKDl98hzjzS/KlYktWDF7GDx8T DUfA== 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=XIMtixO7X9aPr9qCorf1+mIsEV2X49kpj5LakXL5pUM=; b=i9tFpQwfJ5O5h20fL3wNPZLlQb5RJ37AAIY4NW9M+dijHqnX3b7Vw80FAygp8F648w vVKi9B4G/1ULa0yZ6ptMHyVGXNoNNVvF+ypYUtBibCy5EBffwn6XqEQVOF4b5NpOB58P qVQzJFF60T7WeMVgfsni6vIwnBjhOymmdcSxs4KxpChDfU6DN5x15xyWSz8O1yuPDbpc NY5OAvKHWCKuOu13gu1TWvSg7CiNuhalOw9VaYr+k3OtMX1nW0ZNci8QiPxQVkChVbnY C5jWKvIY/7a+qPVW6LN3S5fHK17nSqKf0/0wEhcZYi4ZQvMryoSOiD/FCbdJ+ue1oJSd CdLA== X-Gm-Message-State: APf1xPCrtGKRlgQUrAoWjoga/ASG9T4QNwzoHLL+PkE4XDXHmTICrzYF e+N+lohYcKcjKHGyOSD8trM= X-Received: by 10.98.77.194 with SMTP id a185mr10315407pfb.123.1519828166127; Wed, 28 Feb 2018 06:29:26 -0800 (PST) Received: from server.roeck-us.net (108-223-40-66.lightspeed.sntcca.sbcglobal.net. [108.223.40.66]) by smtp.gmail.com with ESMTPSA id d12sm3622807pfn.42.2018.02.28.06.29.22 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 28 Feb 2018 06:29:24 -0800 (PST) Subject: Re: [PATCH 05/10] hwmon: generic-pwm-tachometer: Add generic PWM based tachometer To: Mikko Perttunen , Rajkumar Rampelli , robh+dt@kernel.org, mark.rutland@arm.com, thierry.reding@gmail.com, jonathanh@nvidia.com, jdelvare@suse.com, corbet@lwn.net, catalin.marinas@arm.com, will.deacon@arm.com, kstewart@linuxfoundation.org, gregkh@linuxfoundation.org, pombredanne@nexb.com, mmaddireddy@nvidia.com, mperttunen@nvidia.com, arnd@arndb.de, timur@codeaurora.org, andy.gross@linaro.org, xuwei5@hisilicon.com, elder@linaro.org, heiko@sntech.de, krzk@kernel.org, ard.biesheuvel@linaro.org Cc: devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-pwm@vger.kernel.org, linux-tegra@vger.kernel.org, linux-hwmon@vger.kernel.org, linux-doc@vger.kernel.org, linux-arm-kernel@lists.infradead.org, ldewangan@nvidia.com References: <1519196339-9377-1-git-send-email-rrajk@nvidia.com> <1519196339-9377-6-git-send-email-rrajk@nvidia.com> <5172edff-fe29-7ed1-f0d2-b0359ea2c24d@roeck-us.net> <2510b525-ec36-b49d-5a62-81f335c0d10d@nvidia.com> <2628eff2-dd33-34f4-a7e1-cfe46ef88a3f@nvidia.com> <4556a8d2-947d-72c4-2962-3167afb53978@kapsi.fi> From: Guenter Roeck Message-ID: <62ba7f67-5a99-51ab-1214-eb68ebb7e642@roeck-us.net> Date: Wed, 28 Feb 2018 06:29:21 -0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: <4556a8d2-947d-72c4-2962-3167afb53978@kapsi.fi> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 02/27/2018 11:03 PM, Mikko Perttunen wrote: > On 02/28/2018 08:12 AM, Rajkumar Rampelli wrote: >> >> On Wednesday 28 February 2018 11:28 AM, Guenter Roeck wrote: >>> On 02/27/2018 09:38 PM, Rajkumar Rampelli wrote: >>>> >>>> On Wednesday 21 February 2018 08:20 PM, Guenter Roeck wrote: >>>>> On 02/20/2018 10:58 PM, Rajkumar Rampelli wrote: >>>>>> Add generic PWM based tachometer driver via HWMON interface >>>>>> to report the RPM of motor. This drivers get the period/duty >>>>>> cycle from PWM IP which captures the motor PWM output. >>>>>> >>>>>> This driver implements a simple interface for monitoring the speed of >>>>>> a fan and exposes it in roatations per minute (RPM) to the user space >>>>>> by using the hwmon's sysfs interface >>>>>> >>>>>> Signed-off-by: Rajkumar Rampelli >>>>>> --- >>>>>>   Documentation/hwmon/generic-pwm-tachometer |  17 +++++ >>>>>>   drivers/hwmon/Kconfig                      |  10 +++ >>>>>>   drivers/hwmon/Makefile                     |   1 + >>>>>>   drivers/hwmon/generic-pwm-tachometer.c     | 112 +++++++++++++++++++++++++++++ >>>>>>   4 files changed, 140 insertions(+) >>>>>>   create mode 100644 Documentation/hwmon/generic-pwm-tachometer >>>>>>   create mode 100644 drivers/hwmon/generic-pwm-tachometer.c >>>>>> >>>>>> diff --git a/Documentation/hwmon/generic-pwm-tachometer b/Documentation/hwmon/generic-pwm-tachometer >>>>>> new file mode 100644 >>>>>> index 0000000..e0713ee >>>>>> --- /dev/null >>>>>> +++ b/Documentation/hwmon/generic-pwm-tachometer >>>>>> @@ -0,0 +1,17 @@ >>>>>> +Kernel driver generic-pwm-tachometer >>>>>> +==================================== >>>>>> + >>>>>> +This driver enables the use of a PWM module to monitor a fan. It uses the >>>>>> +generic PWM interface and can be used on SoCs as along as the SoC supports >>>>>> +Tachometer controller that moniors the Fan speed in periods. >>>>>> + >>>>>> +Author: Rajkumar Rampelli >>>>>> + >>>>>> +Description >>>>>> +----------- >>>>>> + >>>>>> +The driver implements a simple interface for monitoring the Fan speed using >>>>>> +PWM module and Tachometer controller. It requests period value through PWM >>>>>> +capture interface to Tachometer and measures the Rotations per minute using >>>>>> +received period value. It exposes the Fan speed in RPM to the user space by >>>>>> +using the hwmon's sysfs interface. >>>>>> diff --git a/drivers/hwmon/Kconfig b/drivers/hwmon/Kconfig >>>>>> index ef23553..8912dcb 100644 >>>>>> --- a/drivers/hwmon/Kconfig >>>>>> +++ b/drivers/hwmon/Kconfig >>>>>> @@ -1878,6 +1878,16 @@ config SENSORS_XGENE >>>>>>         If you say yes here you get support for the temperature >>>>>>         and power sensors for APM X-Gene SoC. >>>>>>   +config GENERIC_PWM_TACHOMETER >>>>>> +    tristate "Generic PWM based tachometer driver" >>>>>> +    depends on PWM >>>>>> +    help >>>>>> +      Enables a driver to use PWM signal from motor to use >>>>>> +      for measuring the motor speed. The RPM is captured by >>>>>> +      PWM modules which has PWM capture capability and this >>>>>> +      drivers reads the captured data from PWM IP to convert >>>>>> +      it to speed in RPM. >>>>>> + >>>>>>   if ACPI >>>>>>     comment "ACPI drivers" >>>>>> diff --git a/drivers/hwmon/Makefile b/drivers/hwmon/Makefile >>>>>> index f814b4a..9dcc374 100644 >>>>>> --- a/drivers/hwmon/Makefile >>>>>> +++ b/drivers/hwmon/Makefile >>>>>> @@ -175,6 +175,7 @@ obj-$(CONFIG_SENSORS_WM8350)    += wm8350-hwmon.o >>>>>>   obj-$(CONFIG_SENSORS_XGENE)    += xgene-hwmon.o >>>>>>     obj-$(CONFIG_PMBUS)        += pmbus/ >>>>>> +obj-$(CONFIG_GENERIC_PWM_TACHOMETER) += generic-pwm-tachometer.o >>>>>>     ccflags-$(CONFIG_HWMON_DEBUG_CHIP) := -DDEBUG >>>>>>   diff --git a/drivers/hwmon/generic-pwm-tachometer.c b/drivers/hwmon/generic-pwm-tachometer.c >>>>>> new file mode 100644 >>>>>> index 0000000..9354d43 >>>>>> --- /dev/null >>>>>> +++ b/drivers/hwmon/generic-pwm-tachometer.c >>>>>> @@ -0,0 +1,112 @@ >>>>>> +/* >>>>>> + * Copyright (c) 2017-2018, NVIDIA CORPORATION.  All rights reserved. >>>>>> + * >>>>>> + * This program is free software; you can redistribute it and/or modify it >>>>>> + * under the terms and conditions of the GNU General Public License, >>>>>> + * version 2, as published by the Free Software Foundation. >>>>>> + * >>>>>> + * This program is distributed in the hope it will be useful, but WITHOUT >>>>>> + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or >>>>>> + * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for >>>>>> + * more details. >>>>>> + * >>>>>> + */ >>>>>> + >>>>>> +#include >>>>>> +#include >>>>>> +#include >>>>>> +#include >>>>>> +#include >>>>>> +#include >>>>>> + >>>>>> +struct pwm_hwmon_tach { >>>>>> +    struct device        *dev; >>>>>> +    struct pwm_device    *pwm; >>>>>> +    struct device        *hwmon; >>>>>> +}; >>>>>> + >>>>>> +static ssize_t show_rpm(struct device *dev, struct device_attribute *attr, >>>>>> +            char *buf) >>>>>> +{ >>>>>> +    struct pwm_hwmon_tach *ptt = dev_get_drvdata(dev); >>>>>> +    struct pwm_device *pwm = ptt->pwm; >>>>>> +    struct pwm_capture result; >>>>>> +    int err; >>>>>> +    unsigned int rpm = 0; >>>>>> + >>>>>> +    err = pwm_capture(pwm, &result, 0); >>>>>> +    if (err < 0) { >>>>>> +        dev_err(ptt->dev, "Failed to capture PWM: %d\n", err); >>>>>> +        return err; >>>>>> +    } >>>>>> + >>>>>> +    if (result.period) >>>>>> +        rpm = DIV_ROUND_CLOSEST_ULL(60ULL * NSEC_PER_SEC, >>>>>> +                        result.period); >>>>>> + >>>>>> +    return sprintf(buf, "%u\n", rpm); >>>>>> +} >>>>>> + >>>>>> +static SENSOR_DEVICE_ATTR(rpm, 0444, show_rpm, NULL, 0); >>>>>> + >>>>>> +static struct attribute *pwm_tach_attrs[] = { >>>>>> +    &sensor_dev_attr_rpm.dev_attr.attr, >>>>>> +    NULL, >>>>>> +}; >>>>> >>>>> "rpm" is not a standard hwmon sysfs attribute. If you don't provide >>>>> a single standard hwmon sysfs attribute, having a hwmon driver is pointless. >>>> Guenter Roeck, >>>> I will define a new hwmon sysfs attribute node called "hwmon_tachometer_attributes" in hwmon.h like below and update the same in tachometer hwmon driver. Is it fine ? >>>> enum hwmon_tachometer_attributes { >>> >>> Are you kidding me ? >>> >>> Guenter >> Sorry, I just wanted to confirm whether my understanding is correct or not before implementing it actually. >> Or, shall I add this attribute as a part of fan attributes with "hwmon_fan_rpm" ? or any other way to do it ? I need your inputs in fixing this. > > I think he wants the attribute to be named according to the properties in this document: https://www.kernel.org/doc/Documentation/hwmon/sysfs-interface. I guess the attribute would then map to fan1_input, though I'm not sure if that's 100% correct either since this could technically be attached to something other than a fan. But I would think in practice that's not a big concern. > > Guenter, > Please correct me as well if I'm wrong. > You are absolutely correct. While I am not opposed to ABI changes, the merits of those would need to be discussed on the mailing list. But replacing "fan1_input" with "rpm" is not an acceptable ABI change, even if it may measure something that turns but isn't a fan. If this _is_ in fact supposed to be used for something else but fans, we would have to discuss what that might be, and if hwmon is the appropriate subsystem to measure and report it. This does to some degree lead back to my concern of having the "fan" part of this patch series in the pwm core. I am still not sure if that makes sense. Thanks, Guenter > Thank you, > Mikko > >> >> -- >> To unsubscribe from this list: send the line "unsubscribe linux-tegra" in >> the body of a message to majordomo@vger.kernel.org >> More majordomo info at  http://vger.kernel.org/majordomo-info.html > -- > To unsubscribe from this list: send the line "unsubscribe linux-hwmon" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at  http://vger.kernel.org/majordomo-info.html >