aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDaniel Vetter <daniel.vetter@ffwll.ch>2016-11-29 04:45:38 -0500
committerDaniel Vetter <daniel.vetter@ffwll.ch>2016-11-29 17:34:36 -0500
commit661a3755610ead153232011d22dc5c3688b24146 (patch)
treeb02861e28123a25d475db5e8d2578ecf9c5f913f
parentb07c42547b8253c806ae2d03c452b7d894672685 (diff)
drm: Fix locking cargo-cult in encoder/plane init/cleanup
Encoders&planes can't be hotplugged, we dont need locking for this since it's all single-threaded driver setup/teardown code. CRTCs already don't grab locks. While at it I noticed that plane's are missing the drm_modeset_lock_fini() call, so add it. Reviewed-by: Frank Binns <frank.binns@imgtec.com> Signed-off-by: Daniel Vetter <daniel.vetter@intel.com> Link: http://patchwork.freedesktop.org/patch/msgid/20161129094538.9650-1-daniel.vetter@ffwll.ch
-rw-r--r--drivers/gpu/drm/drm_encoder.c9
-rw-r--r--drivers/gpu/drm/drm_plane.c4
2 files changed, 3 insertions, 10 deletions
diff --git a/drivers/gpu/drm/drm_encoder.c b/drivers/gpu/drm/drm_encoder.c
index 5c067719164d..992879f15f23 100644
--- a/drivers/gpu/drm/drm_encoder.c
+++ b/drivers/gpu/drm/drm_encoder.c
@@ -110,11 +110,9 @@ int drm_encoder_init(struct drm_device *dev,
110{ 110{
111 int ret; 111 int ret;
112 112
113 drm_modeset_lock_all(dev);
114
115 ret = drm_mode_object_get(dev, &encoder->base, DRM_MODE_OBJECT_ENCODER); 113 ret = drm_mode_object_get(dev, &encoder->base, DRM_MODE_OBJECT_ENCODER);
116 if (ret) 114 if (ret)
117 goto out_unlock; 115 return ret;
118 116
119 encoder->dev = dev; 117 encoder->dev = dev;
120 encoder->encoder_type = encoder_type; 118 encoder->encoder_type = encoder_type;
@@ -142,9 +140,6 @@ out_put:
142 if (ret) 140 if (ret)
143 drm_mode_object_unregister(dev, &encoder->base); 141 drm_mode_object_unregister(dev, &encoder->base);
144 142
145out_unlock:
146 drm_modeset_unlock_all(dev);
147
148 return ret; 143 return ret;
149} 144}
150EXPORT_SYMBOL(drm_encoder_init); 145EXPORT_SYMBOL(drm_encoder_init);
@@ -164,12 +159,10 @@ void drm_encoder_cleanup(struct drm_encoder *encoder)
164 * the indices on the drm_encoder after us in the encoder_list. 159 * the indices on the drm_encoder after us in the encoder_list.
165 */ 160 */
166 161
167 drm_modeset_lock_all(dev);
168 drm_mode_object_unregister(dev, &encoder->base); 162 drm_mode_object_unregister(dev, &encoder->base);
169 kfree(encoder->name); 163 kfree(encoder->name);
170 list_del(&encoder->head); 164 list_del(&encoder->head);
171 dev->mode_config.num_encoder--; 165 dev->mode_config.num_encoder--;
172 drm_modeset_unlock_all(dev);
173 166
174 memset(encoder, 0, sizeof(*encoder)); 167 memset(encoder, 0, sizeof(*encoder));
175} 168}
diff --git a/drivers/gpu/drm/drm_plane.c b/drivers/gpu/drm/drm_plane.c
index 419ac313c36f..9147aab182c4 100644
--- a/drivers/gpu/drm/drm_plane.c
+++ b/drivers/gpu/drm/drm_plane.c
@@ -221,7 +221,8 @@ void drm_plane_cleanup(struct drm_plane *plane)
221{ 221{
222 struct drm_device *dev = plane->dev; 222 struct drm_device *dev = plane->dev;
223 223
224 drm_modeset_lock_all(dev); 224 drm_modeset_lock_fini(&plane->mutex);
225
225 kfree(plane->format_types); 226 kfree(plane->format_types);
226 drm_mode_object_unregister(dev, &plane->base); 227 drm_mode_object_unregister(dev, &plane->base);
227 228
@@ -236,7 +237,6 @@ void drm_plane_cleanup(struct drm_plane *plane)
236 dev->mode_config.num_total_plane--; 237 dev->mode_config.num_total_plane--;
237 if (plane->type == DRM_PLANE_TYPE_OVERLAY) 238 if (plane->type == DRM_PLANE_TYPE_OVERLAY)
238 dev->mode_config.num_overlay_plane--; 239 dev->mode_config.num_overlay_plane--;
239 drm_modeset_unlock_all(dev);
240 240
241 WARN_ON(plane->state && !plane->funcs->atomic_destroy_state); 241 WARN_ON(plane->state && !plane->funcs->atomic_destroy_state);
242 if (plane->state && plane->funcs->atomic_destroy_state) 242 if (plane->state && plane->funcs->atomic_destroy_state)