aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915/i915_gem.c
diff options
context:
space:
mode:
authorBen Widawsky <benjamin.widawsky@intel.com>2013-08-13 21:09:06 -0400
committerDaniel Vetter <daniel.vetter@ffwll.ch>2013-08-22 07:31:44 -0400
commit433544bd25b06cb6dcdb79b6da8d748a0220898e (patch)
tree43db94682893d338a10d96af3bd12fff9c492c72 /drivers/gpu/drm/i915/i915_gem.c
parent4a025e26a2979193739f46e391ffc05cf0637d90 (diff)
drm/i915: Remove node only when allocated
VMAs can be created and not bound. One may think of it as lazy cleanup, and safely gloss over the conditions which manufacture it. In either case, when the object backing the i915 vma is destroyed, we must cleanup the vma without stumbling into a bunch of pitfalls that assume the vma is bound. NOTE: I was pretty certain the above condition could only happen when we introduced the use of VMAs being looked up at execbuf, and already existing. Paulo has hit this though, so I must be missing something. As I believe the patch is correct anyway, therefore I won't scratch my head too hard. v2: use goto destroy as a compromise (Chris) Cc: Chris Wilson <chris@chris-wilson.co.uk> Cc: Paulo Zanoni <paulo.r.zanoni@intel.com> Signed-off-by: Ben Widawsky <ben@bwidawsk.net> Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers/gpu/drm/i915/i915_gem.c')
-rw-r--r--drivers/gpu/drm/i915/i915_gem.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c
index 5f48ecc77ec2..910fbaff0e99 100644
--- a/drivers/gpu/drm/i915/i915_gem.c
+++ b/drivers/gpu/drm/i915/i915_gem.c
@@ -2619,6 +2619,9 @@ int i915_vma_unbind(struct i915_vma *vma)
2619 if (list_empty(&vma->vma_link)) 2619 if (list_empty(&vma->vma_link))
2620 return 0; 2620 return 0;
2621 2621
2622 if (!drm_mm_node_allocated(&vma->node))
2623 goto destroy;
2624
2622 if (obj->pin_count) 2625 if (obj->pin_count)
2623 return -EBUSY; 2626 return -EBUSY;
2624 2627
@@ -2656,6 +2659,8 @@ int i915_vma_unbind(struct i915_vma *vma)
2656 obj->map_and_fenceable = true; 2659 obj->map_and_fenceable = true;
2657 2660
2658 drm_mm_remove_node(&vma->node); 2661 drm_mm_remove_node(&vma->node);
2662
2663destroy:
2659 i915_gem_vma_destroy(vma); 2664 i915_gem_vma_destroy(vma);
2660 2665
2661 /* Since the unbound list is global, only move to that list if 2666 /* Since the unbound list is global, only move to that list if