From: Paulo Zanoni <paulo.r.zanoni@xxxxxxxxx> The long-term goal is to make preinstall and uninstall almost the same thing, so we will be able to call uninstall and then postinstall if needed. Signed-off-by: Paulo Zanoni <paulo.r.zanoni@xxxxxxxxx> --- drivers/gpu/drm/i915/i915_irq.c | 35 ++++++++++++++++------------------- 1 file changed, 16 insertions(+), 19 deletions(-) diff --git a/drivers/gpu/drm/i915/i915_irq.c b/drivers/gpu/drm/i915/i915_irq.c index 37420b5..400aa63 100644 --- a/drivers/gpu/drm/i915/i915_irq.c +++ b/drivers/gpu/drm/i915/i915_irq.c @@ -79,16 +79,13 @@ static const u32 hpd_status_i915[] = { /* i915 and valleyview are the same */ [HPD_PORT_D] = PORTD_HOTPLUG_INT_STATUS }; -#define INTEL_IRQ_REG_RESET(type, do_iir) do { \ +#define INTEL_IRQ_REG_RESET(type) do { \ I915_WRITE(type##MR, 0xffffffff); \ I915_WRITE(type##ER, 0); \ - POSTING_READ(type##ER); \ - if (do_iir) { \ + I915_WRITE(type##IR, 0xffffffff); \ + if (I915_READ(type##IR)) { \ I915_WRITE(type##IR, 0xffffffff); \ - if (I915_READ(type##IR)) { \ - I915_WRITE(type##IR, 0xffffffff); \ - POSTING_READ(type##IR); \ - } \ + POSTING_READ(type##IR); \ } \ } while (0) @@ -2024,10 +2021,10 @@ static void gen5_gt_irq_preinstall(struct drm_device *dev) { struct drm_i915_private *dev_priv = dev->dev_private; - INTEL_IRQ_REG_RESET(GTI, false); + INTEL_IRQ_REG_RESET(GTI); if (INTEL_INFO(dev)->gen >= 6) - INTEL_IRQ_REG_RESET(GEN6_PMI, false); + INTEL_IRQ_REG_RESET(GEN6_PMI); } /* drm_dma.h hooks @@ -2040,7 +2037,7 @@ static void ironlake_irq_preinstall(struct drm_device *dev) I915_WRITE(HWSTAM, 0xeffe); - INTEL_IRQ_REG_RESET(DEI, false); + INTEL_IRQ_REG_RESET(DEI); gen5_gt_irq_preinstall(dev); @@ -2072,7 +2069,7 @@ static void valleyview_irq_preinstall(struct drm_device *dev) I915_WRITE(PORT_HOTPLUG_STAT, I915_READ(PORT_HOTPLUG_STAT)); for_each_pipe(pipe) I915_WRITE(PIPESTAT(pipe), 0xffff); - INTEL_IRQ_REG_RESET(VLV_I, true); + INTEL_IRQ_REG_RESET(VLV_I); } static void ibx_hpd_irq_setup(struct drm_device *dev) @@ -2282,7 +2279,7 @@ static void valleyview_irq_uninstall(struct drm_device *dev) I915_WRITE(PORT_HOTPLUG_STAT, I915_READ(PORT_HOTPLUG_STAT)); for_each_pipe(pipe) I915_WRITE(PIPESTAT(pipe), 0xffff); - INTEL_IRQ_REG_RESET(VLV_I, true); + INTEL_IRQ_REG_RESET(VLV_I); } static void ironlake_irq_uninstall(struct drm_device *dev) @@ -2296,16 +2293,16 @@ static void ironlake_irq_uninstall(struct drm_device *dev) I915_WRITE(HWSTAM, 0xffffffff); - INTEL_IRQ_REG_RESET(DEI, true); + INTEL_IRQ_REG_RESET(DEI); if (IS_GEN7(dev)) I915_WRITE(GEN7_ERR_INT, I915_READ(GEN7_ERR_INT)); - INTEL_IRQ_REG_RESET(GTI, true); + INTEL_IRQ_REG_RESET(GTI); if (HAS_PCH_NOP(dev)) return; - INTEL_IRQ_REG_RESET(SDEI, true); + INTEL_IRQ_REG_RESET(SDEI); if (HAS_PCH_CPT(dev) || HAS_PCH_LPT(dev)) I915_WRITE(SERR_INT, I915_READ(SERR_INT)); } @@ -2479,7 +2476,7 @@ static void i915_irq_preinstall(struct drm_device * dev) I915_WRITE16(HWSTAM, 0xeffe); for_each_pipe(pipe) I915_WRITE(PIPESTAT(pipe), 0); - INTEL_IRQ_REG_RESET(I, false); + INTEL_IRQ_REG_RESET(I); } static int i915_irq_postinstall(struct drm_device *dev) @@ -2678,7 +2675,7 @@ static void i915_irq_uninstall(struct drm_device * dev) I915_WRITE(PIPESTAT(pipe), I915_READ(PIPESTAT(pipe))); } - INTEL_IRQ_REG_RESET(I, true); + INTEL_IRQ_REG_RESET(I); } static void i965_irq_preinstall(struct drm_device * dev) @@ -2694,7 +2691,7 @@ static void i965_irq_preinstall(struct drm_device * dev) I915_WRITE(HWSTAM, 0xeffe); for_each_pipe(pipe) I915_WRITE(PIPESTAT(pipe), 0); - INTEL_IRQ_REG_RESET(I, false); + INTEL_IRQ_REG_RESET(I); } static int i965_irq_postinstall(struct drm_device *dev) @@ -2919,7 +2916,7 @@ static void i965_irq_uninstall(struct drm_device * dev) I915_WRITE(HWSTAM, 0xffffffff); for_each_pipe(pipe) I915_WRITE(PIPESTAT(pipe), 0); - INTEL_IRQ_REG_RESET(I, true); + INTEL_IRQ_REG_RESET(I); for_each_pipe(pipe) I915_WRITE(PIPESTAT(pipe), -- 1.8.1.2 _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/intel-gfx