From: Billy Tsai <billy_tsai@aspeedtech.com>
To: Rob Herring <robh@kernel.org>
Cc: "lee.jones@linaro.org" <lee.jones@linaro.org>,
"joel@jms.id.au" <joel@jms.id.au>,
"andrew@aj.id.au" <andrew@aj.id.au>,
"thierry.reding@gmail.com" <thierry.reding@gmail.com>,
"u.kleine-koenig@pengutronix.de" <u.kleine-koenig@pengutronix.de>,
"p.zabel@pengutronix.de" <p.zabel@pengutronix.de>,
"devicetree@vger.kernel.org" <devicetree@vger.kernel.org>,
"linux-arm-kernel@lists.infradead.org"
<linux-arm-kernel@lists.infradead.org>,
"linux-aspeed@lists.ozlabs.org" <linux-aspeed@lists.ozlabs.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
"linux-pwm@vger.kernel.org" <linux-pwm@vger.kernel.org>,
BMC-SW <BMC-SW@aspeedtech.com>
Subject: Re: [v9 1/2] dt-bindings: Add bindings for aspeed pwm-tach.
Date: Wed, 14 Jul 2021 04:02:34 +0000 [thread overview]
Message-ID: <029CA29B-1488-4F73-A9E7-FB9BCD0B987F@aspeedtech.com> (raw)
In-Reply-To: <20210713221431.GA936073@robh.at.kernel.org>
On 2021/7/14, 6:14 AM, "Rob Herring" <robh@kernel.org> wrote:
On Fri, Jul 09, 2021 at 02:52:16PM +0800, Billy Tsai wrote:
>> This patch adds device binding for aspeed pwm-tach device which is a
>> multi-function device include pwm and tach function and pwm/tach device
>> bindings which should be the child-node of pwm-tach device.
>I'll say it again, the fan control h/w needs some common bindings for
>describing fans and fan connections to pwm and tach. I'm not going to
>sign off on more fan bindings just doing their own thing.
This patch doesn't use to binding the fan control h/w. It is used to binding the two independent h/w blocks.
One is used to provide pwm output and another is used to monitor the speed of the input.
It is different from "aspeed-pwm-tacho.txt" and "npcm750-pwm-fan.txt" which only focus on fan usage.
It is more like the "kontron,sl28cpld.yaml" the device includes a fan monitor and PWM output devices.
>>
>> Signed-off-by: Billy Tsai <billy_tsai@aspeedtech.com>
>> ---
>> .../bindings/hwmon/aspeed,ast2600-tach.yaml | 69 +++++++++++++++
>> .../bindings/mfd/aspeed,ast2600-pwm-tach.yaml | 87 +++++++++++++++++++
>> .../bindings/pwm/aspeed,ast2600-pwm.yaml | 64 ++++++++++++++
>> 3 files changed, 220 insertions(+)
>> create mode 100644 Documentation/devicetree/bindings/hwmon/aspeed,ast2600-tach.yaml
>> create mode 100644 Documentation/devicetree/bindings/mfd/aspeed,ast2600-pwm-tach.yaml
>> create mode 100644 Documentation/devicetree/bindings/pwm/aspeed,ast2600-pwm.yaml
>>
>> diff --git a/Documentation/devicetree/bindings/hwmon/aspeed,ast2600-tach.yaml b/Documentation/devicetree/bindings/hwmon/aspeed,ast2600-tach.yaml
>> new file mode 100644
>> index 000000000000..a08471f96a61
>> --- /dev/null
>> +++ b/Documentation/devicetree/bindings/hwmon/aspeed,ast2600-tach.yaml
>> @@ -0,0 +1,69 @@
>> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
>> +# Copyright (C) 2021 Aspeed, Inc.
>> +%YAML 1.2
>> +---
>> +$id: http://devicetree.org/schemas/hwmon/aspeed,ast2600-tach.yaml#
>> +$schema: http://devicetree.org/meta-schemas/core.yaml#
>> +
>> +title: Aspeed Ast2600 Tach controller
>> +
>> +maintainers:
>> + - Billy Tsai <billy_tsai@aspeedtech.com>
>> +
>> +description: |
>> + The Aspeed Tach controller can support upto 16 fan input.
>> + This module is part of the ast2600-pwm-tach multi-function device. For more
>> + details see ../mfd/aspeed,ast2600-pwm-tach.yaml.
>> +
>> +properties:
>> + compatible:
>> + enum:
>> + - aspeed,ast2600-tach
>> +
>> + "#address-cells":
>> + const: 1
>> +
>> + "#size-cells":
>> + const: 0
>> +
>> + pinctrl-0: true
>> +
>> + pinctrl-names:
>> + const: default
>> +
>> +required:
>> + - compatible
>> + - "#address-cells"
>> + - "#size-cells"
>> +
>> +additionalProperties:
>> + type: object
>> + properties:
>> + reg:
>> + description:
>> + The tach channel used for this fan.
>> + maxItems: 1
>> +
>> + aspeed,min-rpm:
>> + description:
>> + define the minimal revolutions per minute of the measure fan
>> + used to calculate the sample period of tach
>> + default: 1000
>> +
>> + aspeed,pulse-pr:
>> + description:
>> + Value specifying the number of pulses per revolution of the
>> + monitored FAN.
>> + default: 2
>> +
>> + aspeed,tach-div:
>> + description:
>> + define the tachometer clock divider as an integer. Formula of
>> + tach clock = clock source / (2^tach-div)^2
>> + minimum: 0
>> + maximum: 15
>> + # The value that should be used if the property is not present
>> + default: 5
>> +
>> + required:
>> + - reg
>> diff --git a/Documentation/devicetree/bindings/mfd/aspeed,ast2600-pwm-tach.yaml b/Documentation/devicetree/bindings/mfd/aspeed,ast2600-pwm-tach.yaml
>> new file mode 100644
>> index 000000000000..ab49aff1928a
>> --- /dev/null
>> +++ b/Documentation/devicetree/bindings/mfd/aspeed,ast2600-pwm-tach.yaml
>> @@ -0,0 +1,87 @@
>> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
>> +# Copyright (C) 2021 Aspeed, Inc.
>> +%YAML 1.2
>> +---
>> +$id: http://devicetree.org/schemas/mfd/aspeed,ast2600-pwm-tach.yaml#
>> +$schema: http://devicetree.org/meta-schemas/core.yaml#
>> +
>> +title: PWM Tach controller Device Tree Bindings
>> +
>> +description: |
>> + The PWM Tach controller is represented as a multi-function device which
>> + includes:
>> + PWM
>> + Tach
>> +
>> +maintainers:
>> + - Billy Tsai <billy_tsai@aspeedtech.com>
>> +
>> +properties:
>> + compatible:
>> + items:
>> + - enum:
>> + - aspeed,ast2600-pwm-tach
>> + - const: syscon
>> + - const: simple-mfd
>> +
>> + reg:
>> + maxItems: 1
>> +
>> + clocks:
>> + maxItems: 1
>> +
>> + resets:
>> + maxItems: 1
>> +
>> +required:
>> + - compatible
>> + - reg
>> + - clocks
>> + - resets
>> +
>> +patternProperties:
>> + "^pwm(@[0-9a-f]+)?$":
>> + $ref: ../pwm/aspeed,ast2600-pwm.yaml
>> +
>> + "^tach(@[0-9a-f]+)?$":
>> + $ref: ../hwmon/aspeed,ast2600-tach.yaml
>> +
>> +additionalProperties: false
>> +
>> +examples:
>> + - |
>> + #include <dt-bindings/clock/ast2600-clock.h>
>> + pwm_tach: pwm_tach@1e610000 {
>> + compatible = "aspeed,ast2600-pwm-tach", "syscon", "simple-mfd";
>> + reg = <0x1e610000 0x100>;
>> + clocks = <&syscon ASPEED_CLK_AHB>;
>> + resets = <&syscon ASPEED_RESET_PWM>;
>> +
>> + pwm: pwm {
>> + compatible = "aspeed,ast2600-pwm";
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> + #pwm-cells = <3>;
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&pinctrl_pwm0_default>;
>> + pwm-ch@0 {
>> + reg = <0>;
>> + aspeed,wdt-reload-enable;
>> + aspeed,wdt-reload-duty-point = <32>;
>> + };
>> + };
>> +
>> + tach: tach {
>> + compatible = "aspeed,ast2600-tach";
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&pinctrl_tach0_default>;
>> + tach-ch@0 {
>> + reg = <0>;
>> + aspeed,min-rpm = <1000>;
>> + aspeed,pulse-pr = <2>;
>> + aspeed,tach-div = <5>;
>> + };
>> + };
>> + };
>> diff --git a/Documentation/devicetree/bindings/pwm/aspeed,ast2600-pwm.yaml b/Documentation/devicetree/bindings/pwm/aspeed,ast2600-pwm.yaml
>> new file mode 100644
>> index 000000000000..f501f8a769df
>> --- /dev/null
>> +++ b/Documentation/devicetree/bindings/pwm/aspeed,ast2600-pwm.yaml
>> @@ -0,0 +1,64 @@
>> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
>> +# Copyright (C) 2021 Aspeed, Inc.
>> +%YAML 1.2
>> +---
>> +$id: http://devicetree.org/schemas/pwm/aspeed,ast2600-pwm.yaml#
>> +$schema: http://devicetree.org/meta-schemas/core.yaml#
>> +
>> +title: Aspeed Ast2600 PWM controller
>> +
>> +maintainers:
>> + - Billy Tsai <billy_tsai@aspeedtech.com>
>> +
>> +description: |
>> + The Aspeed PWM controller can support upto 16 PWM outputs.
>> + This module is part of the ast2600-pwm-tach multi-function device. For more
>> + details see ../mfd/aspeed,ast2600-pwm-tach.yaml.
>> +
>> +properties:
>> + compatible:
>> + enum:
>> + - aspeed,ast2600-pwm
>> +
>> + "#pwm-cells":
>> + const: 3
>> +
>> + "#address-cells":
>> + const: 1
>> +
>> + "#size-cells":
>> + const: 0
>> +
>> + pinctrl-0: true
>> +
>> + pinctrl-names:
>> + const: default
>> +
>> +required:
>> + - compatible
>> + - "#pwm-cells"
>> + - "#address-cells"
>> + - "#size-cells"
>> +
>> +additionalProperties:
>> + description: Set extend properties for each pwm channel.
>> + type: object
>> + properties:
>> + reg:
>> + description:
>> + The pwm channel index.
>> + maxItems: 1
>> +
>> + aspeed,wdt-reload-enable:
>> + type: boolean
>> + description:
>> + Enable the function of wdt reset reload duty point.
>> +
>> + aspeed,wdt-reload-duty-point:
>> + description:
>> + Define the duty point after wdt reset, 0 = 100%
>> + minimum: 0
>> + maximum: 255
>> +
>> + required:
>> + - reg
>> --
>> 2.25.1
>>
>>
next prev parent reply other threads:[~2021-07-14 4:03 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-07-09 6:52 [v9 0/2] Support pwm driver for aspeed ast26xx Billy Tsai
2021-07-09 6:52 ` [v9 1/2] dt-bindings: Add bindings for aspeed pwm-tach Billy Tsai
2021-07-13 22:14 ` Rob Herring
2021-07-14 4:02 ` Billy Tsai [this message]
2021-10-04 1:46 ` Billy Tsai
2021-07-09 6:52 ` [v9 2/2] pwm: Add Aspeed ast2600 PWM support Billy Tsai
2021-07-15 15:05 ` Uwe Kleine-König
2021-07-16 1:48 ` Billy Tsai
2021-07-16 7:09 ` Uwe Kleine-König
2021-07-16 9:22 ` Billy Tsai
2021-07-16 10:13 ` Uwe Kleine-König
2021-07-16 10:56 ` Billy Tsai
2021-07-21 10:52 ` Billy Tsai
2021-07-21 12:48 ` Uwe Kleine-König
2021-07-23 4:23 ` Billy Tsai
2021-07-23 20:12 ` Uwe Kleine-König
2021-07-26 5:14 ` Billy Tsai
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=029CA29B-1488-4F73-A9E7-FB9BCD0B987F@aspeedtech.com \
--to=billy_tsai@aspeedtech.com \
--cc=BMC-SW@aspeedtech.com \
--cc=andrew@aj.id.au \
--cc=devicetree@vger.kernel.org \
--cc=joel@jms.id.au \
--cc=lee.jones@linaro.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-aspeed@lists.ozlabs.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pwm@vger.kernel.org \
--cc=p.zabel@pengutronix.de \
--cc=robh@kernel.org \
--cc=thierry.reding@gmail.com \
--cc=u.kleine-koenig@pengutronix.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).