On 05/08/2025 09:13, Chaoyi Chen wrote:
Hi Dmitry,

On 8/2/2025 5:55 PM, Dmitry Baryshkov wrote:

[...]


Currently, the software simply selects the first available port. So if user plugs in DP dongles in both USB-C ports, the DP driver will select the first
port. This process is implemented in cdn_dp_connected_port() .

I think Stephen Boyd has been looking on similar issues for Chromebooks,
which were sharing DP controller between several USB-C ports. I don't
remember what was his last status. I think there it was easier since the
bifurcation point was the EC.

I think the latest progress should be here: [0]. It seems that it hasn't been updated for a while.

Might be :-(


[0]: https://lore.kernel.org/all/20240901040658.157425-1- swb...@chromium.org/



I think, CDN-DP needs to register up to two encoders and up to two
connectors, having a separate drm_bridge chain for each of the DP
signals paths (in the end, you can not guarantee that both branches will
have the same simple CDN-DP -> PHY -> USB-C configuration: there can be
different retimers, etc).

Both encoders should list the same CRTC in possible_crtcs, etc. Of
course, it should not be possible to enable both of them.

This way if the user plugs in two DP dongles, it would be possible to
select, which output actually gets a signal.

That makes sense, but this might make the DP driver quite complex. I will see if I can make it happen.

I think it's trading one burden for another, because CDN-DP currently has a complication of calling cdn_dp_get_port_lanes() / cdn_dp_enable_phy() in a loop rather than just enabling one instance.





BTW, one of the important things to do is to implement extcon-like
notifications. I found include/drm/bridge/aux-bridge.h , but if the
aux-bridge is used, the bridge chain would look like this:

PHY0 aux-bridge ---+
                     | ----> CDN-DP bridge
PHY1 aux-bridge ---+

Oh, CDN-DP bridge has two previous aux-bridge!

Now, I try to use drm_connector_oob_hotplug_event() to notify HPD
state between PHY and CDN-DP controller.
Does it actually work? The OOB HPD event will be repoted for the usb-c
connector's fwnode, but the DP controller isn't connected to that node
anyhow. If I'm not mistaken, the HPD signal will not reach DP driver in
this case.
Yes.  What you mentioned is the case in
drivers/usb/typec/altmodes/displayport.c . I have also added a new OOB event notify in the PHY driver in Patch 3, where the expected fwnode is used in the PHY. So now we have two OOB HPD events, one from altmodes/ displayport.c and the other from PHY. Only the HPD from PHY is eventually passed to the DP
driver.
This way you will loose IRQ_HPD pulse events from the DP. They are used
by DPRX (aka DP Sink) to signal to DPTX (DP Source) that there was a
change on the DPRX side and the DPTX should reread link params and maybe
retrain the link.

Sorry, I still don't quite understand your point. I think the entire notification path is as follows:

Type-C mux callback -> RK3399 USBDP PHY -> PHY calls drm_connector_oob_hotplug_event() -> DP driver

Are you concerned that the IRQ_HPD event is not being handled somewhere along the path? Is it that the Type-C mux callback didn't notify the PHY, or that after the PHY passed the event to the DP driver via the OOB event, the DP driver didn't handle it?

The IRQ_HPD is an event coming from DPRX, it is delivered as a part of the attention VDM, see DP_STATUS_IRQ_HPD. It's being handled by the altmode displayport.c driver and is then delivered as an OOB hotplug call. However, it's not a mux event, so it is not (and it should not) being broadcasted over the typec_mux devices.

The way we were handling that is by having a chain of drm_aux_bridges for all interim devices, ending up with a drm_dp_hpd_bridge registered by the TCPM. This way when the DPRX triggers the IRQ_HPD event, it is being handled by the displayport.c and then delivered through that bridge to the DP driver.

--
With best wishes
Dmitry

Reply via email to