Re: [PATCH v2] dt-bindings:iio:adc:st,spear600-adc: txt to yaml format conversion.
From: Jonathan Cameron
Date: Sun May 04 2025 - 12:54:03 EST
On Tue, 29 Apr 2025 22:50:01 -0300
Rodrigo Gobbi <rodrigo.gobbi.7@xxxxxxxxx> wrote:
> Straight forward conversion from spear-adc.txt into yaml format.
>
> Signed-off-by: Rodrigo Gobbi <rodrigo.gobbi.7@xxxxxxxxx>
> ---
> Some constraints were extracted from the driver (spear_adc.c) and the public datasheet
> referenced at the yaml.
>
> Changelog:
> v2: add constraints over properties and remove a ref at MAINTAINERS file.
> v1: https://lore.kernel.org/linux-devicetree/20250423022956.31218-1-rodrigo.gobbi.7@xxxxxxxxx/
> ---
> .../bindings/iio/adc/st,spear600-adc.yaml | 69 +++++++++++++++++++
> .../bindings/staging/iio/adc/spear-adc.txt | 24 -------
> MAINTAINERS | 2 +-
> 3 files changed, 70 insertions(+), 25 deletions(-)
> create mode 100644 Documentation/devicetree/bindings/iio/adc/st,spear600-adc.yaml
> delete mode 100644 Documentation/devicetree/bindings/staging/iio/adc/spear-adc.txt
>
> diff --git a/Documentation/devicetree/bindings/iio/adc/st,spear600-adc.yaml b/Documentation/devicetree/bindings/iio/adc/st,spear600-adc.yaml
> new file mode 100644
> index 000000000000..afce10eab1c1
> --- /dev/null
> +++ b/Documentation/devicetree/bindings/iio/adc/st,spear600-adc.yaml
> @@ -0,0 +1,69 @@
> +# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
> +%YAML 1.2
> +---
> +$id: http://devicetree.org/schemas/iio/adc/st,spear600-adc.yaml#
> +$schema: http://devicetree.org/meta-schemas/core.yaml#
> +
> +title: ST SPEAr ADC device driver
> +
> +maintainers:
> + - Jonathan Cameron <jic23@xxxxxxxxxx>
> +
> +description: |
> + Integrated ADC inside the ST SPEAr SoC, SPEAr600, supporting
> + 10-bit resolution. Datasheet can be found here:
> + https://www.st.com/resource/en/datasheet/spear600.pdf
> +
> +properties:
> + compatible:
> + enum:
> + - st,spear600-adc
> +
> + reg:
> + maxItems: 1
> +
> + interrupts:
> + maxItems: 1
> +
> + sampling-frequency:
> + $ref: /schemas/types.yaml#/definitions/uint32
> + minimum: 2500000
> + maximum: 20000000
> + description:
> + Default sampling frequency of the ADC
For consistency probably wants a full stop. (as well as units)
> +
> + vref-external:
> + $ref: /schemas/types.yaml#/definitions/uint32
> + minimum: 1000
> + maximum: 2800
> + description:
> + External voltage reference in milli-volts. If omitted
Very short wrap. Go up to 80 chars.
> + the internal voltage reference will be used.
> +
> + average-samples:
> + $ref: /schemas/types.yaml#/definitions/uint32
> + minimum: 1
> + maximum: 128
> + default: 0
> + description:
> + Number of samples to generate an average value. If
> + omitted, single data conversion will be used.
It is odd to have a default outside of range. I'll wait
to see what Conor suggests for that. I'm fine with anything
that doesn't trip up the dt parsing!
> +
> +required:
> + - compatible
> + - reg
> + - interrupts
> + - sampling-frequency
> +
> +additionalProperties: false
> +
> +examples:
> + - |
> + adc: adc@d8200000 {
> + compatible = "st,spear600-adc";
> + reg = <0xd8200000 0x1000>;
> + interrupt-parent = <&vic1>;
> + interrupts = <6>;
> + sampling-frequency = <5000000>;
> + vref-external = <2500>; /* 2.5V VRef */
> + };