Skip to content
Snippets Groups Projects
Commit bf9d3f5e authored by Lyude Paul's avatar Lyude Paul
Browse files

WIP: drm/dp_mst: Drop all ports from topology on CSNs before queueing link address work


TODO: Finish writing commit message by adding refs

We want to start cutting down on all of the places that we use port
validation, so that ports may be removed from the topology as quickly as
possible to minimize the number of errors we run into as a result of being
out of sync with the current topology status. Let's do this with CSNs by
moving some code around so that we only queue link address probing work at
the end of handling all CSNs - allowing us to make sure we drop as many
topology references as we can beforehand.

This is also intended to replace the workaround that was added fix to some
of the payload leaks that were observed before $COMMIT, where we would
attempt to determine if the port was still connected to the topology before
updating payloads using drm_dp_mst_port_downstream_of_branch. This wasn't a
particularly good solution, since one of the points of still having port
and mstb validation is to avoid sending messages to newly disconnected
branches wherever possible - thus the required use of
drm_dp_mst_port_downstream_of_branch would indicate something may be wrong
with said validation.

It seems like it may have just been races and luck that made
drm_dp_mst_port_downstream_of_branch work however, as while I was trying to
figure out the true cause of this issue when removing the legacy MST code -
I discovered an important excerpt in section 2.14.2.3.3.6 of the DP 2.0
specs:

"BAD_PARAM - This reply is transmitted when a Message Transaction parameter
is in error; for example, the next port number is invalid or /no device is
connected/ to the port associated with the port number."

Sure enough - removing the calls to drm_dp_mst_port_downstream_of_branch()
and instead checking the ->ddps field of the parent port to see whether we
should release a given payload or not seems to totally fix the issue. This
does actually make sense to me, as it seems the implication is that given a
topology where an MSTB is removed, the payload for the MST parent's port
will be released automatically if that port is also marked as disconnected.
However, if there's another parent in the chain after that which is
connected - payloads must be released there with an ALLOCATE_PAYLOAD
message.

Signed-off-by: Lyude Paul's avatarLyude Paul <lyude@redhat.com>
parent 2cb5384f
No related branches found
No related tags found
Loading
Loading
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment