From: Jesse Barnes Date: Tue, 1 Jul 2008 23:10:01 +0000 (-0700) Subject: i915: only use tiled blits on 965+ X-Git-Tag: libdrm-2.4.0~129 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=301d984ea80cb250460d6701c4373cf0af8bf59e;p=platform%2Fupstream%2Flibdrm.git i915: only use tiled blits on 965+ When scheduled swaps occur, we need to blit between front & back buffers. I the buffers are tiled, we need to set the appropriate XY_SRC_COPY tile bit, only on 965 chips, since it will cause corruption on pre-965 (e.g. 945). Bug reported by and fix tested by Tomas Janousek . Signed-off-by: Jesse Barnes --- diff --git a/shared-core/i915_irq.c b/shared-core/i915_irq.c index 0bf01bd..28f9f6a 100644 --- a/shared-core/i915_irq.c +++ b/shared-core/i915_irq.c @@ -162,11 +162,11 @@ static void i915_vblank_tasklet(struct drm_device *dev) u32 ropcpp = (0xcc << 16) | ((cpp - 1) << 24); RING_LOCALS; - if (sarea_priv->front_tiled) { + if (IS_I965G(dev) && sarea_priv->front_tiled) { cmd |= XY_SRC_COPY_BLT_DST_TILED; dst_pitch >>= 2; } - if (sarea_priv->back_tiled) { + if (IS_I965G(dev) && sarea_priv->back_tiled) { cmd |= XY_SRC_COPY_BLT_SRC_TILED; src_pitch >>= 2; }