This reintroduces the IRQ misses, with 2 events in 1874 runs.

Signed-off-by: Eric Anholt <e...@anholt.net>
---
 drivers/gpu/drm/i915/i915_drv.c |   16 +++++++++++-----
 1 files changed, 11 insertions(+), 5 deletions(-)

diff --git a/drivers/gpu/drm/i915/i915_drv.c b/drivers/gpu/drm/i915/i915_drv.c
index eabf82c..5444032 100644
--- a/drivers/gpu/drm/i915/i915_drv.c
+++ b/drivers/gpu/drm/i915/i915_drv.c
@@ -383,18 +383,24 @@ void __gen6_gt_wait_for_fifo(struct drm_i915_private 
*dev_priv)
 void
 intel_posting_read(struct drm_i915_private *dev_priv, uint32_t reg)
 {
-       int ret;
+       u32 fifo;
+       int loop = 5000;
 
        if (dev_priv->info->gen < 6) {
                (void)I915_READ_NOTRACE(reg);
                return;
        }
 
-       gen6_gt_force_wake_get(dev_priv);
-       ret = wait_for(I915_READ_NOTRACE(GT_FIFO_FREE_ENTRIES) == 0x3f, 500);
-       gen6_gt_force_wake_put(dev_priv);
+       if (!I915_READ_NOTRACE(GT_FIFO_FREE_ENTRIES))
+               printk("it got 0\n");
+
+       fifo = I915_READ_NOTRACE(GT_FIFO_FREE_ENTRIES);
+       while (fifo != 0x3f && --loop) {
+               udelay(10);
+               fifo = I915_READ_NOTRACE(GT_FIFO_FREE_ENTRIES);
+       }
 
-       WARN_ON_ONCE(ret != 0);
+       WARN_ON_ONCE(loop == 0);
 }
 
 static int i915_drm_freeze(struct drm_device *dev)
-- 
1.7.5.1

_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/intel-gfx

Reply via email to