drm/i915: Protect private gem objects from truncate (such as imported dmabuf)
authorChris Wilson <chris@chris-wilson.co.uk>
Sat, 11 Aug 2012 14:41:05 +0000 (15:41 +0100)
committerDaniel Vetter <daniel.vetter@ffwll.ch>
Fri, 24 Aug 2012 00:04:31 +0000 (02:04 +0200)
If the object has no backing shmemfs filp, then we obviously cannot
perform a truncation operation upon it.

Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
drivers/gpu/drm/i915/i915_gem.c

index 1ec5f7e..eb54a6d 100644 (file)
@@ -1385,6 +1385,11 @@ i915_gem_object_truncate(struct drm_i915_gem_object *obj)
 {
        struct inode *inode;
 
+       i915_gem_object_free_mmap_offset(obj);
+
+       if (obj->base.filp == NULL)
+               return;
+
        /* Our goal here is to return as much of the memory as
         * is possible back to the system as we are called from OOM.
         * To do this we must instruct the shmfs to drop all of its
@@ -1393,8 +1398,6 @@ i915_gem_object_truncate(struct drm_i915_gem_object *obj)
        inode = obj->base.filp->f_path.dentry->d_inode;
        shmem_truncate_range(inode, 0, (loff_t)-1);
 
-       i915_gem_object_free_mmap_offset(obj);
-
        obj->madv = __I915_MADV_PURGED;
 }