Re: Device tree representation of (hotplug) connectors: discussion at ELCE
From: David Gibson
Date: Fri Oct 10 2025 - 07:13:04 EST
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@xxxxxxxxxxxxxxxxxxxxx> 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.
--
David Gibson (he or they) | I'll have my music baroque, and my code
david AT gibson.dropbear.id.au | minimalist, thank you, not the other way
| around.
http://www.ozlabs.org/~dgibson
Attachment:
signature.asc
Description: PGP signature