diff options
author | Ben Widawsky <benjamin.widawsky@intel.com> | 2013-08-13 21:09:06 -0400 |
---|---|---|
committer | Daniel Vetter <daniel.vetter@ffwll.ch> | 2013-08-22 07:31:44 -0400 |
commit | 433544bd25b06cb6dcdb79b6da8d748a0220898e (patch) | |
tree | 43db94682893d338a10d96af3bd12fff9c492c72 /drivers/gpu/drm/i915/i915_gem.c | |
parent | 4a025e26a2979193739f46e391ffc05cf0637d90 (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.c | 5 |
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 | |||
2663 | destroy: | ||
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 |