drm/i915: Remove the double-list iteration from bound_any()
authorChris Wilson <chris@chris-wilson.co.uk>
Tue, 10 Sep 2013 10:27:37 +0000 (11:27 +0100)
committerDaniel Vetter <daniel.vetter@ffwll.ch>
Tue, 10 Sep 2013 14:14:06 +0000 (16:14 +0200)
The purpose of the function is to find out whether the object is still
bound in any address space. This can be easily checked by looking at the
vma currently associated with the object, rather than asking if any of
the global address spaces have an active vma on the object.

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 04e810c59d6209bb422eb34df22f9d7183700d22..face1451786ad4f971f675c8122b0908249c4a09 100644 (file)
@@ -4887,11 +4887,10 @@ bool i915_gem_obj_bound(struct drm_i915_gem_object *o,
 
 bool i915_gem_obj_bound_any(struct drm_i915_gem_object *o)
 {
-       struct drm_i915_private *dev_priv = o->base.dev->dev_private;
-       struct i915_address_space *vm;
+       struct i915_vma *vma;
 
-       list_for_each_entry(vm, &dev_priv->vm_list, global_link)
-               if (i915_gem_obj_bound(o, vm))
+       list_for_each_entry(vma, &o->vma_list, vma_link)
+               if (drm_mm_node_allocated(&vma->node))
                        return true;
 
        return false;