aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/omapdrm/omap_gem.c
diff options
context:
space:
mode:
authorLaurent Pinchart <laurent.pinchart@ideasonboard.com>2018-05-25 12:39:22 -0400
committerTomi Valkeinen <tomi.valkeinen@ti.com>2018-06-28 06:41:05 -0400
commitdc8c9aeee5098688c1085691213fb9a703bf20ad (patch)
tree233f6c722cbdd5b50fe81753921fea8e6fd5f95b /drivers/gpu/drm/omapdrm/omap_gem.c
parent2491244d7709d4e35f61d75ed3f6b4ea31b0a6f3 (diff)
drm/omap: gem: Don't take struct_mutex to get GEM object mmap offset
GEM objects mmap offsets are created by calling drm_gem_create_mmap_offset_size() that doesn't need struct_mutex protection as it includes its own locking, based on a size that is static across the object's life time. Remove the unneeded struct_mutex locking. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch> Reviewed-by: Tomi Valkeinen <tomi.valkeinen@ti.com> Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
Diffstat (limited to 'drivers/gpu/drm/omapdrm/omap_gem.c')
-rw-r--r--drivers/gpu/drm/omapdrm/omap_gem.c16
1 files changed, 2 insertions, 14 deletions
diff --git a/drivers/gpu/drm/omapdrm/omap_gem.c b/drivers/gpu/drm/omapdrm/omap_gem.c
index a3efac4abd4b..623856d9b85a 100644
--- a/drivers/gpu/drm/omapdrm/omap_gem.c
+++ b/drivers/gpu/drm/omapdrm/omap_gem.c
@@ -137,14 +137,12 @@ struct omap_drm_usergart {
137 */ 137 */
138 138
139/** get mmap offset */ 139/** get mmap offset */
140static u64 mmap_offset(struct drm_gem_object *obj) 140u64 omap_gem_mmap_offset(struct drm_gem_object *obj)
141{ 141{
142 struct drm_device *dev = obj->dev; 142 struct drm_device *dev = obj->dev;
143 int ret; 143 int ret;
144 size_t size; 144 size_t size;
145 145
146 WARN_ON(!mutex_is_locked(&dev->struct_mutex));
147
148 /* Make it mmapable */ 146 /* Make it mmapable */
149 size = omap_gem_mmap_size(obj); 147 size = omap_gem_mmap_size(obj);
150 ret = drm_gem_create_mmap_offset_size(obj, size); 148 ret = drm_gem_create_mmap_offset_size(obj, size);
@@ -178,7 +176,7 @@ static void omap_gem_evict_entry(struct drm_gem_object *obj,
178 struct omap_drm_private *priv = obj->dev->dev_private; 176 struct omap_drm_private *priv = obj->dev->dev_private;
179 int n = priv->usergart[fmt].height; 177 int n = priv->usergart[fmt].height;
180 size_t size = PAGE_SIZE * n; 178 size_t size = PAGE_SIZE * n;
181 loff_t off = mmap_offset(obj) + 179 loff_t off = omap_gem_mmap_offset(obj) +
182 (entry->obj_pgoff << PAGE_SHIFT); 180 (entry->obj_pgoff << PAGE_SHIFT);
183 const int m = DIV_ROUND_UP(omap_obj->width << fmt, PAGE_SIZE); 181 const int m = DIV_ROUND_UP(omap_obj->width << fmt, PAGE_SIZE);
184 182
@@ -319,16 +317,6 @@ u32 omap_gem_flags(struct drm_gem_object *obj)
319 return to_omap_bo(obj)->flags; 317 return to_omap_bo(obj)->flags;
320} 318}
321 319
322u64 omap_gem_mmap_offset(struct drm_gem_object *obj)
323{
324 u64 offset;
325
326 mutex_lock(&obj->dev->struct_mutex);
327 offset = mmap_offset(obj);
328 mutex_unlock(&obj->dev->struct_mutex);
329 return offset;
330}
331
332/** get mmap size */ 320/** get mmap size */
333size_t omap_gem_mmap_size(struct drm_gem_object *obj) 321size_t omap_gem_mmap_size(struct drm_gem_object *obj)
334{ 322{