On Thu, Oct 3, 2019 at 1:56 PM Hans de Goede <hdegoede@xxxxxxxxxx> wrote: > On 03-10-2019 22:45, John Stultz wrote: > > The HiKey960 has only one USB controller, but in order to support both > > USB-C gadget/OTG and USB-A (host only) ports. When the USB-C > > connection is attached, it powers down and disconnects the hub. When > > the USB-C connection is detached, it powers the hub on and connects > > the controller to the hub. > > When you say one controller, do you mean 1 host and 1 gadget controller, > or is this one of these lovely devices where a gadget controller gets > abused as / confused with a proper host controller? I'm not totally sure myself, but I believe it's the latter, as the host ports have to be disabled in order for the gadet/otg port to function. There was a similar situation w/ the original HiKey board (dwc2 controller) as well, though the switching was done fully in hardware and we only needed some minor tweaks to the driver to keep the state transitions straight. > And since you are doing a usb-role-switch driver, I guess that the > role-switch is integrated inside the SoC, so you only get one pair > of USB datalines to the outside ? I believe so, but again, I don't have a ton of knowledge about the SoC details, Chen Yu would probably be the right person to answer, but I don't know if he's doing upstreaming anymore. > This does seem rather special, it might help if you can provide a diagram > with both the relevant bits inside the SoC as well as what lives outside > the Soc. even if it is in ASCII art... There is a schematic pdf here: https://github.com/96boards/documentation/raw/master/consumer/hikey/hikey960/hardware-docs/HiKey960_Schematics.pdf The larger block diagram on page 3 might be helpful, but you can find more details on the usb hub bits on page 17 and 18. thanks -john