From: Herve Codina <herve.codina@bootlin.com>
To: David Gibson <david@gibson.dropbear.id.au>
Cc: Geert Uytterhoeven <geert@linux-m68k.org>,
Ayush Singh <ayush@beagleboard.org>,
Krzysztof Kozlowski <krzk@kernel.org>,
Rob Herring <robh@kernel.org>, Andrew Davis <afd@ti.com>,
Wolfram Sang <wsa+renesas@sang-engineering.com>,
Luca Ceresoli <luca.ceresoli@bootlin.com>,
devicetree@vger.kernel.org, Jason Kridner <jkridner@gmail.com>,
Krzysztof Kozlowski <krzk+dt@kernel.org>,
Conor Dooley <conor+dt@kernel.org>,
devicetree-compiler@vger.kernel.org,
linux-kernel@vger.kernel.org,
Thomas Petazzoni <thomas.petazzoni@bootlin.com>
Subject: Re: Device tree representation of (hotplug) connectors: discussion at ELCE
Date: Fri, 10 Oct 2025 18:31:52 +0200 [thread overview]
Message-ID: <20251010183152.1530f5ab@bootlin.com> (raw)
In-Reply-To: <aOi8oLGYVckesJSb@zatzit>
On Fri, 10 Oct 2025 18:58:24 +1100
David Gibson <david@gibson.dropbear.id.au> wrote:
> On Tue, Sep 30, 2025 at 09:52:44AM +0200, Geert Uytterhoeven wrote:
> > Hi David,
> >
> > On Tue, 30 Sept 2025 at 06:34, David Gibson <david@gibson.dropbear.id.au> wrote:
> > > On Wed, Sep 24, 2025 at 10:33:50PM +0530, Ayush Singh wrote:
> > > > On 9/24/25 09:41, David Gibson wrote:
> [snip]
> > > > > > > > a) Addons can only add completely new nodes, never modify existing
> > > > > > > > ones. This means that whatever addons are present at runtime,
> > > > > > > > every node has a single well defined owner (either base board or
> > > > > > > > addon).
> > > > > > > In this rule I suppose that "never modify existing ones" should be understood
> > > > > > > as "never modify, add or remove properties in existing ones". Because, of course
> > > > > > > adding a full node in a existing one is allowed (rule b).
> > > > > > What if the add-on board contains a provider for the base board.
> > > > > > E.g. the connector has a clock input, fed by an optional clock generator
> > > > > > on the add-on board. Hooking that into the system requires modifying
> > > > > > a clocks property in the base board, cfr. [1].
> > > > > > Or is there some other solution?
> > > > > Hmm. My first inclination would be that this case is not in scope for
> > > > > the protocol we're trying to design now. If the widget provides
> > > > > things to the base board as well as the other way around, it's no
> > > > > longer an "addon" for the purposes of this spec.
> > > > >
> > > > > But it's possible I've underestimated how common / useful such a case
> > > > > is.
> > > > >
> > > > > Note that I'd expect the existing overlay mechanism to still be
> > > > > around. It may be ugly and not very well thought out, but its
> > > > > drawbacks are much less severe if you're not dealing with hot unplug.
> > > >
> > > > Well, while that was not an initial use-case in my mind, external clock
> > > > inputs are a valid use-case when talking about connectors for board headers
> > > > specifically (e.g. pocketbeagle connector).
> > >
> > > I guess I'm not familiar enough with modern embedded hardware. I'm
> > > having a hard time wrapping my head around what's going on here. If
> > > the external clock input is optional (hence under a connector), how is
> > > anything on the base board dependent on it? If nothing on the base
> > > board is dependent, why do we need to modify its properties to
> > > represent it?
> > >
> > > Is this a design flaw in the clocks binding?
> >
> > In my example, the external clock input is indeed optional, and not
> > used by the base board itself. Still, it is a clock input to the SoC,
> > and may be used as a reference clock when an add-on board is connected
> > that needs to use the exact clock frequency of that reference clock.
> >
> > https://elixir.bootlin.com/linux/v6.17/source/arch/arm64/boot/dts/renesas/white-hawk-ard-audio-da7212.dtso
> > AUDIO_CLKIN_V is the optional clock input to the SoC.
> > GP1_25/SL_SW2_V/TPU is the reference clock (actually it is not
> > generated on the add-on board, but by a PWM controller on the base
> > board, but it could just be a crystal oscillator on the add-on board
> > instead)
> >
> > I hope this makes it clearer.
>
> I think so.
>
> IIUC, the problem is that while both the producer and the consumer of
> the clock are addons, it's routed through the SoC, which is why it
> requires some representation there.
>
> What seems like the logical approach to me is for the base board to
> have essentially an unresolved pointer to the clock input. I'm not
> really sure how that could be sensibly encoded, though.
>
I don't think that having unresolved symbols in the base DT is the right
direction. This base DT is used and so all symbols have to be resolved.
If any symbols are not resolved (either in addon DT or base DT), this DT
should not be used. For the base DT, "not used" means no boot.
Do we really want to support DT used in runtime with some "invalid" parts ?
IMHO, if the base DT need a resource wired at the connector and provided by
the addon, the base DT need to reference the connector. From the base DT
point of view, the consumed resource is the one provided at the connector.
if a clock is wired at the connector the connector can be seen as a clock
controller. This clock controller should be a kind of "bridge" between the
base DT clock consumer and the addon board provider and it should perform
the link without having any unresolved symbols in the base DT side.
Best regards,
Hervé
next prev parent reply other threads:[~2025-10-10 16:32 UTC|newest]
Thread overview: 50+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-09-02 8:57 Device tree representation of (hotplug) connectors: discussion at ELCE Luca Ceresoli
2025-09-04 5:23 ` David Gibson
2025-09-04 5:45 ` Ayush Singh
2025-09-08 4:36 ` David Gibson
2025-09-08 9:01 ` Geert Uytterhoeven
2025-09-09 2:44 ` David Gibson
2025-09-08 12:51 ` Herve Codina
2025-09-09 5:09 ` David Gibson
2025-09-09 9:41 ` Herve Codina
2025-09-09 13:04 ` Geert Uytterhoeven
2025-09-10 4:36 ` David Gibson
2025-09-11 10:11 ` Herve Codina
2025-09-12 9:40 ` Luca Ceresoli
2025-09-10 4:33 ` David Gibson
2025-09-11 8:48 ` Herve Codina
2025-09-11 8:54 ` Geert Uytterhoeven
2025-09-11 10:23 ` Herve Codina
2025-09-11 12:15 ` Ayush Singh
2025-09-11 12:45 ` Herve Codina
2025-09-11 13:08 ` Geert Uytterhoeven
2025-09-11 13:58 ` Herve Codina
2025-09-15 4:51 ` David Gibson
2025-09-16 6:46 ` Herve Codina
2025-09-16 10:14 ` Geert Uytterhoeven
2025-09-16 12:22 ` Ayush Singh
2025-09-16 13:34 ` Geert Uytterhoeven
2025-09-16 14:25 ` Herve Codina
2025-09-16 15:35 ` Ayush Singh
2025-09-18 3:16 ` David Gibson
2025-09-18 7:44 ` Herve Codina
2025-09-18 8:06 ` Herve Codina
2025-09-19 4:52 ` David Gibson
2025-09-19 5:17 ` Ayush Singh
2025-09-19 15:20 ` Luca Ceresoli
2025-09-23 8:09 ` David Gibson
2025-09-23 9:48 ` Herve Codina
2025-09-23 10:29 ` Geert Uytterhoeven
2025-09-23 13:36 ` Herve Codina
2025-09-23 16:47 ` Andrew Davis
2025-09-24 4:17 ` David Gibson
2025-09-24 4:11 ` David Gibson
2025-09-24 17:03 ` Ayush Singh
2025-09-30 4:07 ` David Gibson
2025-09-30 7:52 ` Geert Uytterhoeven
2025-10-10 7:58 ` David Gibson
2025-10-10 16:31 ` Herve Codina [this message]
2025-09-24 3:54 ` David Gibson
2025-09-24 12:31 ` Herve Codina
2025-09-29 9:23 ` David Gibson
2025-09-30 7:09 ` Herve Codina
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=20251010183152.1530f5ab@bootlin.com \
--to=herve.codina@bootlin.com \
--cc=afd@ti.com \
--cc=ayush@beagleboard.org \
--cc=conor+dt@kernel.org \
--cc=david@gibson.dropbear.id.au \
--cc=devicetree-compiler@vger.kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=geert@linux-m68k.org \
--cc=jkridner@gmail.com \
--cc=krzk+dt@kernel.org \
--cc=krzk@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=luca.ceresoli@bootlin.com \
--cc=robh@kernel.org \
--cc=thomas.petazzoni@bootlin.com \
--cc=wsa+renesas@sang-engineering.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).