diff options
author | Laurent Pinchart <laurent.pinchart@ideasonboard.com> | 2018-05-25 12:39:22 -0400 |
---|---|---|
committer | Tomi Valkeinen <tomi.valkeinen@ti.com> | 2018-06-28 06:41:05 -0400 |
commit | dc8c9aeee5098688c1085691213fb9a703bf20ad (patch) | |
tree | 233f6c722cbdd5b50fe81753921fea8e6fd5f95b /drivers/gpu/drm/omapdrm/omap_gem.c | |
parent | 2491244d7709d4e35f61d75ed3f6b4ea31b0a6f3 (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.c | 16 |
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 */ |
140 | static u64 mmap_offset(struct drm_gem_object *obj) | 140 | u64 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 | ||
322 | u64 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 */ |
333 | size_t omap_gem_mmap_size(struct drm_gem_object *obj) | 321 | size_t omap_gem_mmap_size(struct drm_gem_object *obj) |
334 | { | 322 | { |