Skip to content

Commit 4e270f0

Browse files
committed
drm/gem: Drop struct_mutex requirement from drm_gem_mmap_obj
Since commit 131e663 Author: Daniel Vetter <daniel.vetter@ffwll.ch> Date: Thu Jul 9 23:32:33 2015 +0200 drm/gem: rip out drm vma accounting for gem mmaps there is no need for this any more. v2: Fixup compile noise spotted by 0-day build. Link: http://mid.gmane.org/1444894601-5200-9-git-send-email-daniel.vetter@ffwll.ch Reviewed-by: David Herrmann <dh.herrmann@gmail.com> Signed-off-by: Daniel Vetter <daniel.vetter@intel.com>
1 parent 70d9947 commit 4e270f0

File tree

6 files changed

+0
-19
lines changed

6 files changed

+0
-19
lines changed

drivers/gpu/drm/drm_gem.c

Lines changed: 0 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -810,8 +810,6 @@ EXPORT_SYMBOL(drm_gem_vm_close);
810810
* drm_gem_mmap() prevents unprivileged users from mapping random objects. So
811811
* callers must verify access restrictions before calling this helper.
812812
*
813-
* NOTE: This function has to be protected with dev->struct_mutex
814-
*
815813
* Return 0 or success or -EINVAL if the object size is smaller than the VMA
816814
* size, or if no gem_vm_ops are provided.
817815
*/
@@ -820,8 +818,6 @@ int drm_gem_mmap_obj(struct drm_gem_object *obj, unsigned long obj_size,
820818
{
821819
struct drm_device *dev = obj->dev;
822820

823-
lockdep_assert_held(&dev->struct_mutex);
824-
825821
/* Check for valid size. */
826822
if (obj_size < vma->vm_end - vma->vm_start)
827823
return -EINVAL;

drivers/gpu/drm/drm_gem_cma_helper.c

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -484,9 +484,7 @@ int drm_gem_cma_prime_mmap(struct drm_gem_object *obj,
484484
struct drm_device *dev = obj->dev;
485485
int ret;
486486

487-
mutex_lock(&dev->struct_mutex);
488487
ret = drm_gem_mmap_obj(obj, obj->size, vma);
489-
mutex_unlock(&dev->struct_mutex);
490488
if (ret < 0)
491489
return ret;
492490

drivers/gpu/drm/msm/msm_fbdev.c

Lines changed: 0 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -68,12 +68,7 @@ static int msm_fbdev_mmap(struct fb_info *info, struct vm_area_struct *vma)
6868
if (drm_device_is_unplugged(dev))
6969
return -ENODEV;
7070

71-
mutex_lock(&dev->struct_mutex);
72-
7371
ret = drm_gem_mmap_obj(drm_obj, drm_obj->size, vma);
74-
75-
mutex_unlock(&dev->struct_mutex);
76-
7772
if (ret) {
7873
pr_err("%s:drm_gem_mmap_obj fail\n", __func__);
7974
return ret;

drivers/gpu/drm/msm/msm_gem_prime.c

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -45,9 +45,7 @@ int msm_gem_prime_mmap(struct drm_gem_object *obj, struct vm_area_struct *vma)
4545
{
4646
int ret;
4747

48-
mutex_lock(&obj->dev->struct_mutex);
4948
ret = drm_gem_mmap_obj(obj, obj->size, vma);
50-
mutex_unlock(&obj->dev->struct_mutex);
5149
if (ret < 0)
5250
return ret;
5351

drivers/gpu/drm/omapdrm/omap_gem_dmabuf.c

Lines changed: 0 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -140,15 +140,12 @@ static int omap_gem_dmabuf_mmap(struct dma_buf *buffer,
140140
struct vm_area_struct *vma)
141141
{
142142
struct drm_gem_object *obj = buffer->priv;
143-
struct drm_device *dev = obj->dev;
144143
int ret = 0;
145144

146145
if (WARN_ON(!obj->filp))
147146
return -EINVAL;
148147

149-
mutex_lock(&dev->struct_mutex);
150148
ret = drm_gem_mmap_obj(obj, omap_gem_mmap_size(obj), vma);
151-
mutex_unlock(&dev->struct_mutex);
152149
if (ret < 0)
153150
return ret;
154151

drivers/gpu/drm/rockchip/rockchip_drm_gem.c

Lines changed: 0 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -79,12 +79,9 @@ static int rockchip_drm_gem_object_mmap(struct drm_gem_object *obj,
7979
int rockchip_gem_mmap_buf(struct drm_gem_object *obj,
8080
struct vm_area_struct *vma)
8181
{
82-
struct drm_device *drm = obj->dev;
8382
int ret;
8483

85-
mutex_lock(&drm->struct_mutex);
8684
ret = drm_gem_mmap_obj(obj, obj->size, vma);
87-
mutex_unlock(&drm->struct_mutex);
8885
if (ret)
8986
return ret;
9087

0 commit comments

Comments
 (0)