[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <1694753689-29782-1-git-send-email-quic_rsr@quicinc.com>
Date: Fri, 15 Sep 2023 10:24:49 +0530
From: Ramya SR <quic_rsr@...cinc.com>
To: David Airlie <airlied@...il.com>, Daniel Vetter <daniel@...ll.ch>,
"Lyude Paul" <lyude@...hat.com>, Wayne Lin <Wayne.Lin@....com>,
Jani Nikula <jani.nikula@...el.com>,
Imre Deak <imre.deak@...el.com>,
Alex Deucher <alexander.deucher@....com>,
Jeff Layton <jlayton@...nel.org>,
<dri-devel@...ts.freedesktop.org>, <linux-kernel@...r.kernel.org>
CC: Ramya SR <quic_rsr@...cinc.com>
Subject: [PATCH v1] drm/dp/mst: fix missing modeset unlock for MST port detect
Modeset mutex unlock is missing in drm_dp_mst_detect_port function.
This will lead to deadlock if calling the function multiple times in
an atomic operation, for example, getting imultiple MST ports status
for a DP MST bonding scenario.
Signed-off-by: Ramya SR <quic_rsr@...cinc.com>
---
drivers/gpu/drm/display/drm_dp_mst_topology.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/drivers/gpu/drm/display/drm_dp_mst_topology.c b/drivers/gpu/drm/display/drm_dp_mst_topology.c
index ed96cfc..d6512c4 100644
--- a/drivers/gpu/drm/display/drm_dp_mst_topology.c
+++ b/drivers/gpu/drm/display/drm_dp_mst_topology.c
@@ -4154,7 +4154,7 @@ drm_dp_mst_detect_port(struct drm_connector *connector,
ret = drm_modeset_lock(&mgr->base.lock, ctx);
if (ret)
- goto out;
+ goto fail;
ret = connector_status_disconnected;
@@ -4181,6 +4181,8 @@ drm_dp_mst_detect_port(struct drm_connector *connector,
break;
}
out:
+ drm_modeset_unlock(&mgr->base.lock);
+fail:
drm_dp_mst_topology_put_port(port);
return ret;
}
--
2.7.4
Powered by blists - more mailing lists