From: Rob Herring <robh@kernel.org>
To: Jonathan Cameron <jic23@kernel.org>
Cc: linux-iio@vger.kernel.org, devicetree@vger.kernel.org,
Jonathan Cameron <Jonathan.Cameron@huawei.com>,
Martin Blumenstingl <martin.blumenstingl@googlemail.com>,
Kevin Hilman <khilman@baylibre.com>,
Neil Armstrong <narmstrong@baylibre.com>,
Jerome Brunet <jbrunet@baylibre.com>
Subject: Re: [PATCH v2 18/20] dt-bindings:iio:adc:amlogic,meson-saradc yaml conversion
Date: Tue, 15 Sep 2020 13:23:51 -0600 [thread overview]
Message-ID: <20200915192351.GA2341834@bogus> (raw)
In-Reply-To: <20200909175946.395313-19-jic23@kernel.org>
On Wed, Sep 09, 2020 at 06:59:44PM +0100, Jonathan Cameron wrote:
> From: Jonathan Cameron <Jonathan.Cameron@huawei.com>
>
> 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@huawei.com>
> Cc: Martin Blumenstingl <martin.blumenstingl@googlemail.com>
> Cc: Kevin Hilman <khilman@baylibre.com>
> Cc: Neil Armstrong <narmstrong@baylibre.com>
> Cc: Jerome Brunet <jbrunet@baylibre.com>
> ---
> .../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@googlemail.com>
> +
> +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
>
next prev parent reply other threads:[~2020-09-15 19:25 UTC|newest]
Thread overview: 74+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-09-09 17:59 [PATCH v2 00/20] dt-bindings:iio:adc: Another set of yaml conversions Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 01/20] dt-bindings:iio:adc:fsl,vf610-adc conversion to yaml Jonathan Cameron
2020-09-15 19:00 ` Rob Herring
2020-09-15 20:45 ` Rob Herring
2020-09-16 10:34 ` Jonathan Cameron
2020-09-17 2:24 ` Andy Duan
2020-09-19 13:33 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 02/20] dt-bindings:iio:adc:ti,twl4030-madc yaml conversion Jonathan Cameron
2020-09-15 19:01 ` Rob Herring
2020-09-19 13:42 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 03/20] dt-bindings:iio:adc:st,stmpe-adc " Jonathan Cameron
2020-09-15 19:02 ` Rob Herring
2020-09-19 13:44 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 04/20] dt-bindings:iio:adc: aspeed,ast2400 " Jonathan Cameron
2020-09-10 2:32 ` Joel Stanley
2020-09-16 10:36 ` Jonathan Cameron
2020-09-16 12:39 ` Joel Stanley
2020-09-16 14:17 ` Jonathan Cameron
2020-09-19 13:47 ` Jonathan Cameron
2020-09-19 13:52 ` Jonathan Cameron
2020-09-15 19:03 ` Rob Herring
2020-09-09 17:59 ` [PATCH v2 05/20] dt-bindings:iio:adc:marvell,berlin2-adc " Jonathan Cameron
2020-09-15 19:04 ` Rob Herring
2020-09-19 13:55 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 06/20] dt-bindings:iio:adc:sprd,sc2720-adc " Jonathan Cameron
2020-09-15 19:05 ` Rob Herring
2020-09-19 13:57 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 07/20] dt-bindings:iio:adc:nuvoton,nau7802 " Jonathan Cameron
2020-09-09 19:19 ` Alexandre Belloni
2020-09-10 7:57 ` Jonathan Cameron
2020-09-15 19:06 ` Rob Herring
2020-09-19 14:01 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 08/20] dt-bindings:iio:adc:nuvoton,npcm750-adc " Jonathan Cameron
2020-09-15 19:07 ` Rob Herring
2020-09-19 14:03 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 09/20] dt-bindings:iio:adc:nxp,lpc1850-adc " Jonathan Cameron
2020-09-15 19:07 ` Rob Herring
2020-09-19 14:20 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 10/20] dt-bindings:iio:adc:lpc3220-adc " Jonathan Cameron
2020-09-15 19:09 ` Rob Herring
2020-09-19 14:22 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 11/20] dt-bindings:iio:adc:motorola,cpcap-adc " Jonathan Cameron
2020-09-15 19:11 ` Rob Herring
2020-09-19 14:25 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 12/20] dt-bindings:iio:adc:dlg,da9150-gpadc " Jonathan Cameron
2020-09-15 19:12 ` Rob Herring
2020-09-19 14:57 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 13/20] dt-bindings:iio:adc:cosmic,10001-adc " Jonathan Cameron
2020-09-15 19:13 ` Rob Herring
2020-09-19 14:07 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 14/20] dt-bindings:iio:adc:adi,ad7949 " Jonathan Cameron
2020-09-15 19:13 ` Rob Herring
2020-09-19 14:59 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 15/20] dt-bindings:iio:adc:ad7768-1 " Jonathan Cameron
2020-09-15 19:15 ` Rob Herring
2020-09-19 15:01 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 16/20] dt-bindings:iio:adc:ti,ads1015 " Jonathan Cameron
2020-09-15 19:16 ` Rob Herring
2020-09-19 14:12 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 17/20] dt-bindings:iio:adc:holt,hi8435 " Jonathan Cameron
2020-09-15 19:17 ` Rob Herring
2020-09-19 15:03 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 18/20] dt-bindings:iio:adc:amlogic,meson-saradc " Jonathan Cameron
2020-09-15 19:23 ` Rob Herring [this message]
2020-09-15 19:31 ` Martin Blumenstingl
2020-09-09 17:59 ` [PATCH v2 19/20] dt-bindings:iio:adc:fsl,imx7d-adc " Jonathan Cameron
2020-09-15 19:24 ` Rob Herring
2020-09-16 10:27 ` Jonathan Cameron
2020-09-19 14:14 ` Jonathan Cameron
2020-09-09 17:59 ` [PATCH v2 20/20] dt-bindings:iio:adc:fsl,imx25-gcq " Jonathan Cameron
2020-09-15 19:26 ` Rob Herring
2020-09-16 10:33 ` Jonathan Cameron
2020-09-16 10:38 ` Jonathan Cameron
2020-09-19 14:19 ` Jonathan Cameron
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=20200915192351.GA2341834@bogus \
--to=robh@kernel.org \
--cc=Jonathan.Cameron@huawei.com \
--cc=devicetree@vger.kernel.org \
--cc=jbrunet@baylibre.com \
--cc=jic23@kernel.org \
--cc=khilman@baylibre.com \
--cc=linux-iio@vger.kernel.org \
--cc=martin.blumenstingl@googlemail.com \
--cc=narmstrong@baylibre.com \
/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).