Commit 3fe95742 authored by Mika Westerberg's avatar Mika Westerberg

thunderbolt: Do not touch CL state configuration during discovery

If the boot firmware has already established tunnels, especially ones
that have special requirements from the link such as DisplayPort, we
should not blindly enable CL states (nor change the TMU configuration).
Otherwise the existing tunnels may not work as expected.

For this reason, skip the CL state enabling when we go over the existing
topology. This will also keep the TMU settings untouched because we do
not change the TMU configuration when CL states are not enabled.
Reported-by: default avatarKoba Ko <koba.ko@canonical.com>
Closes: https://gitlab.freedesktop.org/drm/intel/-/issues/7831
Cc: stable@vger.kernel.org # v6.0+
Acked-By: default avatarYehezkel Bernat <YehezkelShB@gmail.com>
Signed-off-by: default avatarMika Westerberg <mika.westerberg@linux.intel.com>
parent b6d572ae
...@@ -737,6 +737,7 @@ static void tb_scan_port(struct tb_port *port) ...@@ -737,6 +737,7 @@ static void tb_scan_port(struct tb_port *port)
{ {
struct tb_cm *tcm = tb_priv(port->sw->tb); struct tb_cm *tcm = tb_priv(port->sw->tb);
struct tb_port *upstream_port; struct tb_port *upstream_port;
bool discovery = false;
struct tb_switch *sw; struct tb_switch *sw;
int ret; int ret;
...@@ -804,8 +805,10 @@ static void tb_scan_port(struct tb_port *port) ...@@ -804,8 +805,10 @@ static void tb_scan_port(struct tb_port *port)
* tunnels and know which switches were authorized already by * tunnels and know which switches were authorized already by
* the boot firmware. * the boot firmware.
*/ */
if (!tcm->hotplug_active) if (!tcm->hotplug_active) {
dev_set_uevent_suppress(&sw->dev, true); dev_set_uevent_suppress(&sw->dev, true);
discovery = true;
}
/* /*
* At the moment Thunderbolt 2 and beyond (devices with LC) we * At the moment Thunderbolt 2 and beyond (devices with LC) we
...@@ -835,10 +838,14 @@ static void tb_scan_port(struct tb_port *port) ...@@ -835,10 +838,14 @@ static void tb_scan_port(struct tb_port *port)
* CL0s and CL1 are enabled and supported together. * CL0s and CL1 are enabled and supported together.
* Silently ignore CLx enabling in case CLx is not supported. * Silently ignore CLx enabling in case CLx is not supported.
*/ */
if (discovery) {
tb_sw_dbg(sw, "discovery, not touching CL states\n");
} else {
ret = tb_switch_enable_clx(sw, TB_CL1); ret = tb_switch_enable_clx(sw, TB_CL1);
if (ret && ret != -EOPNOTSUPP) if (ret && ret != -EOPNOTSUPP)
tb_sw_warn(sw, "failed to enable %s on upstream port\n", tb_sw_warn(sw, "failed to enable %s on upstream port\n",
tb_switch_clx_name(TB_CL1)); tb_switch_clx_name(TB_CL1));
}
if (tb_switch_is_clx_enabled(sw, TB_CL1)) if (tb_switch_is_clx_enabled(sw, TB_CL1))
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment