drm/i915: no need to hold mutex for object lookup
authorChris Wilson <chris@chris-wilson.co.uk>
Sat, 6 Jun 2009 08:46:00 +0000 (09:46 +0100)
committerEric Anholt <eric@anholt.net>
Tue, 9 Jun 2009 21:41:37 +0000 (14:41 -0700)
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: Eric Anholt <eric@anholt.net>
drivers/gpu/drm/i915/i915_gem.c

index 2d705e8a297ef941c3efea403bce614d22dd69f1..744bf9803ea3d53713b8e273ffa5fd481a0d08af 100644 (file)
@@ -3701,15 +3701,14 @@ i915_gem_busy_ioctl(struct drm_device *dev, void *data,
        struct drm_gem_object *obj;
        struct drm_i915_gem_object *obj_priv;
 
-       mutex_lock(&dev->struct_mutex);
        obj = drm_gem_object_lookup(dev, file_priv, args->handle);
        if (obj == NULL) {
                DRM_ERROR("Bad handle in i915_gem_busy_ioctl(): %d\n",
                          args->handle);
-               mutex_unlock(&dev->struct_mutex);
                return -EBADF;
        }
 
+       mutex_lock(&dev->struct_mutex);
        /* Update the active list for the hardware's current position.
         * Otherwise this only updates on a delayed timer or when irqs are
         * actually unmasked, and our working set ends up being larger than