drm/i915/dp_mst: Work around Thunderbolt sink disconnect after SINK_COUNT_ESI read
authorImre Deak <imre.deak@intel.com>
Mon, 19 May 2025 13:34:17 +0000 (16:34 +0300)
committerImre Deak <imre.deak@intel.com>
Tue, 20 May 2025 08:20:17 +0000 (11:20 +0300)
commitc3a48363cf1f76147088b1adb518136ac5df86a0
tree67501fc5df382ddfeb88341d6ff82f1633d1a4aa
parent99354ec6409f716488887fc8094a1e63b7d35af3
drm/i915/dp_mst: Work around Thunderbolt sink disconnect after SINK_COUNT_ESI read

Due to a problem in the iTBT DP-in adapter's firmware the sink on a TBT
link may get disconnected inadvertently if the SINK_COUNT_ESI and the
DP_LINK_SERVICE_IRQ_VECTOR_ESI0 registers are read in a single AUX
transaction. Work around the issue by reading these registers in
separate transactions.

The issue affects MTL+ platforms and will be fixed in the DP-in adapter
firmware, however releasing that firmware fix may take some time and is
not guaranteed to be available for all systems. Based on this apply the
workaround on affected platforms.

See HSD #13013007775.

v2: Cc'ing Mika Westerberg.

Closes: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/13760
Closes: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/14147
Cc: Mika Westerberg <mika.westerberg@linux.intel.com>
Cc: stable@vger.kernel.org
Reviewed-by: Mika Westerberg <mika.westerberg@linux.intel.com>
Signed-off-by: Imre Deak <imre.deak@intel.com>
Link: https://lore.kernel.org/r/20250519133417.1469181-1-imre.deak@intel.com
drivers/gpu/drm/i915/display/intel_dp.c