]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/i915/irq: remove GEN3_IRQ_RESET() and GEN3_IRQ_INIT() macros
authorJani Nikula <jani.nikula@intel.com>
Wed, 2 Oct 2024 10:26:44 +0000 (13:26 +0300)
committerJani Nikula <jani.nikula@intel.com>
Thu, 3 Oct 2024 12:42:41 +0000 (15:42 +0300)
Define register offset triplets for all registers used with
GEN3_IRQ_RESET() and GEN3_IRQ_INIT() macros, and call the underlying
gen3_irq_reset() and gen3_irq_init() functions directly. Remove the
macros, along with the macro name concatenation hackery.

Reviewed-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20241002102645.136155-2-jani.nikula@intel.com
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
drivers/gpu/drm/i915/display/intel_display_irq.c
drivers/gpu/drm/i915/gt/intel_gt_irq.c
drivers/gpu/drm/i915/gt/intel_gt_regs.h
drivers/gpu/drm/i915/i915_irq.c
drivers/gpu/drm/i915/i915_irq.h
drivers/gpu/drm/i915/i915_reg.h

index a09909c3c6cdf739a8469f220ff6e7eeb07ac4be..1f6ddc66799f369eacedeb5b7bda08618acfd1c4 100644 (file)
@@ -1496,7 +1496,7 @@ void vlv_display_irq_reset(struct drm_i915_private *dev_priv)
 
        i9xx_pipestat_irq_reset(dev_priv);
 
-       GEN3_IRQ_RESET(uncore, VLV_);
+       gen3_irq_reset(uncore, VLV_IRQ_REGS);
        dev_priv->irq_mask = ~0u;
 }
 
@@ -1539,7 +1539,7 @@ void vlv_display_irq_postinstall(struct drm_i915_private *dev_priv)
 
        dev_priv->irq_mask = ~enable_mask;
 
-       GEN3_IRQ_INIT(uncore, VLV_, dev_priv->irq_mask, enable_mask);
+       gen3_irq_init(uncore, VLV_IRQ_REGS, dev_priv->irq_mask, enable_mask);
 }
 
 void gen8_display_irq_reset(struct drm_i915_private *dev_priv)
@@ -1558,8 +1558,8 @@ void gen8_display_irq_reset(struct drm_i915_private *dev_priv)
                                                   POWER_DOMAIN_PIPE(pipe)))
                        GEN8_IRQ_RESET_NDX(uncore, DE_PIPE, pipe);
 
-       GEN3_IRQ_RESET(uncore, GEN8_DE_PORT_);
-       GEN3_IRQ_RESET(uncore, GEN8_DE_MISC_);
+       gen3_irq_reset(uncore, GEN8_DE_PORT_IRQ_REGS);
+       gen3_irq_reset(uncore, GEN8_DE_MISC_IRQ_REGS);
 }
 
 void gen11_display_irq_reset(struct drm_i915_private *dev_priv)
@@ -1601,16 +1601,16 @@ void gen11_display_irq_reset(struct drm_i915_private *dev_priv)
                                                   POWER_DOMAIN_PIPE(pipe)))
                        GEN8_IRQ_RESET_NDX(uncore, DE_PIPE, pipe);
 
-       GEN3_IRQ_RESET(uncore, GEN8_DE_PORT_);
-       GEN3_IRQ_RESET(uncore, GEN8_DE_MISC_);
+       gen3_irq_reset(uncore, GEN8_DE_PORT_IRQ_REGS);
+       gen3_irq_reset(uncore, GEN8_DE_MISC_IRQ_REGS);
 
        if (DISPLAY_VER(dev_priv) >= 14)
-               GEN3_IRQ_RESET(uncore, PICAINTERRUPT_);
+               gen3_irq_reset(uncore, PICAINTERRUPT_IRQ_REGS);
        else
-               GEN3_IRQ_RESET(uncore, GEN11_DE_HPD_);
+               gen3_irq_reset(uncore, GEN11_DE_HPD_IRQ_REGS);
 
        if (INTEL_PCH_TYPE(dev_priv) >= PCH_ICP)
-               GEN3_IRQ_RESET(uncore, SDE);
+               gen3_irq_reset(uncore, SDE_IRQ_REGS);
 }
 
 void gen8_irq_power_well_post_enable(struct drm_i915_private *dev_priv,
@@ -1685,7 +1685,7 @@ static void ibx_irq_postinstall(struct drm_i915_private *dev_priv)
        else
                mask = SDE_GMBUS_CPT;
 
-       GEN3_IRQ_INIT(uncore, SDE, ~mask, 0xffffffff);
+       gen3_irq_init(uncore, SDE_IRQ_REGS, ~mask, 0xffffffff);
 }
 
 void valleyview_enable_display_irqs(struct drm_i915_private *dev_priv)
@@ -1753,7 +1753,7 @@ void ilk_de_irq_postinstall(struct drm_i915_private *i915)
 
        ibx_irq_postinstall(i915);
 
-       GEN3_IRQ_INIT(uncore, DE, i915->irq_mask,
+       gen3_irq_init(uncore, DE_IRQ_REGS, i915->irq_mask,
                      display_mask | extra_mask);
 }
 
@@ -1844,15 +1844,15 @@ void gen8_de_irq_postinstall(struct drm_i915_private *dev_priv)
                                          de_pipe_enables);
        }
 
-       GEN3_IRQ_INIT(uncore, GEN8_DE_PORT_, ~de_port_masked, de_port_enables);
-       GEN3_IRQ_INIT(uncore, GEN8_DE_MISC_, ~de_misc_masked, de_misc_masked);
+       gen3_irq_init(uncore, GEN8_DE_PORT_IRQ_REGS, ~de_port_masked, de_port_enables);
+       gen3_irq_init(uncore, GEN8_DE_MISC_IRQ_REGS, ~de_misc_masked, de_misc_masked);
 
        if (IS_DISPLAY_VER(dev_priv, 11, 13)) {
                u32 de_hpd_masked = 0;
                u32 de_hpd_enables = GEN11_DE_TC_HOTPLUG_MASK |
                                     GEN11_DE_TBT_HOTPLUG_MASK;
 
-               GEN3_IRQ_INIT(uncore, GEN11_DE_HPD_, ~de_hpd_masked,
+               gen3_irq_init(uncore, GEN11_DE_HPD_IRQ_REGS, ~de_hpd_masked,
                              de_hpd_enables);
        }
 }
@@ -1865,10 +1865,10 @@ static void mtp_irq_postinstall(struct drm_i915_private *i915)
        u32 de_hpd_enables = de_hpd_mask | XELPDP_DP_ALT_HOTPLUG_MASK |
                             XELPDP_TBT_HOTPLUG_MASK;
 
-       GEN3_IRQ_INIT(uncore, PICAINTERRUPT_, ~de_hpd_mask,
+       gen3_irq_init(uncore, PICAINTERRUPT_IRQ_REGS, ~de_hpd_mask,
                      de_hpd_enables);
 
-       GEN3_IRQ_INIT(uncore, SDE, ~sde_mask, 0xffffffff);
+       gen3_irq_init(uncore, SDE_IRQ_REGS, ~sde_mask, 0xffffffff);
 }
 
 static void icp_irq_postinstall(struct drm_i915_private *dev_priv)
@@ -1876,7 +1876,7 @@ static void icp_irq_postinstall(struct drm_i915_private *dev_priv)
        struct intel_uncore *uncore = &dev_priv->uncore;
        u32 mask = SDE_GMBUS_ICP;
 
-       GEN3_IRQ_INIT(uncore, SDE, ~mask, 0xffffffff);
+       gen3_irq_init(uncore, SDE_IRQ_REGS, ~mask, 0xffffffff);
 }
 
 void gen11_de_irq_postinstall(struct drm_i915_private *dev_priv)
index ad4c51f18d3a1826ec6f403d8e01d259a0cd25e7..fbb3117e324a59d6e529ab7f66ee55722d3865ed 100644 (file)
@@ -514,9 +514,9 @@ void gen5_gt_irq_reset(struct intel_gt *gt)
 {
        struct intel_uncore *uncore = gt->uncore;
 
-       GEN3_IRQ_RESET(uncore, GT);
+       gen3_irq_reset(uncore, GT_IRQ_REGS);
        if (GRAPHICS_VER(gt->i915) >= 6)
-               GEN3_IRQ_RESET(uncore, GEN6_PM);
+               gen3_irq_reset(uncore, GEN6_PM_IRQ_REGS);
 }
 
 void gen5_gt_irq_postinstall(struct intel_gt *gt)
@@ -538,7 +538,7 @@ void gen5_gt_irq_postinstall(struct intel_gt *gt)
        else
                gt_irqs |= GT_BLT_USER_INTERRUPT | GT_BSD_USER_INTERRUPT;
 
-       GEN3_IRQ_INIT(uncore, GT, gt->gt_imr, gt_irqs);
+       gen3_irq_init(uncore, GT_IRQ_REGS, gt->gt_imr, gt_irqs);
 
        if (GRAPHICS_VER(gt->i915) >= 6) {
                /*
@@ -551,6 +551,6 @@ void gen5_gt_irq_postinstall(struct intel_gt *gt)
                }
 
                gt->pm_imr = 0xffffffff;
-               GEN3_IRQ_INIT(uncore, GEN6_PM, gt->pm_imr, pm_irqs);
+               gen3_irq_init(uncore, GEN6_PM_IRQ_REGS, gt->pm_imr, pm_irqs);
        }
 }
index 57a3c83d3655377f3482328fd1bdc19371c2e501..04577658695ef8877799f0b9c979dc4ddab8f9f9 100644 (file)
                                                 GEN6_PM_RP_DOWN_THRESHOLD  | \
                                                 GEN6_PM_RP_DOWN_TIMEOUT)
 
+#define GEN6_PM_IRQ_REGS                       I915_IRQ_REGS(GEN6_PMIMR, \
+                                                             GEN6_PMIER, \
+                                                             GEN6_PMIIR)
+
 #define GEN7_GT_SCRATCH(i)                     _MMIO(0x4f100 + (i) * 4)
 #define   GEN7_GT_SCRATCH_REG_NUM              8
 
index db3b4f7f175977802201b2e17dad802d24e6e170..333d58343b37f17b4181d722ad8dbb406d0a1624 100644 (file)
@@ -622,7 +622,7 @@ static void ibx_irq_reset(struct drm_i915_private *dev_priv)
        if (HAS_PCH_NOP(dev_priv))
                return;
 
-       GEN3_IRQ_RESET(uncore, SDE);
+       gen3_irq_reset(uncore, SDE_IRQ_REGS);
 
        if (HAS_PCH_CPT(dev_priv) || HAS_PCH_LPT(dev_priv))
                intel_uncore_write(&dev_priv->uncore, SERR_INT, 0xffffffff);
@@ -634,7 +634,7 @@ static void ilk_irq_reset(struct drm_i915_private *dev_priv)
 {
        struct intel_uncore *uncore = &dev_priv->uncore;
 
-       GEN3_IRQ_RESET(uncore, DE);
+       gen3_irq_reset(uncore, DE_IRQ_REGS);
        dev_priv->irq_mask = ~0u;
 
        if (GRAPHICS_VER(dev_priv) == 7)
@@ -671,7 +671,7 @@ static void gen8_irq_reset(struct drm_i915_private *dev_priv)
 
        gen8_gt_irq_reset(to_gt(dev_priv));
        gen8_display_irq_reset(dev_priv);
-       GEN3_IRQ_RESET(uncore, GEN8_PCU_);
+       gen3_irq_reset(uncore, GEN8_PCU_IRQ_REGS);
 
        if (HAS_PCH_SPLIT(dev_priv))
                ibx_irq_reset(dev_priv);
@@ -688,8 +688,8 @@ static void gen11_irq_reset(struct drm_i915_private *dev_priv)
        gen11_gt_irq_reset(gt);
        gen11_display_irq_reset(dev_priv);
 
-       GEN3_IRQ_RESET(uncore, GEN11_GU_MISC_);
-       GEN3_IRQ_RESET(uncore, GEN8_PCU_);
+       gen3_irq_reset(uncore, GEN11_GU_MISC_IRQ_REGS);
+       gen3_irq_reset(uncore, GEN8_PCU_IRQ_REGS);
 }
 
 static void dg1_irq_reset(struct drm_i915_private *dev_priv)
@@ -705,8 +705,8 @@ static void dg1_irq_reset(struct drm_i915_private *dev_priv)
 
        gen11_display_irq_reset(dev_priv);
 
-       GEN3_IRQ_RESET(uncore, GEN11_GU_MISC_);
-       GEN3_IRQ_RESET(uncore, GEN8_PCU_);
+       gen3_irq_reset(uncore, GEN11_GU_MISC_IRQ_REGS);
+       gen3_irq_reset(uncore, GEN8_PCU_IRQ_REGS);
 
        intel_uncore_write(uncore, GEN11_GFX_MSTR_IRQ, ~0);
 }
@@ -720,7 +720,7 @@ static void cherryview_irq_reset(struct drm_i915_private *dev_priv)
 
        gen8_gt_irq_reset(to_gt(dev_priv));
 
-       GEN3_IRQ_RESET(uncore, GEN8_PCU_);
+       gen3_irq_reset(uncore, GEN8_PCU_IRQ_REGS);
 
        spin_lock_irq(&dev_priv->irq_lock);
        if (dev_priv->display.irq.display_irqs_enabled)
@@ -765,7 +765,7 @@ static void gen11_irq_postinstall(struct drm_i915_private *dev_priv)
        gen11_gt_irq_postinstall(gt);
        gen11_de_irq_postinstall(dev_priv);
 
-       GEN3_IRQ_INIT(uncore, GEN11_GU_MISC_, ~gu_misc_masked, gu_misc_masked);
+       gen3_irq_init(uncore, GEN11_GU_MISC_IRQ_REGS, ~gu_misc_masked, gu_misc_masked);
 
        gen11_master_intr_enable(intel_uncore_regs(uncore));
        intel_uncore_posting_read(&dev_priv->uncore, GEN11_GFX_MSTR_IRQ);
@@ -781,7 +781,7 @@ static void dg1_irq_postinstall(struct drm_i915_private *dev_priv)
        for_each_gt(gt, dev_priv, i)
                gen11_gt_irq_postinstall(gt);
 
-       GEN3_IRQ_INIT(uncore, GEN11_GU_MISC_, ~gu_misc_masked, gu_misc_masked);
+       gen3_irq_init(uncore, GEN11_GU_MISC_IRQ_REGS, ~gu_misc_masked, gu_misc_masked);
 
        dg1_de_irq_postinstall(dev_priv);
 
@@ -869,7 +869,7 @@ static void i915_irq_reset(struct drm_i915_private *dev_priv)
 
        i9xx_display_irq_reset(dev_priv);
 
-       GEN3_IRQ_RESET(uncore, GEN2_);
+       gen3_irq_reset(uncore, GEN2_IRQ_REGS);
        dev_priv->irq_mask = ~0u;
 }
 
@@ -901,7 +901,7 @@ static void i915_irq_postinstall(struct drm_i915_private *dev_priv)
                enable_mask |= I915_DISPLAY_PORT_INTERRUPT;
        }
 
-       GEN3_IRQ_INIT(uncore, GEN2_, dev_priv->irq_mask, enable_mask);
+       gen3_irq_init(uncore, GEN2_IRQ_REGS, dev_priv->irq_mask, enable_mask);
 
        /* Interrupt setup is already guaranteed to be single-threaded, this is
         * just to make the assert_spin_locked check happy. */
@@ -974,7 +974,7 @@ static void i965_irq_reset(struct drm_i915_private *dev_priv)
 
        i9xx_display_irq_reset(dev_priv);
 
-       GEN3_IRQ_RESET(uncore, GEN2_);
+       gen3_irq_reset(uncore, GEN2_IRQ_REGS);
        dev_priv->irq_mask = ~0u;
 }
 
@@ -1022,7 +1022,7 @@ static void i965_irq_postinstall(struct drm_i915_private *dev_priv)
        if (IS_G4X(dev_priv))
                enable_mask |= I915_BSD_USER_INTERRUPT;
 
-       GEN3_IRQ_INIT(uncore, GEN2_, dev_priv->irq_mask, enable_mask);
+       gen3_irq_init(uncore, GEN2_IRQ_REGS, dev_priv->irq_mask, enable_mask);
 
        /* Interrupt setup is already guaranteed to be single-threaded, this is
         * just to make the assert_spin_locked check happy. */
index 361ba46eed76d7be8f3b01aa6b4b323c8300cf74..06a38671b32bb87d53c439f1daf9538c19ca68b5 100644 (file)
@@ -55,9 +55,6 @@ void gen3_irq_init(struct intel_uncore *uncore, struct i915_irq_regs regs,
                                               GEN8_##type##_IIR(which_))); \
 })
 
-#define GEN3_IRQ_RESET(uncore, type) \
-       gen3_irq_reset((uncore), I915_IRQ_REGS(type##IMR, type##IER, type##IIR))
-
 #define GEN8_IRQ_INIT_NDX(uncore, type, which, imr_val, ier_val) \
 ({ \
        unsigned int which_ = which; \
@@ -67,8 +64,4 @@ void gen3_irq_init(struct intel_uncore *uncore, struct i915_irq_regs regs,
                      imr_val, ier_val); \
 })
 
-#define GEN3_IRQ_INIT(uncore, type, imr_val, ier_val) \
-       gen3_irq_init((uncore), I915_IRQ_REGS(type##IMR, type##IER, type##IIR), \
-                     imr_val, ier_val)
-
 #endif /* __I915_IRQ_H__ */
index 7396fc630e2952ffee137074e01063434a5258f6..818fb71f7efc37e9fc6f7639a9ffbdaf05910edf 100644 (file)
 #define GEN2_IIR       _MMIO(0x20a4)
 #define GEN2_IMR       _MMIO(0x20a8)
 #define GEN2_ISR       _MMIO(0x20ac)
+
+#define GEN2_IRQ_REGS          I915_IRQ_REGS(GEN2_IMR, \
+                                             GEN2_IER, \
+                                             GEN2_IIR)
+
 #define VLV_GUNIT_CLOCK_GATE   _MMIO(VLV_DISPLAY_BASE + 0x2060)
 #define   GINT_DIS             (1 << 22)
 #define   GCFG_DIS             (1 << 8)
 #define VLV_PCBR       _MMIO(VLV_DISPLAY_BASE + 0x2120)
 #define VLV_PCBR_ADDR_SHIFT    12
 
+#define VLV_IRQ_REGS           I915_IRQ_REGS(VLV_IMR, \
+                                             VLV_IER, \
+                                             VLV_IIR)
+
 #define   DISPLAY_PLANE_FLIP_PENDING(plane) (1 << (11 - (plane))) /* A and B only */
 #define EIR            _MMIO(0x20b0)
 #define EMR            _MMIO(0x20b4)
 #define DEIIR   _MMIO(0x44008)
 #define DEIER   _MMIO(0x4400c)
 
+#define DE_IRQ_REGS            I915_IRQ_REGS(DEIMR, \
+                                             DEIER, \
+                                             DEIIR)
+
 #define GTISR   _MMIO(0x44010)
 #define GTIMR   _MMIO(0x44014)
 #define GTIIR   _MMIO(0x44018)
 #define GTIER   _MMIO(0x4401c)
 
+#define GT_IRQ_REGS            I915_IRQ_REGS(GTIMR, \
+                                             GTIER, \
+                                             GTIIR)
+
 #define GEN8_MASTER_IRQ                        _MMIO(0x44200)
 #define  GEN8_MASTER_IRQ_CONTROL       (1 << 31)
 #define  GEN8_PCU_IRQ                  (1 << 30)
 #define  TGL_DE_PORT_AUX_DDIB          REG_BIT(1)
 #define  TGL_DE_PORT_AUX_DDIA          REG_BIT(0)
 
+#define GEN8_DE_PORT_IRQ_REGS          I915_IRQ_REGS(GEN8_DE_PORT_IMR, \
+                                                     GEN8_DE_PORT_IER, \
+                                                     GEN8_DE_PORT_IIR)
+
 #define GEN8_DE_MISC_ISR _MMIO(0x44460)
 #define GEN8_DE_MISC_IMR _MMIO(0x44464)
 #define GEN8_DE_MISC_IIR _MMIO(0x44468)
 #define  GEN8_DE_EDP_PSR               REG_BIT(19)
 #define  XELPDP_PMDEMAND_RSP           REG_BIT(3)
 
+#define GEN8_DE_MISC_IRQ_REGS          I915_IRQ_REGS(GEN8_DE_MISC_IMR, \
+                                                     GEN8_DE_MISC_IER, \
+                                                     GEN8_DE_MISC_IIR)
+
 #define GEN8_PCU_ISR _MMIO(0x444e0)
 #define GEN8_PCU_IMR _MMIO(0x444e4)
 #define GEN8_PCU_IIR _MMIO(0x444e8)
 #define GEN8_PCU_IER _MMIO(0x444ec)
 
+#define GEN8_PCU_IRQ_REGS              I915_IRQ_REGS(GEN8_PCU_IMR, \
+                                                     GEN8_PCU_IER, \
+                                                     GEN8_PCU_IIR)
+
 #define GEN11_GU_MISC_ISR      _MMIO(0x444f0)
 #define GEN11_GU_MISC_IMR      _MMIO(0x444f4)
 #define GEN11_GU_MISC_IIR      _MMIO(0x444f8)
 #define GEN11_GU_MISC_IER      _MMIO(0x444fc)
 #define  GEN11_GU_MISC_GSE     (1 << 27)
 
+#define GEN11_GU_MISC_IRQ_REGS         I915_IRQ_REGS(GEN11_GU_MISC_IMR, \
+                                                     GEN11_GU_MISC_IER, \
+                                                     GEN11_GU_MISC_IIR)
+
 #define GEN11_GFX_MSTR_IRQ             _MMIO(0x190010)
 #define  GEN11_MASTER_IRQ              (1 << 31)
 #define  GEN11_PCU_IRQ                 (1 << 30)
                                                 GEN11_TBT_HOTPLUG(HPD_PORT_TC2) | \
                                                 GEN11_TBT_HOTPLUG(HPD_PORT_TC1))
 
+#define GEN11_DE_HPD_IRQ_REGS          I915_IRQ_REGS(GEN11_DE_HPD_IMR, \
+                                                     GEN11_DE_HPD_IER, \
+                                                     GEN11_DE_HPD_IIR)
+
 #define GEN11_TBT_HOTPLUG_CTL                          _MMIO(0x44030)
 #define GEN11_TC_HOTPLUG_CTL                           _MMIO(0x44038)
 #define  GEN11_HOTPLUG_CTL_ENABLE(hpd_pin)             (8 << (_HPD_PIN_TC(hpd_pin) * 4))
 #define  XELPDP_TBT_HOTPLUG(hpd_pin)           REG_BIT(_HPD_PIN_TC(hpd_pin))
 #define  XELPDP_TBT_HOTPLUG_MASK               REG_GENMASK(3, 0)
 
+#define PICAINTERRUPT_IRQ_REGS                 I915_IRQ_REGS(PICAINTERRUPT_IMR, \
+                                                             PICAINTERRUPT_IER, \
+                                                             PICAINTERRUPT_IIR)
+
 #define XELPDP_PORT_HOTPLUG_CTL(hpd_pin)       _MMIO(0x16F270 + (_HPD_PIN_TC(hpd_pin) * 0x200))
 #define  XELPDP_TBT_HOTPLUG_ENABLE             REG_BIT(6)
 #define  XELPDP_TBT_HPD_LONG_DETECT            REG_BIT(5)
 #define SDEIIR  _MMIO(0xc4008)
 #define SDEIER  _MMIO(0xc400c)
 
+#define SDE_IRQ_REGS                   I915_IRQ_REGS(SDEIMR, \
+                                                     SDEIER, \
+                                                     SDEIIR)
+
 #define SERR_INT                       _MMIO(0xc4040)
 #define  SERR_INT_POISON               (1 << 31)
 #define  SERR_INT_TRANS_FIFO_UNDERRUN(pipe)    (1 << ((pipe) * 3))