drm/gma500: Acquire reservation lock for GEM objects
authorThomas Zimmermann <tzimmermann@suse.de>
Tue, 8 Mar 2022 19:52:12 +0000 (20:52 +0100)
committerPatrik Jakobsson <patrik.r.jakobsson@gmail.com>
Wed, 16 Mar 2022 16:42:18 +0000 (17:42 +0100)
Protect concurrent access to struct psb_gem_object by acquiring
the GEM object's reservation lock; as it's supposed to be. The
use of the GTT mutex can now be moved into GTT code.

Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de>
Acked-by: Patrik Jakobsson <patrik.r.jakobsson@gmail.com>
Signed-off-by: Patrik Jakobsson <patrik.r.jakobsson@gmail.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220308195222.13471-3-tzimmermann@suse.de
drivers/gpu/drm/gma500/gem.c

index fe7d242567c03e5c8a59697f1f042cff48a2883e..026ce11f74608c567d47236a5682c8bb5367ae4f 100644 (file)
@@ -31,6 +31,10 @@ int psb_gem_pin(struct psb_gem_object *pobj)
        unsigned int npages;
        int ret;
 
+       ret = dma_resv_lock(obj->resv, NULL);
+       if (drm_WARN_ONCE(dev, ret, "dma_resv_lock() failed, ret=%d\n", ret))
+               return ret;
+
        mutex_lock(&dev_priv->gtt_mutex);
 
        if (pobj->in_gart || pobj->stolen)
@@ -56,11 +60,13 @@ int psb_gem_pin(struct psb_gem_object *pobj)
 out:
        ++pobj->in_gart;
        mutex_unlock(&dev_priv->gtt_mutex);
+       dma_resv_unlock(obj->resv);
 
        return 0;
 
 err_mutex_unlock:
        mutex_unlock(&dev_priv->gtt_mutex);
+       dma_resv_unlock(obj->resv);
        return ret;
 }
 
@@ -71,6 +77,11 @@ void psb_gem_unpin(struct psb_gem_object *pobj)
        struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
        u32 gpu_base = dev_priv->gtt.gatt_start;
        unsigned long npages;
+       int ret;
+
+       ret = dma_resv_lock(obj->resv, NULL);
+       if (drm_WARN_ONCE(dev, ret, "dma_resv_lock() failed, ret=%d\n", ret))
+               return;
 
        mutex_lock(&dev_priv->gtt_mutex);
 
@@ -95,6 +106,7 @@ void psb_gem_unpin(struct psb_gem_object *pobj)
 
 out:
        mutex_unlock(&dev_priv->gtt_mutex);
+       dma_resv_unlock(obj->resv);
 }
 
 static vm_fault_t psb_gem_fault(struct vm_fault *vmf);