forked from luck/tmp_suning_uos_patched
drm/i915: Clean up the HWSTAM mess
Currently we're unmasking some random looking bits in HWSTAM on gen3/4/5. The two bits we apparently unmask are 0 and 12, and also bits 16-31 on gen4/5. What those bits do depends on the gen as follows: bit 0: Breakpoint (gen2), ASLE (gen3), reserved (gen4), render user interrupt (gen5) bit 12: Sync flush statusa (gen2-4), reserved (gen5) bit 16-31: The ones that can unmasked seem to be mostly some display stuff on gen4. Bit 18 is the PIPE_CONTROL notify, which might be the only intresting one. On gen5 all the bits are reserved. So I don't know whether we actually depend on that status page write somehow. Extra seqno coherency by accident perhaps? Except we don't even unmask the user interrupt bit in HWSTAM except on gen5, and sync flush isn't something we use normally, so seems unlikely. So let's just assume we don't need any of this and mask everything in HWSTAM. From gen6 onwards there's a separate HWSTAM for each engine, and so we deal with them during the engine setup. Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20170818183705.27850-15-ville.syrjala@linux.intel.com Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk>
This commit is contained in:
parent
c549808946
commit
d420a50c21
|
@ -3058,6 +3058,7 @@ static void ironlake_irq_reset(struct drm_device *dev)
|
||||||
{
|
{
|
||||||
struct drm_i915_private *dev_priv = to_i915(dev);
|
struct drm_i915_private *dev_priv = to_i915(dev);
|
||||||
|
|
||||||
|
if (IS_GEN5(dev_priv))
|
||||||
I915_WRITE(HWSTAM, 0xffffffff);
|
I915_WRITE(HWSTAM, 0xffffffff);
|
||||||
|
|
||||||
GEN3_IRQ_RESET(DE);
|
GEN3_IRQ_RESET(DE);
|
||||||
|
@ -3419,8 +3420,6 @@ static int ironlake_irq_postinstall(struct drm_device *dev)
|
||||||
|
|
||||||
dev_priv->irq_mask = ~display_mask;
|
dev_priv->irq_mask = ~display_mask;
|
||||||
|
|
||||||
I915_WRITE(HWSTAM, 0xeffe);
|
|
||||||
|
|
||||||
ibx_irq_pre_postinstall(dev);
|
ibx_irq_pre_postinstall(dev);
|
||||||
|
|
||||||
GEN3_IRQ_INIT(DE, dev_priv->irq_mask, display_mask | extra_mask);
|
GEN3_IRQ_INIT(DE, dev_priv->irq_mask, display_mask | extra_mask);
|
||||||
|
@ -3621,8 +3620,6 @@ static void valleyview_irq_uninstall(struct drm_device *dev)
|
||||||
|
|
||||||
gen5_gt_irq_reset(dev_priv);
|
gen5_gt_irq_reset(dev_priv);
|
||||||
|
|
||||||
I915_WRITE(HWSTAM, 0xffffffff);
|
|
||||||
|
|
||||||
spin_lock_irq(&dev_priv->irq_lock);
|
spin_lock_irq(&dev_priv->irq_lock);
|
||||||
if (dev_priv->display_irqs_enabled)
|
if (dev_priv->display_irqs_enabled)
|
||||||
vlv_display_irq_reset(dev_priv);
|
vlv_display_irq_reset(dev_priv);
|
||||||
|
@ -3657,6 +3654,8 @@ static void i8xx_irq_preinstall(struct drm_device * dev)
|
||||||
|
|
||||||
i9xx_pipestat_irq_reset(dev_priv);
|
i9xx_pipestat_irq_reset(dev_priv);
|
||||||
|
|
||||||
|
I915_WRITE16(HWSTAM, 0xffff);
|
||||||
|
|
||||||
GEN2_IRQ_RESET();
|
GEN2_IRQ_RESET();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3738,6 +3737,8 @@ static void i8xx_irq_uninstall(struct drm_device * dev)
|
||||||
|
|
||||||
i9xx_pipestat_irq_reset(dev_priv);
|
i9xx_pipestat_irq_reset(dev_priv);
|
||||||
|
|
||||||
|
I915_WRITE16(HWSTAM, 0xffff);
|
||||||
|
|
||||||
GEN2_IRQ_RESET();
|
GEN2_IRQ_RESET();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3752,7 +3753,7 @@ static void i915_irq_preinstall(struct drm_device * dev)
|
||||||
|
|
||||||
i9xx_pipestat_irq_reset(dev_priv);
|
i9xx_pipestat_irq_reset(dev_priv);
|
||||||
|
|
||||||
I915_WRITE(HWSTAM, 0xffffeffe);
|
I915_WRITE(HWSTAM, 0xffffffff);
|
||||||
|
|
||||||
GEN3_IRQ_RESET();
|
GEN3_IRQ_RESET();
|
||||||
}
|
}
|
||||||
|
@ -3873,7 +3874,7 @@ static void i965_irq_preinstall(struct drm_device * dev)
|
||||||
|
|
||||||
i9xx_pipestat_irq_reset(dev_priv);
|
i9xx_pipestat_irq_reset(dev_priv);
|
||||||
|
|
||||||
I915_WRITE(HWSTAM, 0xeffe);
|
I915_WRITE(HWSTAM, 0xffffffff);
|
||||||
|
|
||||||
GEN3_IRQ_RESET();
|
GEN3_IRQ_RESET();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user