As gen6 introduced per-engine masking of the user interrupt at source,
we can leave the global GT interrupt unmasked (as we can filter the
interrupts earlier) and so reduce enabling/disabling the user interrupt
to a single register write in the local engine.

Signed-off-by: Chris Wilson <[email protected]>
Cc: Mika Kuoppala <[email protected]>
Cc: Ville Syrjälä <[email protected]>
---
 drivers/gpu/drm/i915/i915_irq.c         | 17 ++++++++--------
 drivers/gpu/drm/i915/intel_ringbuffer.c | 27 -------------------------
 2 files changed, 8 insertions(+), 36 deletions(-)

diff --git a/drivers/gpu/drm/i915/i915_irq.c b/drivers/gpu/drm/i915/i915_irq.c
index fbb094ecf6c9..d71f82997ea7 100644
--- a/drivers/gpu/drm/i915/i915_irq.c
+++ b/drivers/gpu/drm/i915/i915_irq.c
@@ -4027,19 +4027,18 @@ static void gen5_gt_irq_postinstall(struct drm_device 
*dev)
 
        pm_irqs = gt_irqs = 0;
 
-       dev_priv->gt_irq_mask = ~0;
-       if (HAS_L3_DPF(dev_priv)) {
-               /* L3 parity interrupt is always unmasked. */
-               dev_priv->gt_irq_mask = ~GT_PARITY_ERROR(dev_priv);
+       if (HAS_L3_DPF(dev_priv))
                gt_irqs |= GT_PARITY_ERROR(dev_priv);
-       }
 
        gt_irqs |= GT_RENDER_USER_INTERRUPT;
-       if (IS_GEN(dev_priv, 5)) {
+       if (IS_GEN(dev_priv, 5))
                gt_irqs |= ILK_BSD_USER_INTERRUPT;
-       } else {
+       else
                gt_irqs |= GT_BLT_USER_INTERRUPT | GT_BSD_USER_INTERRUPT;
-       }
+
+       dev_priv->gt_irq_mask = ~0u;
+       if (INTEL_GEN(dev_priv) >= 6)
+               dev_priv->gt_irq_mask = ~gt_irqs;
 
        GEN3_IRQ_INIT(GT, dev_priv->gt_irq_mask, gt_irqs);
 
@@ -4053,7 +4052,7 @@ static void gen5_gt_irq_postinstall(struct drm_device 
*dev)
                        dev_priv->pm_ier |= PM_VEBOX_USER_INTERRUPT;
                }
 
-               dev_priv->pm_imr = 0xffffffff;
+               dev_priv->pm_imr = ~pm_irqs;
                GEN3_IRQ_INIT(GEN6_PM, dev_priv->pm_imr, pm_irqs);
        }
 }
diff --git a/drivers/gpu/drm/i915/intel_ringbuffer.c 
b/drivers/gpu/drm/i915/intel_ringbuffer.c
index 488ace0f4093..f1fca06c09f6 100644
--- a/drivers/gpu/drm/i915/intel_ringbuffer.c
+++ b/drivers/gpu/drm/i915/intel_ringbuffer.c
@@ -949,8 +949,6 @@ gen6_irq_enable(struct intel_engine_cs *engine)
 
        /* Flush/delay to ensure the RING_IMR is active before the GT IMR */
        POSTING_READ_FW(RING_IMR(engine->mmio_base));
-
-       gen5_enable_gt_irq(dev_priv, engine->irq_enable_mask);
 }
 
 static void
@@ -959,29 +957,6 @@ gen6_irq_disable(struct intel_engine_cs *engine)
        struct drm_i915_private *dev_priv = engine->i915;
 
        I915_WRITE_IMR(engine, ~engine->irq_keep_mask);
-       gen5_disable_gt_irq(dev_priv, engine->irq_enable_mask);
-}
-
-static void
-hsw_vebox_irq_enable(struct intel_engine_cs *engine)
-{
-       struct drm_i915_private *dev_priv = engine->i915;
-
-       I915_WRITE_IMR(engine, ~engine->irq_enable_mask);
-
-       /* Flush/delay to ensure the RING_IMR is active before the GT IMR */
-       POSTING_READ_FW(RING_IMR(engine->mmio_base));
-
-       gen6_unmask_pm_irq(dev_priv, engine->irq_enable_mask);
-}
-
-static void
-hsw_vebox_irq_disable(struct intel_engine_cs *engine)
-{
-       struct drm_i915_private *dev_priv = engine->i915;
-
-       I915_WRITE_IMR(engine, ~0);
-       gen6_mask_pm_irq(dev_priv, engine->irq_enable_mask);
 }
 
 static int
@@ -2283,8 +2258,6 @@ int intel_init_vebox_ring_buffer(struct intel_engine_cs 
*engine)
 
        engine->emit_flush = gen6_ring_flush;
        engine->irq_enable_mask = PM_VEBOX_USER_INTERRUPT;
-       engine->irq_enable = hsw_vebox_irq_enable;
-       engine->irq_disable = hsw_vebox_irq_disable;
 
        engine->emit_breadcrumb = gen6_xcs_emit_breadcrumb;
        engine->emit_breadcrumb_sz = gen6_xcs_emit_breadcrumb_sz;
-- 
2.20.1

_______________________________________________
Intel-gfx mailing list
[email protected]
https://lists.freedesktop.org/mailman/listinfo/intel-gfx

Reply via email to