Prev: writeback: Add tracing to write_cache_pages
Next: lglock: introduce special lglock and brlock spin locks
From: Jeff Chua on 4 Jun 2010 04:00 The following commit broke X11 mouse pointer. Symptom is "mouse pointer" on X11 cannot change "shape" when positioned to the frames of xterm window. Reverting it makes it work again. Running on X.Org X Server 1.8.99. Xterm 258. Lenovo X201s. Thanks, Jeff commit 9b8c4a0b215e603497daebe8ecbc9b1f0f035808 Author: Chris Wilson <chris(a)chris-wilson.co.uk> Date: Thu May 27 14:21:01 2010 +0100 drm/i915: Avoid moving from CPU domain during pwrite We can avoid an early clflush when pwriting if we use the current CPU write domain rather than moving the object to the GTT domain for the purposes of the pwrite. This has the advantage of not flushing the presumably hot data that we want to upload into the bo, and of ascribing the clflush to the execution when profiling. Signed-off-by: Chris Wilson <chris(a)chris-wilson.co.uk> Signed-off-by: Eric Anholt <eric(a)anholt.net> diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c index 42866c0..4590c78 100644 --- a/drivers/gpu/drm/i915/i915_gem.c +++ b/drivers/gpu/drm/i915/i915_gem.c @@ -971,7 +971,8 @@ i915_gem_pwrite_ioctl(struct drm_device *dev, void *data, if (obj_priv->phys_obj) ret = i915_gem_phys_pwrite(dev, obj, args, file_priv); else if (obj_priv->tiling_mode == I915_TILING_NONE && - dev->gtt_total != 0) { + dev->gtt_total != 0 && + obj->write_domain != I915_GEM_DOMAIN_CPU) { ret = i915_gem_gtt_pwrite_fast(dev, obj, args, file_priv); if (ret == -EFAULT) { ret = i915_gem_gtt_pwrite_slow(dev, obj, args, -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/ |