drm/i915: Fix current tiling check for relaxed fencing
authorChris Wilson <chris@chris-wilson.co.uk>
Mon, 15 Nov 2010 05:25:58 +0000 (05:25 +0000)
committerChris Wilson <chris@chris-wilson.co.uk>
Mon, 15 Nov 2010 06:48:46 +0000 (06:48 +0000)
As we may bind an object with the correct alignment, but with an invalid
size, it may pass the current checks on whether the object may be reused
with a fence.

Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
drivers/gpu/drm/i915/i915_gem_tiling.c

index 0597a737ebad2e90202321c65c84f347b6a23fa0..a517b48d441d625604d00c160ce863695520f6aa 100644 (file)
@@ -245,6 +245,17 @@ i915_gem_object_fence_ok(struct drm_gem_object *obj, int tiling_mode)
        if (INTEL_INFO(obj->dev)->gen >= 4)
                return true;
 
+       if (!obj_priv->gtt_space)
+               return true;
+
+       if (INTEL_INFO(obj->dev)->gen == 3) {
+               if (obj_priv->gtt_offset & ~I915_FENCE_START_MASK)
+                       return false;
+       } else {
+               if (obj_priv->gtt_offset & ~I830_FENCE_START_MASK)
+                       return false;
+       }
+
        /*
         * Previous chips need to be aligned to the size of the smallest
         * fence register that can contain the object.
@@ -257,16 +268,11 @@ i915_gem_object_fence_ok(struct drm_gem_object *obj, int tiling_mode)
        while (size < obj_priv->base.size)
                size <<= 1;
 
-       if (obj_priv->gtt_offset & (size - 1))
+       if (obj_priv->gtt_space->size != size)
                return false;
 
-       if (INTEL_INFO(obj->dev)->gen == 3) {
-               if (obj_priv->gtt_offset & ~I915_FENCE_START_MASK)
-                       return false;
-       } else {
-               if (obj_priv->gtt_offset & ~I830_FENCE_START_MASK)
-                       return false;
-       }
+       if (obj_priv->gtt_offset & (size - 1))
+               return false;
 
        return true;
 }