Re: [PATCH v2 18/20] dt-bindings:iio:adc:amlogic,meson-saradc yaml conversion

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, Sep 09, 2020 at 06:59:44PM +0100, Jonathan Cameron wrote:
> From: Jonathan Cameron <Jonathan.Cameron@xxxxxxxxxx>
> 
> This binding is non trivial due to the range of different parts
> supported having several subtle quirks. Martin has helped
> clarify some of them.
> 
> Note, I haven't restricted the amlogic,hhi-sysctrl to only
> be present on the relevant parts if nvmem stuff also is, but
> it would seem to be rather odd if it were otherwise.
> 
> Perhaps we look to make this binding more restrictive at a later date.
> 
> Signed-off-by: Jonathan Cameron <Jonathan.Cameron@xxxxxxxxxx>
> Cc: Martin Blumenstingl <martin.blumenstingl@xxxxxxxxxxxxxx>
> Cc: Kevin Hilman <khilman@xxxxxxxxxxxx>
> Cc: Neil Armstrong <narmstrong@xxxxxxxxxxxx>
> Cc: Jerome Brunet <jbrunet@xxxxxxxxxxxx>
> ---
>  .../bindings/iio/adc/amlogic,meson-saradc.txt |  48 ------
>  .../iio/adc/amlogic,meson-saradc.yaml         | 149 ++++++++++++++++++
>  2 files changed, 149 insertions(+), 48 deletions(-)
> 
> diff --git a/Documentation/devicetree/bindings/iio/adc/amlogic,meson-saradc.txt b/Documentation/devicetree/bindings/iio/adc/amlogic,meson-saradc.txt
> deleted file mode 100644
> index d57e9df25f4f..000000000000
> --- a/Documentation/devicetree/bindings/iio/adc/amlogic,meson-saradc.txt
> +++ /dev/null
> @@ -1,48 +0,0 @@
> -* Amlogic Meson SAR (Successive Approximation Register) A/D converter
> -
> -Required properties:
> -- compatible:	depending on the SoC this should be one of:
> -			- "amlogic,meson8-saradc" for Meson8
> -			- "amlogic,meson8b-saradc" for Meson8b
> -			- "amlogic,meson8m2-saradc" for Meson8m2
> -			- "amlogic,meson-gxbb-saradc" for GXBB
> -			- "amlogic,meson-gxl-saradc" for GXL
> -			- "amlogic,meson-gxm-saradc" for GXM
> -			- "amlogic,meson-axg-saradc" for AXG
> -			- "amlogic,meson-g12a-saradc" for AXG
> -		along with the generic "amlogic,meson-saradc"
> -- reg:		the physical base address and length of the registers
> -- interrupts:	the interrupt indicating end of sampling
> -- clocks:	phandle and clock identifier (see clock-names)
> -- clock-names:	mandatory clocks:
> -			- "clkin" for the reference clock (typically XTAL)
> -			- "core" for the SAR ADC core clock
> -		optional clocks:
> -			- "adc_clk" for the ADC (sampling) clock
> -			- "adc_sel" for the ADC (sampling) clock mux
> -- vref-supply:	the regulator supply for the ADC reference voltage
> -- #io-channel-cells: must be 1, see ../iio-bindings.txt
> -
> -Optional properties:
> -- amlogic,hhi-sysctrl:	phandle to the syscon which contains the 5th bit
> -			of the TSC (temperature sensor coefficient) on
> -			Meson8b and Meson8m2 (which used to calibrate the
> -			temperature sensor)
> -- nvmem-cells:		phandle to the temperature_calib eFuse cells
> -- nvmem-cell-names:	if present (to enable the temperature sensor
> -			calibration) this must contain "temperature_calib"
> -
> -
> -Example:
> -	saradc: adc@8680 {
> -		compatible = "amlogic,meson-gxl-saradc", "amlogic,meson-saradc";
> -		#io-channel-cells = <1>;
> -		reg = <0x0 0x8680 0x0 0x34>;
> -		interrupts = <GIC_SPI 73 IRQ_TYPE_EDGE_RISING>;
> -		clocks = <&xtal>,
> -			 <&clkc CLKID_SAR_ADC>,
> -			 <&clkc CLKID_SANA>,
> -			 <&clkc CLKID_SAR_ADC_CLK>,
> -			 <&clkc CLKID_SAR_ADC_SEL>;
> -		clock-names = "clkin", "core", "sana", "adc_clk", "adc_sel";
> -	};
> diff --git a/Documentation/devicetree/bindings/iio/adc/amlogic,meson-saradc.yaml b/Documentation/devicetree/bindings/iio/adc/amlogic,meson-saradc.yaml
> new file mode 100644
> index 000000000000..6d94bf76900e
> --- /dev/null
> +++ b/Documentation/devicetree/bindings/iio/adc/amlogic,meson-saradc.yaml
> @@ -0,0 +1,149 @@
> +# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
> +%YAML 1.2
> +---
> +$id: http://devicetree.org/schemas/iio/adc/amlogic,meson-saradc.yaml#
> +$schema: http://devicetree.org/meta-schemas/core.yaml#
> +
> +title: Amlogic Meson SAR (Successive Approximation Register) A/D converter
> +
> +maintainers:
> +  - Martin Blumenstingl <martin.blumenstingl@xxxxxxxxxxxxxx>
> +
> +description:
> +  Binding covers a range of ADCs found on amlogic meson SoCs.
> +
> +properties:
> +  compatible:
> +    oneOf:
> +      - const: amlogic,meson-saradc
> +      - items:
> +          - enum:
> +              - amlogic,meson8-saradc
> +              - amlogic,meson8b-saradc
> +              - amlogic,meson8m2-saradc
> +              - amlogic,meson-gxbb-saradc
> +              - amlogic,meson-gxl-saradc
> +              - amlogic,meson-gxm-saradc
> +              - amlogic,meson-axg-saradc
> +              - amlogic,meson-g12a-saradc
> +          - const: amlogic,meson-saradc
> +
> +  reg:
> +    maxItems: 1
> +
> +  interrupts:
> +    description: Interrupt indicates end of sampling.
> +    maxItems: 1
> +
> +  clocks: true
> +
> +  clock-names: true

Since the names are the same, I prefer to have a schema that covers both 
cases here and then...

> +
> +  vref-supply: true
> +
> +  "#io-channel-cells":
> +    const: 1
> +
> +  amlogic,hhi-sysctrl:
> +    $ref: /schemas/types.yaml#/definitions/phandle
> +    description:
> +      Syscon which contains the 5th bit of the TSC (temperature sensor
> +      coefficient) on Meson8b and Meson8m2 (which used to calibrate the
> +      temperature sensor)
> +
> +  nvmem-cells:
> +    description: phandle to the temperature_calib eFuse cells

maxItems: 1

> +
> +  nvmem-cell-names:
> +    const: temperature_calib
> +
> +allOf:
> +  - if:
> +      properties:
> +        compatible:
> +          contains:
> +            enum:
> +              - amlogic,meson8-saradc
> +              - amlogic,meson8b-saradc
> +              - amlogic,meson8m2-saradc
> +    then:
> +      properties:
> +        nvmem-cells: true
> +        nvmem-cell-names: true

You can drop these 2.

> +        clock-names:
> +          items:
> +            - const: clkin
> +            - const: core
> +          minItems: 2
> +        clocks:
> +          minItems: 2

This case just needs 'maxItems: 2' for clock-names and clocks.

> +    else:
> +      properties:
> +        nvmem-cells: false
> +        mvmem-cel-names: false
> +        clock-names:
> +          items:
> +            - const: clkin
> +            - const: core
> +            - const: adc_clk
> +            - const: adc_sel
> +          minItems: 4

And just minItems here.

> +        clocks:
> +          minItems: 4
> +
> +  - if:
> +      properties:
> +        compatible:
> +          contains:
> +            enum:
> +              - amlogic,meson8b-saradc
> +              - amlogic,meson8m2-saradc
> +    then:
> +      properties:
> +        amlogic,hhi-sysctrl: true
> +    else:
> +      properties:
> +        amlogic,hhi-sysctrl: false
> +
> +required:
> +  - compatible
> +  - reg
> +  - interrupts
> +  - clocks
> +  - clock-names
> +  - "#io-channel-cells"
> +
> +additionalProperties: false
> +
> +examples:
> +  - |
> +    #include <dt-bindings/interrupt-controller/irq.h>
> +    #include <dt-bindings/clock/gxbb-clkc.h>
> +    #include <dt-bindings/interrupt-controller/arm-gic.h>
> +    soc {
> +        #address-cells = <2>;
> +        #size-cells = <2>;
> +        adc@8680 {
> +            compatible = "amlogic,meson-gxl-saradc", "amlogic,meson-saradc";
> +            #io-channel-cells = <1>;
> +            reg = <0x0 0x8680 0x0 0x34>;
> +            interrupts = <GIC_SPI 73 IRQ_TYPE_EDGE_RISING>;
> +            clocks = <&xtal>,
> +                <&clkc CLKID_SAR_ADC>,
> +                <&clkc CLKID_SAR_ADC_CLK>,
> +                <&clkc CLKID_SAR_ADC_SEL>;
> +            clock-names = "clkin", "core", "adc_clk", "adc_sel";
> +        };
> +        adc@9680 {
> +            compatible = "amlogic,meson8b-saradc", "amlogic,meson-saradc";
> +            #io-channel-cells = <1>;
> +            reg = <0x0 0x9680 0x0 0x34>;
> +            interrupts = <GIC_SPI 73 IRQ_TYPE_EDGE_RISING>;
> +            clocks = <&xtal>, <&clkc CLKID_SAR_ADC>;
> +            clock-names = "clkin", "core";
> +            nvmem-cells = <&tsens_caldata>;
> +            nvmem-cell-names = "temperature_calib";
> +            amlogic,hhi-sysctrl = <&hhi>;
> +        };
> +    };
> +...
> -- 
> 2.28.0
> 



[Index of Archives]     [Device Tree Compilter]     [Device Tree Spec]     [Linux Driver Backports]     [Video for Linux]     [Linux USB Devel]     [Linux PCI Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Yosemite Backpacking]


  Powered by Linux