Re: [PATCH v4 3/5] dt-bindings: hwmon: Document adt7475 invert-pwm property

From: Rob Herring
Date: Fri Feb 21 2020 - 10:40:15 EST


On Thu, Feb 20, 2020 at 10:16 PM Chris Packham
<chris.packham@xxxxxxxxxxxxxxxxxxx> wrote:
>
> Add binding information for the invert-pwm property.
>
> Signed-off-by: Chris Packham <chris.packham@xxxxxxxxxxxxxxxxxxx>
> ---
>
> Notes:
> Changes in v4:
> - use $ref uint32 and enum
> - add adi vendor prefix
>
> Cahnges in v3:
> - new
>
> Documentation/devicetree/bindings/hwmon/adt7475.yaml | 12 ++++++++++++
> 1 file changed, 12 insertions(+)
>
> diff --git a/Documentation/devicetree/bindings/hwmon/adt7475.yaml b/Documentation/devicetree/bindings/hwmon/adt7475.yaml
> index e40612ee075f..6a358b30586c 100644
> --- a/Documentation/devicetree/bindings/hwmon/adt7475.yaml
> +++ b/Documentation/devicetree/bindings/hwmon/adt7475.yaml
> @@ -50,6 +50,17 @@ patternProperties:
> - $ref: /schemas/types.yaml#/definitions/uint32
> - enum: [0, 1]
>
> + "^adi,invert-pwm[1-3]$":
> + description: |
> + Configures the pwm output to use inverted logic. If set to 1
> + the pwm uses a logic low output for 100% duty cycle. If set
> + to 0 the pwm uses a logic high output for 100% duty cycle.
> + If the property is absent the pwm retains it's configuration
> + from the bios/bootloader.

I believe we already have an inverted flag for consumers. That doesn't
work if you don't have a consumer described in DT, but then the
question is should you? Or is this something the user will want to
configure from userspace.

The problem with 'invert' properties is they assume you know what the
not inverted state is. I would also make this an array:

adi,pwm-active-state = <1 0 0 1>; // PWM1 and PWM2 active low

And not present means <1 1 1 1>.

Rob