aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915/intel_dp_mst.c
diff options
context:
space:
mode:
authorThierry Reding <treding@nvidia.com>2017-07-04 11:18:21 -0400
committerDaniel Vetter <daniel.vetter@ffwll.ch>2017-07-06 04:00:22 -0400
commitaf2405af07d168e2905f2ac9494d3a804a549f0f (patch)
tree516d361cfd4ed9b403f9ac481dc859a69be5d441 /drivers/gpu/drm/i915/intel_dp_mst.c
parente6090cc9be15f8e3a5e736d427186e39fea7cceb (diff)
drm/fb-helper: Push down modeset lock into FB helpers
Move the modeset locking from drivers into FB helpers. v2: Also handle intel_connector_add_to_fbdev. v3: Prevent race in intel_dp_mst with ->detect (Maarten) Cc: Maarten Lankhorst <maarten.lankhorst@linux.intel.com> Cc: Alex Deucher <alexander.deucher@amd.com> Cc: Christian König <christian.koenig@amd.com> Tested-by: John Stultz <john.stultz@linaro.org> Signed-off-by: Thierry Reding <treding@nvidia.com> (v1) Reviewed-by: Maarten Lankhorst <maarten.lankhorst@intel.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch> Link: http://patchwork.freedesktop.org/patch/msgid/20170704151833.17304-2-daniel.vetter@ffwll.ch
Diffstat (limited to 'drivers/gpu/drm/i915/intel_dp_mst.c')
-rw-r--r--drivers/gpu/drm/i915/intel_dp_mst.c9
1 files changed, 3 insertions, 6 deletions
diff --git a/drivers/gpu/drm/i915/intel_dp_mst.c b/drivers/gpu/drm/i915/intel_dp_mst.c
index 2cf046beae0f..9aa959284497 100644
--- a/drivers/gpu/drm/i915/intel_dp_mst.c
+++ b/drivers/gpu/drm/i915/intel_dp_mst.c
@@ -501,11 +501,8 @@ static struct drm_connector *intel_dp_add_mst_connector(struct drm_dp_mst_topolo
501static void intel_dp_register_mst_connector(struct drm_connector *connector) 501static void intel_dp_register_mst_connector(struct drm_connector *connector)
502{ 502{
503 struct intel_connector *intel_connector = to_intel_connector(connector); 503 struct intel_connector *intel_connector = to_intel_connector(connector);
504 struct drm_device *dev = connector->dev;
505 504
506 drm_modeset_lock_all(dev);
507 intel_connector_add_to_fbdev(intel_connector); 505 intel_connector_add_to_fbdev(intel_connector);
508 drm_modeset_unlock_all(dev);
509 506
510 drm_connector_register(&intel_connector->base); 507 drm_connector_register(&intel_connector->base);
511} 508}
@@ -514,15 +511,15 @@ static void intel_dp_destroy_mst_connector(struct drm_dp_mst_topology_mgr *mgr,
514 struct drm_connector *connector) 511 struct drm_connector *connector)
515{ 512{
516 struct intel_connector *intel_connector = to_intel_connector(connector); 513 struct intel_connector *intel_connector = to_intel_connector(connector);
517 struct drm_device *dev = connector->dev;
518 514
519 drm_connector_unregister(connector); 515 drm_connector_unregister(connector);
520 516
521 /* need to nuke the connector */ 517 /* need to nuke the connector */
522 drm_modeset_lock_all(dev);
523 intel_connector_remove_from_fbdev(intel_connector); 518 intel_connector_remove_from_fbdev(intel_connector);
519 /* prevent race with the check in ->detect */
520 drm_modeset_lock(&connector->dev->mode_config.connection_mutex, NULL);
524 intel_connector->mst_port = NULL; 521 intel_connector->mst_port = NULL;
525 drm_modeset_unlock_all(dev); 522 drm_modeset_unlock(&connector->dev->mode_config.connection_mutex);
526 523
527 drm_connector_unreference(&intel_connector->base); 524 drm_connector_unreference(&intel_connector->base);
528 DRM_DEBUG_KMS("\n"); 525 DRM_DEBUG_KMS("\n");