[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <21f59c3b-1d54-6980-8e25-af7532a1cbae@gmx.de>
Date: Thu, 9 Jun 2022 07:49:49 +0200
From: Heinrich Schuchardt <xypron.glpk@....de>
To: Rob Herring <robh@...nel.org>
Cc: Hans de Goede <hdegoede@...hat.com>, Chen-Yu Tsai <wens@...e.org>,
Jernej Skrabec <jernej.skrabec@...il.com>,
Samuel Holland <samuel@...lland.org>,
Bartosz Golaszewski <brgl@...ev.pl>,
Artur Rojek <contact@...ur-rojek.eu>,
Maxime Ripard <mripard@...nel.org>,
Jeff LaBundy <jeff@...undy.com>, linux-input@...r.kernel.org,
devicetree@...r.kernel.org, linux-kernel@...r.kernel.org,
Alexandre Belloni <alexandre.belloni@...tlin.com>,
Krzysztof Kozlowski <krzysztof.kozlowski+dt@...aro.org>,
Dmitry Torokhov <dmitry.torokhov@...il.com>
Subject: Re: [PATCH v2 5/5] dt-bindings: input: Convert adc-keys to DT schema
On 6/8/22 23:12, Rob Herring wrote:
> Convert the adc-keys binding to DT schema format.
>
> The old binding has 'label' as required, but it should never be
> required given it's just a human readable description.
>
> Signed-off-by: Rob Herring <robh@...nel.org>
> ---
> v2:
> - Drop Heinrich as a maintainer
> - Use common linux,code definition
> - Drop label as required
> ---
> .../devicetree/bindings/input/adc-keys.txt | 67 ------------
> .../devicetree/bindings/input/adc-keys.yaml | 103 ++++++++++++++++++
> 2 files changed, 103 insertions(+), 67 deletions(-)
> delete mode 100644 Documentation/devicetree/bindings/input/adc-keys.txt
> create mode 100644 Documentation/devicetree/bindings/input/adc-keys.yaml
>
> diff --git a/Documentation/devicetree/bindings/input/adc-keys.txt b/Documentation/devicetree/bindings/input/adc-keys.txt
> deleted file mode 100644
> index 6c8be6a9ace2..000000000000
> --- a/Documentation/devicetree/bindings/input/adc-keys.txt
> +++ /dev/null
> @@ -1,67 +0,0 @@
> -ADC attached resistor ladder buttons
> -------------------------------------
> -
> -Required properties:
> - - compatible: "adc-keys"
> - - io-channels: Phandle to an ADC channel
> - - io-channel-names = "buttons";
> - - keyup-threshold-microvolt: Voltage above or equal to which all the keys are
> - considered up.
> -
> -Optional properties:
> - - poll-interval: Poll interval time in milliseconds
> - - autorepeat: Boolean, Enable auto repeat feature of Linux input
> - subsystem.
> -
> -Each button (key) is represented as a sub-node of "adc-keys":
> -
> -Required subnode-properties:
> - - label: Descriptive name of the key.
> - - linux,code: Keycode to emit.
> - - press-threshold-microvolt: voltage above or equal to which this key is
> - considered pressed.
> -
> -No two values of press-threshold-microvolt may be the same.
> -All values of press-threshold-microvolt must be less than
> -keyup-threshold-microvolt.
> -
> -Example:
> -
> -#include <dt-bindings/input/input.h>
> -
> - adc-keys {
> - compatible = "adc-keys";
> - io-channels = <&lradc 0>;
> - io-channel-names = "buttons";
> - keyup-threshold-microvolt = <2000000>;
> -
> - button-up {
> - label = "Volume Up";
> - linux,code = <KEY_VOLUMEUP>;
> - press-threshold-microvolt = <1500000>;
> - };
> -
> - button-down {
> - label = "Volume Down";
> - linux,code = <KEY_VOLUMEDOWN>;
> - press-threshold-microvolt = <1000000>;
> - };
> -
> - button-enter {
> - label = "Enter";
> - linux,code = <KEY_ENTER>;
> - press-threshold-microvolt = <500000>;
> - };
> - };
> -
> -+--------------------------------+------------------------+
> -| 2.000.000 <= value | no key pressed |
> -+--------------------------------+------------------------+
> -| 1.500.000 <= value < 2.000.000 | KEY_VOLUMEUP pressed |
> -+--------------------------------+------------------------+
> -| 1.000.000 <= value < 1.500.000 | KEY_VOLUMEDOWN pressed |
> -+--------------------------------+------------------------+
> -| 500.000 <= value < 1.000.000 | KEY_ENTER pressed |
> -+--------------------------------+------------------------+
> -| value < 500.000 | no key pressed |
> -+--------------------------------+------------------------+
> diff --git a/Documentation/devicetree/bindings/input/adc-keys.yaml b/Documentation/devicetree/bindings/input/adc-keys.yaml
> new file mode 100644
> index 000000000000..7aa078dead37
> --- /dev/null
> +++ b/Documentation/devicetree/bindings/input/adc-keys.yaml
> @@ -0,0 +1,103 @@
> +# SPDX-License-Identifier: GPL-2.0
> +%YAML 1.2
> +---
> +$id: http://devicetree.org/schemas/input/adc-keys.yaml#
> +$schema: http://devicetree.org/meta-schemas/core.yaml#
> +
> +title: ADC attached resistor ladder buttons
> +
> +maintainers:
> + - Alexandre Belloni <alexandre.belloni@...tlin.com>
> +
> +allOf:
> + - $ref: input.yaml#
> +
> +properties:
> + compatible:
> + const: adc-keys
> +
> + io-channels:
> + maxItems: 1
> +
> + io-channel-names:
> + const: buttons
> +
> + keyup-threshold-microvolt:
> + description:
> + Voltage above or equal to which all the keys are considered up.
> +
> + poll-interval: true
> + autorepeat: true
> +
> +patternProperties:
> + '^button-':
> + type: object
> + $ref: input.yaml#
> + additionalProperties: false
> + description:
> + Each button (key) is represented as a sub-node.
> +
> + properties:
> + label: true
> +
> + linux,code: true
Can we provide a reference to a new type in
Documentation/devicetree/bindings/input/input.yaml limiting the range to
0 - 0x2ff?
Best regards
Heinrich
> +
> + press-threshold-microvolt:
> + description:
> + Voltage above or equal to which this key is considered pressed. No
> + two values of press-threshold-microvolt may be the same. All values
> + of press-threshold-microvolt must be less than
> + keyup-threshold-microvolt.
> +
> + required:
> + - linux,code
> + - press-threshold-microvolt
> +
> +required:
> + - compatible
> + - io-channels
> + - io-channel-names
> + - keyup-threshold-microvolt
> +
> +additionalProperties: false
> +
> +examples:
> + - |
> + #include <dt-bindings/input/input.h>
> + // +--------------------------------+------------------------+
> + // | 2.000.000 <= value | no key pressed |
> + // +--------------------------------+------------------------+
> + // | 1.500.000 <= value < 2.000.000 | KEY_VOLUMEUP pressed |
> + // +--------------------------------+------------------------+
> + // | 1.000.000 <= value < 1.500.000 | KEY_VOLUMEDOWN pressed |
> + // +--------------------------------+------------------------+
> + // | 500.000 <= value < 1.000.000 | KEY_ENTER pressed |
> + // +--------------------------------+------------------------+
> + // | value < 500.000 | no key pressed |
> + // +--------------------------------+------------------------+
> +
> + adc-keys {
> + compatible = "adc-keys";
> + io-channels = <&lradc 0>;
> + io-channel-names = "buttons";
> + keyup-threshold-microvolt = <2000000>;
> +
> + button-up {
> + label = "Volume Up";
> + linux,code = <KEY_VOLUMEUP>;
> + press-threshold-microvolt = <1500000>;
> + };
> +
> + button-down {
> + label = "Volume Down";
> + linux,code = <KEY_VOLUMEDOWN>;
> + press-threshold-microvolt = <1000000>;
> + };
> +
> + button-enter {
> + label = "Enter";
> + linux,code = <KEY_ENTER>;
> + press-threshold-microvolt = <500000>;
> + };
> + };
> +...
Powered by blists - more mailing lists