Re: usb typec not doing handling in-kernel

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

On Tue, Aug 14, 2018 at 03:58:31PM +0200, Heiko Stuebner wrote:
> Am Montag, 13. August 2018, 15:36:37 CEST schrieb Heikki Krogerus:
> > On Mon, Aug 13, 2018 at 12:36:55PM +0200, Heiko Stuebner wrote:
> > > I'm currently trying to wrap my head around the new typec subsystem and
> > > also how to do it correctly on Rockchip rk3399 devices.
> > > 
> > > The issue (and Guenter might know quite a bit about that) is that on
> > > ChromeOS devices the embedded controller hides the whole tcpm/vdm
> > > logic from the operating system and just provides a custom interface to
> > > query things like cable state, display-port hotplug status and so on.
> > > 
> > > So right now the rk3399-typec-phy uses that extcon-based interface to
> > > get all status changes but that of course leaves out all systems directly
> > > talking to a fusb302. I did a small drawing to showcase that:
> > > 
> > > -------------    ------------------
> > > | typec-phy |----| extcon-cros-ec |\
> > > -------------    ------------------ \
> > >      |        \                      \
> > > -------------  \ ------------------   \ -----------
> > > |  cdn-dp   |   \|     ?????      |-----| fusb302 |
> > > -------------    ------------------     -----------
> > > 
> > > So to bring everything on the same page, I guess the cros-ec extcon
> > > (drivers/extcon/extcon-usbc-cros-ec.c) should somehow use the typec
> > > functions instead of implementing an extcon?
> > 
> > I don't think the two necessary exclude each other. You can continue
> > to register the extcon device and use it for communication with the
> > phy driver, and also register your Type-C port(s), partners, and
> > optionally the port and partner alternate modes. I guess Guenter has
> > patches for that already?
> 
> The issue is less with the working ChromeOS devices :-) .
> 
> What I'm trying to fit in there are all the other boards directly talking
> to a fusb302 via i2c and needing to do all these negotiations.

Ah, OK. Now I get it.

> So the rockchip typec phy would need to handle both cases. In the Rockchip
> vendor kernel they bolted the extcon export onto their fusb302 driver
> but I don't think that is really future proof ;-) .
> 
> Hence the easiest way would probably be to have everything use the newer
> typec APIs and not try to make the Rockchip typec-phy handle both cases.
> 
> 
> And looking at Guenters mail, it seems like he had the same idea as well
> in the past, so I'll hope for his archeology-skills :-) .
> 
> 
> > It looks to me like that phy driver could just register a Type-C
> > switch for the orientation, and mux for the mode. Those seem to be the
> > only details the driver needs from extcon-usbc-cros-ec.
> 
> Looks like it - I'm still trying to find my way through the typec subsystem
> though.
> 
> > > But from reading into the typec code, it somehow looks like the
> > > typec framework expects to be in control of things like altmode
> > > negotiations, or am I misreading something?
> > 
> > The alternate mode drivers will assume they are in control of the
> > negotiation with the partner, but note that you will not always need
> > them. The rest of the code in the framework doesn't expect to be in
> > control of the communication.
> > 
> > If the EC (or some other microcontroller) firmware is taking care of
> > the actual entering and configuring of the alternate modes, the port
> > driver (so extcon-usbc-cros-ec in your case) will need to "emulate"
> > the VDM communication if the alt mode drivers need to be used, and
> > that means they need to do so with every supported alternate mode
> > separately.
> > 
> > Of course if the details that for example the DisplayPort alt mode
> > driver supplies to the user space is not relevant on your system, and
> > there is no requirement to allow the user to be able to reconfigure
> > the DisplayPort alt mode (note: you will also be unable to exit the
> > mode from sysfs in this case), you can still register the partner alt
> > mode device and simply allow the binding to the driver fail, or don't
> > register the partner alt modes with the USB Type-C framework at all.
> 
> As said above, I'm mainly trying to make the typec framework usable
> for all the rk3399 boards using the "standard" setup of talking directly
> to the fusb302 but of course want to pull the cros-ec special case along,
> to not create to much overhead anywhere.
> 
> Thankfully it is really only the DisplayPort Alt Mode that is supported
> on the rk3399.
> 
> While the extcon driver doesn't seem to use it right now, looking through
> the ec-commands shows that muxes, roles etc seem configurable from the
> host side.
> 
> 
> > I've prepared patches for the ucsi driver that add displayport alt
> > mode support to it. UCSI is just a standardised firmware interface for
> > USB Type-C conncetors, so the situation is exactly the same as with
> > extcon-usbc-cros-ec. I was planning to send the patches out for review
> > after next -rc1, but I guess I could send a RFC already. With UCSI we
> > do have a requirement to allow the user to reconfigure the DisplayPort
> > alternate mode if needed.
> 
> That might be helpful. But you don't really have to hurry that much.
> -rc1 isn't that far away and I do have enough individual projects to
> keep me busy ;-) .
> 
> Especially also as the device_connection stuff does seem to still
> miss graph-parsing [0] to connect my dt-stuff together, there
> is no really hurry.

True, the graph parsing is indeed missing from that API. I'll see if I
can propose something for that at one point (soon hopefully).


Cheers,

-- 
heikki



[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux