Re: [PATCH 1/6] dt-bindings: usb: dwc3: Clean up hs_phy_irq in bindings

From: Johan Hovold
Date: Fri Nov 24 2023 - 08:45:47 EST


On Fri, Nov 24, 2023 at 05:32:37PM +0530, Krishna Kurapati PSSNV wrote:
> >
> > Thanks for sorting this out.
> >
> > It seems like we have a few combinations of these interrupts and we
> > should probably try to define the order for these once and for all and
> > update the current devicetrees to match (even if it means adding new
> > interrupts in the middle).
> >
> > Instead of adding separate compatibles for the controllers without SS
> > support, I suggest keeping that interrupt last as an optional one.
> >
> > But IIUC we essentially have something like:
> >
> > qusb2-:
> >
> > - const: qusb2_phy
> > - const: pwr_event
> > - const: ss_phy_irq (optional)
> >
> > qusb2:
> >
> > - const: hs_phy_irq
> > - const: qusb2_phy
> > - const: pwr_event
> > - const: ss_phy_irq (optional)
> >
> > qusb2+:
> >
> > - const: hs_phy_irq
> > - const: qusb2_phy
> > - const: dp_hs_phy_irq
> > - const: dm_hs_phy_irq
> > - const: pwr_event
> > - const: ss_phy_irq (optional)
> >
>
> This combination doesn't exist. So we can skip this one.

Ok, good. I thought you said some QUSB2 platforms used DP/DM, but I guess
that means they don't have the qusb2_phy interrupt then.

> > femto-:
> > - const: dp_hs_phy_irq
> > - const: dm_hs_phy_irq
> > - const: pwr_event
> > - const: ss_phy_irq (optional)
> >
> > femto:
> > - const: hs_phy_irq
> > - const: dp_hs_phy_irq
> > - const: dm_hs_phy_irq
> > - const: pwr_event
> > - const: ss_phy_irq (optional)
> >
> > Does this look like it would cover all of our currents SoCs?
> >
> > Do all of them have the pwr_event interrupt?
>
> Yes. From whatever targets I was able to find, only one of them didn't
> have the power_event irq. Rest all of them had. I will recheck that
> particular one again.

Please do. The driver polls the corresponding status register on all
platforms currently, and perhaps this interrupt can one day be used to
get rid of the polling.

> > Note that DP comes before DM above as that seems like the natural order
> > of these (plus before minus).
> >
> > Now if the HS interrupt is truly unusable, I guess we can consider
> > dropping it throughout and the above becomes just three permutations
> > instead, which can even be expressed along the lines of:
>
> Infact, I wanted to do this but since you mentioned before that if HW
> has it, we must describe it, I kept it in. But since this functionality
> is confirmed to be mutually exclusive of qusb2/{dp/dm}, I am aligned to
> skip it in bindings and drop it in DT.

As I mentioned elsewhere, it depends on whether it can be used at all.
Not simply whether there is some other mechanism that can be used in its
stead. Such a decision should be left up to the implementation.

That's why I said "truly unusable" above. It's still not clear to me
whether that is the case or not.

> > - anyOf:
> > - items:
> > - const: qusb2_phy
> > - items:
> > - const: dp_hs_phy_irq
> > - const: dm_hs_phy_irq
> > - const: pwr_event
> > - const: ss_phy_irq (optional)
> >
>
> This must cover all cases AFAIK. How about we keep pwr_event also
> optional for time being. The ones I am not able to find also would come
> up under still binding block.

No, we should avoid that if we can as with two many optional things,
these quickly gets messy (one optional interrupt at the end is fine and
can be expressed using min/maxItems).

If the "qusb2+" combination above isn't needed, then we're down to four
permutations, which is few enough to be spelled out explicitly even if
we decide that the hs_phy_irq should be kept in. Without hs_phy_irq, it
seems there's really only two permutations.

Johan