On Thu, Sep 28, 2017 at 03:07:27PM +0200, Andrzej Hajda wrote: > These bindings allows to describe most known standard USB connectors > and it should be possible to extend it if necessary. > USB connectors, beside USB can be used to route other protocols, > for example UART, Audio, MHL. In such case every device passing data > through the connector should have appropriate graph bindings. Yay! > Signed-off-by: Andrzej Hajda <a.hajda@xxxxxxxxxxx> > --- > There are few things for discussion (IMO): > 1. vendor specific connectors, I have added them here, but maybe better is > to place them in separate files. I'd worry about the standard connectors first, but probably good to have an idea of how vendor connectors need to be extended. > 2. physical connector description - I have split it to three properties: > type(a,b,ab,c), max-mode(ls,fs,hs,ss,ss+), size(mini,micro,powered). > This tripled is able to describe all USB-standard connectors, but there > are also impossible combinations, for example(c, *, micro). Maybe better > would be to just enumerate all possible connectors in include file. We did "type" for hdmi-connector, but I think I'd really prefer compatible be used to distinguish as least where it may matter to s/w. In the HDMI case, they all are pretty much the same, just different physical size. > 3. Numbering of port/remote nodes, currently only 0 is assigned for Interface > Controller. Maybe other functions should be also assigned: > HS, SS, CC, SBU, ... whatever. Maybe functions should be described > as an additional property of remote node? child of the controller is also an option. There's already prec > ... > > Regards > Andrzej > --- > .../bindings/connector/usb-connector.txt | 49 ++++++++++++++++++++++ > 1 file changed, 49 insertions(+) > create mode 100644 Documentation/devicetree/bindings/connector/usb-connector.txt > > diff --git a/Documentation/devicetree/bindings/connector/usb-connector.txt b/Documentation/devicetree/bindings/connector/usb-connector.txt > new file mode 100644 > index 000000000000..f3a4e85122d5 > --- /dev/null > +++ b/Documentation/devicetree/bindings/connector/usb-connector.txt > @@ -0,0 +1,49 @@ > +USB Connector > +============= > + > +Required properties: > +- compatible: "usb-connector" > + connectors with vendor specific extensions can add one of additional > + compatibles: > + "samsung,usb-connector-11pin": 11-pin Samsung micro-USB connector > +- type: the USB connector type: "a", "b", "ab", "c" > +- max-mode: max USB speed mode supported by the connector: > + "ls", "fs", "hs", "ss", "ss+" Do we really see cases where the connector is slower than the controller? Plus things like "ls" with an type A connector are not valid. > + > +Optional properties: > +- label: a symbolic name for the connector > +- size: size of the connector, should be specified in case of > + non-standard USB connectors: "mini", "micro", "powered" What does powered mean? This is really "type" if you compare to HDMI. > + > +Required nodes: > +- any data bus to the connector should be modeled using the > + OF graph bindings specified in bindings/graph.txt. > + There should be exactly one port with at least one endpoint to > + different device nodes. The first endpoint (reg = <0>) should > + point to USB Interface Controller. > + > +Example > +------- > + > +musb_con: connector { > + compatible = "samsung,usb-connector-11pin", "usb-connector"; > + label = "usb"; > + type = "b"; > + size = "micro"; > + max-mode = "hs"; These all are implied by "samsung,usb-connector-11pin". > + > + port { > + #address-cells = <1>; > + #size-cells = <0>; > + > + musb_con_usb_in: endpoint@0 { > + reg = <0>; > + remote-endpoint = <&muic_usb_out>; > + }; > + > + musb_con_mhl_in: endpoint@1 { > + reg = <1>; > + remote-endpoint = <&mhl_out>; > + }; I think this should be 2 ports, not 2 endpoints. Think of ports as different data streams and endpoints are either the same data stream muxed or fanned out depending on direction. Now for Type-C, 1 port for USB and alternate modes is probably correct. Rob -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html