Devicetree
 help / color / mirror / Atom feed
From: Jonathan Cameron <jic23@kernel.org>
To: Conor Dooley <conor@kernel.org>
Cc: "Janani Sunil" <janani.sunil@analog.com>,
	"Lars-Peter Clausen" <lars@metafoo.de>,
	"Michael Hennerich" <Michael.Hennerich@analog.com>,
	"David Lechner" <dlechner@baylibre.com>,
	"Nuno Sá" <nuno.sa@analog.com>,
	"Andy Shevchenko" <andy@kernel.org>,
	"Rob Herring" <robh@kernel.org>,
	"Krzysztof Kozlowski" <krzk+dt@kernel.org>,
	"Conor Dooley" <conor+dt@kernel.org>,
	"Philipp Zabel" <p.zabel@pengutronix.de>,
	"Jonathan Corbet" <corbet@lwn.net>,
	"Shuah Khan" <skhan@linuxfoundation.org>,
	"Mark Brown" <broonie@kernel.org>,
	linux-iio@vger.kernel.org, devicetree@vger.kernel.org,
	linux-kernel@vger.kernel.org, linux-doc@vger.kernel.org,
	"Janani Sunil" <jan.sun97@gmail.com>,
	linux-spi@vger.kernel.org
Subject: Re: [PATCH v5 1/3] dt-bindings: spi: Add spi,device-addr peripheral property
Date: Wed, 1 Jul 2026 19:29:15 +0100	[thread overview]
Message-ID: <20260701192915.2fca6b06@jic23-huawei> (raw)
In-Reply-To: <20260701-immodest-carrot-611d255656b5@spud>

On Wed, 1 Jul 2026 12:04:37 +0100
Conor Dooley <conor@kernel.org> wrote:

> On Wed, Jul 01, 2026 at 08:40:39AM +0200, Janani Sunil wrote:
> > Some SPI devices support sharing a single chip select across multiple
> > physical chips by encoding a device address in the SPI frame itself.
> > Add a generic spi,device-addr property to document this per-peripheral
> > address. This property belongs in channel or sub-device nodes of
> > peripherals that use this addressing scheme.
> > 
> > Signed-off-by: Janani Sunil <janani.sunil@analog.com>
> > ---
> >  Documentation/devicetree/bindings/spi/spi-peripheral-props.yaml | 5 +++++
> >  1 file changed, 5 insertions(+)
> > 
> > diff --git a/Documentation/devicetree/bindings/spi/spi-peripheral-props.yaml b/Documentation/devicetree/bindings/spi/spi-peripheral-props.yaml
> > index 880a9f624566..3774e8018355 100644
> > --- a/Documentation/devicetree/bindings/spi/spi-peripheral-props.yaml
> > +++ b/Documentation/devicetree/bindings/spi/spi-peripheral-props.yaml
> > @@ -142,6 +142,11 @@ properties:
> >      minItems: 2
> >      maxItems: 4
> >  
> > +  spi,device-addr:  
> 
> To match other generic spi properties, s/,/-/.
> 
> However, you don't actually use this as a spi peripheral's property in
> your device binding, so you've got your wires crossed here somewhere.

If we are going to make this generic (which I'm not against) I think
it should also work for the case of multiple independent devices.
So it can also be a top level device node spi property.

That kind of makes me wonder if we are better off having it always
in the top level node, but allowing multiple values to represent
sub devices under this.  That would leave figuring out mappings of which
channels are on which device to the driver. The driver must know the
mapping afterall.  For the example something like


#include <dt-bindings/gpio/gpio.h>
spi {
    #address-cells = <1>;
    #size-cells = <0>;
    dac@0 {
        compatible = "adi,ad5529r-16";
        reg = <0>;
        spi-max-frequency = <25000000>;

        spi-device-addreses = <0 3>
...

        #address-cells = <1>;
        #size-cells = <0>;

        channel@0 {
            reg = <0>;
            adi,output-range-microvolt = <0 5000000>;
        };

        channel@16 { #on second device using dev addr 3
            reg = <16>;
            adi,output-range-microvolt = <(-10000000) 10000000>;
        };
        channel@18 { #3rd channel on device using dev addr 3
            reg = <18>;
            adi,output-range-microvolt = <0 40000000>;
        };
    };
};

Where devices are truely independent then you would have separate device
nodes each with one entry in spi-device-addresses

I'm a bit dubious about putting this in the spi namespace though given
it is not part of any standard specification.  Do we have any precedence
for that sort of thing?

Jonathan

> 
> If it's a generic dac channel property (as you use it) it should be in
> dac.yaml (or adc.yaml for the other device that I asked you to add it
> for as proof of being generic), or it is a spi peripheral property and
> needs to go into the dac node itself.
> 
> pw-bot: changes-requested
> 
> > +    $ref: /schemas/types.yaml#/definitions/uint32
> > +    description:
> > +      Device address used when multiple peripherals share a single chip select.
> > +
> >    st,spi-midi-ns:
> >      deprecated: true
> >      description: |
> > 
> > -- 
> > 2.43.0
> >   


  reply	other threads:[~2026-07-01 18:29 UTC|newest]

Thread overview: 15+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-07-01  6:40 [PATCH v5 0/3] iio: dac: Add support for AD5529R DAC Janani Sunil
2026-07-01  6:40 ` [PATCH v5 1/3] dt-bindings: spi: Add spi,device-addr peripheral property Janani Sunil
2026-07-01  6:52   ` sashiko-bot
2026-07-01 11:04   ` Conor Dooley
2026-07-01 18:29     ` Jonathan Cameron [this message]
2026-07-01 18:48       ` David Lechner
2026-07-01 20:31         ` Conor Dooley
2026-07-01  6:40 ` [PATCH v5 2/3] dt-bindings: iio: dac: Add AD5529R Janani Sunil
2026-07-01  6:52   ` sashiko-bot
2026-07-01 11:07   ` Conor Dooley
2026-07-01 18:41   ` Jonathan Cameron
2026-07-01  6:40 ` [PATCH v5 3/3] iio: dac: Add AD5529R DAC driver support Janani Sunil
2026-07-01  6:52   ` sashiko-bot
2026-07-01  9:17   ` Andy Shevchenko
2026-07-01 18:55   ` 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=20260701192915.2fca6b06@jic23-huawei \
    --to=jic23@kernel.org \
    --cc=Michael.Hennerich@analog.com \
    --cc=andy@kernel.org \
    --cc=broonie@kernel.org \
    --cc=conor+dt@kernel.org \
    --cc=conor@kernel.org \
    --cc=corbet@lwn.net \
    --cc=devicetree@vger.kernel.org \
    --cc=dlechner@baylibre.com \
    --cc=jan.sun97@gmail.com \
    --cc=janani.sunil@analog.com \
    --cc=krzk+dt@kernel.org \
    --cc=lars@metafoo.de \
    --cc=linux-doc@vger.kernel.org \
    --cc=linux-iio@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-spi@vger.kernel.org \
    --cc=nuno.sa@analog.com \
    --cc=p.zabel@pengutronix.de \
    --cc=robh@kernel.org \
    --cc=skhan@linuxfoundation.org \
    /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