[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <Pine.LNX.4.44L0.1802221325220.1295-100000@iolanthe.rowland.org>
Date: Thu, 22 Feb 2018 13:27:54 -0500 (EST)
From: Alan Stern <stern@...land.harvard.edu>
To: Amelie DELAUNAY <amelie.delaunay@...com>
cc: Roger Quadros <rogerq@...com>,
Greg Kroah-Hartman <gregkh@...uxfoundation.org>,
Rob Herring <robh+dt@...nel.org>,
Mark Rutland <mark.rutland@....com>,
Tony Prisk <linux@...sktech.co.nz>,
"linux-usb@...r.kernel.org" <linux-usb@...r.kernel.org>,
"devicetree@...r.kernel.org" <devicetree@...r.kernel.org>,
"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>,
"linux-arm-kernel@...ts.infradead.org"
<linux-arm-kernel@...ts.infradead.org>
Subject: Re: [PATCH v2] usb: host: ehci-platform: add support for optional
external vbus supply
On Thu, 22 Feb 2018, Amelie DELAUNAY wrote:
> >>>>> --- a/Documentation/devicetree/bindings/usb/usb-ehci.txt
> >>>>> +++ b/Documentation/devicetree/bindings/usb/usb-ehci.txt
> >>>>> @@ -19,6 +19,7 @@ Optional properties:
> >>>>> - phys : phandle + phy specifier pair
> >>>>> - phy-names : "usb"
> >>>>> - resets : phandle + reset specifier pair
> >>>>> + - vbus-supply : phandle of regulator supplying vbus
> >>>>>
> >>>>
> >>>> Can platforms have more than one regulator e.g. one regulator per port?
> >>>>
> >>>
> >>> I imagine that yes, platforms could have one regulator per port.
> >>> Regulator consumers bindings impose a <name>-supply property per
> >>> regulator, so, what do you think about :
> >>> vbus0-supply for port#0
> >>> vbus1-supply for port#1
> >>> ...
> >>> vbusN-supply for port#N
> >>>
> >>> And then in probe, allocate 'struct regulator *vbus_supplies' with a
> >>> size corresponding to 'HCS_N_PORTS(ehci->hcs_params) * sizeof(struct
> >>> regulator *)'.
> >>> And loop to get optional regulator vbus0, vbus1,..., vbusN.
> >>> And then enable/disable the corresponding regulator in
> >>> ehci_platform_port_power thanks to portnum.
> >>
> >> Looks fine to me but we need to get Alan's opinion if this is worth the effort.
> >> If there isn't a single platform needing it we could probably do without it
> >> but the DT binding must be scalable to add this feature in the future.
> >
> > I agree that for now there don't seem to be any platforms requiring
> > more than one regulator, but this should be implemented in a way that
> > could be expanded if necessary.
> >
> > Anyway, the basic idea is reasonable. I don't know to what extent
> > people want to power-off their EHCI ports, but if they do then we ought
> > to turn off external regulators at the same time.
> >
> > Is there a real-life use case for this?
> >
> > Alan Stern
> >
>
> On my setup I have the following:
>
> regulator_____vbus
> _________________ \
> | EHCI controller |-port0-----[USB connector]
> |_________________|-port1-----X
>
> So, I have one regulator only for port0. But I could I have one more if
> port1 was connected. My current regulator could also supplies port1.
>
> To allocate a vbus_supplies array depending on N_PORTS, I have to move
> this initialization from probe to ehci_platform_reset, after ehci_setup
> is done.
> Then, I have to define each regulator id depending on the port number.
> This imposes a binding like
> - portN_vbus-supply : phandle of regulator supplying vbus for port N
> But I don't know if we can describe it like this in dt-bindings ?
>
> &ehci {
> ...
> port0_vbus-supply = <&vbus_reg>;
> port1_vbus-supply = <&vbus_reg>; //Could be another regulator, or not
> specified if port is not connected.
> ...
> };
>
> Is it ok to move vbus_supplies initialization in ehci_platform_reset ?
Yes, it's okay to move the code if you need to.
However, I can not speak on the DT implications. Someone who knows
more about it should chime in.
Alan Stern
Powered by blists - more mailing lists