aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu
diff options
context:
space:
mode:
authorDaniel Vetter <daniel.vetter@ffwll.ch>2010-02-19 05:51:57 -0500
committerEric Anholt <eric@anholt.net>2010-02-26 16:23:21 -0500
commit4a87b8ca2185199c5d1b37b570efffd2e46fe813 (patch)
treed7b6df2f58f56277d6dfeac43334b7279868451d /drivers/gpu
parent798750e30d3de7932b0ac420f8fae2a970f2ac34 (diff)
drm/i915: fixup active list locking in object_unbind
All other accesses take this spinlock, so do this here, too. Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch> Signed-off-by: Eric Anholt <eric@anholt.net>
Diffstat (limited to 'drivers/gpu')
-rw-r--r--drivers/gpu/drm/i915/i915_gem.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c
index 302e096c3ca0..e6b85cdbc60f 100644
--- a/drivers/gpu/drm/i915/i915_gem.c
+++ b/drivers/gpu/drm/i915/i915_gem.c
@@ -1987,6 +1987,7 @@ int
1987i915_gem_object_unbind(struct drm_gem_object *obj) 1987i915_gem_object_unbind(struct drm_gem_object *obj)
1988{ 1988{
1989 struct drm_device *dev = obj->dev; 1989 struct drm_device *dev = obj->dev;
1990 drm_i915_private_t *dev_priv = dev->dev_private;
1990 struct drm_i915_gem_object *obj_priv = obj->driver_private; 1991 struct drm_i915_gem_object *obj_priv = obj->driver_private;
1991 int ret = 0; 1992 int ret = 0;
1992 1993
@@ -2042,8 +2043,10 @@ i915_gem_object_unbind(struct drm_gem_object *obj)
2042 } 2043 }
2043 2044
2044 /* Remove ourselves from the LRU list if present. */ 2045 /* Remove ourselves from the LRU list if present. */
2046 spin_lock(&dev_priv->mm.active_list_lock);
2045 if (!list_empty(&obj_priv->list)) 2047 if (!list_empty(&obj_priv->list))
2046 list_del_init(&obj_priv->list); 2048 list_del_init(&obj_priv->list);
2049 spin_unlock(&dev_priv->mm.active_list_lock);
2047 2050
2048 if (i915_gem_object_is_purgeable(obj_priv)) 2051 if (i915_gem_object_is_purgeable(obj_priv))
2049 i915_gem_object_truncate(obj); 2052 i915_gem_object_truncate(obj);