]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
drm/i915/display: add struct intel_irq_regs and use it
authorJani Nikula <jani.nikula@intel.com>
Tue, 5 May 2026 09:16:46 +0000 (12:16 +0300)
committerJani Nikula <jani.nikula@intel.com>
Wed, 13 May 2026 13:03:17 +0000 (16:03 +0300)
Add struct intel_irq_regs, a display version of struct i915_irq_regs,
and use it. The goal is to reduce the dependency on i915 core types and
headers.

Reviewed-by: Michał Grzelak <michal.grzelak@intel.com>
Acked-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patch.msgid.link/56118c2e40e171e898034a7bea6c8d14f515f5c1.1777972548.git.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/display/intel_display_reg_defs.h
drivers/gpu/drm/i915/display/intel_display_regs.h

index 9bd72a99db2b83d5c277a9d47d3ffa5b51e88032..0c9c21b1290be193d273fe3a008a14965c6e12f3 100644 (file)
@@ -30,7 +30,7 @@
 #include "intel_psr.h"
 #include "intel_psr_regs.h"
 
-static void irq_reset(struct intel_display *display, struct i915_irq_regs regs)
+static void irq_reset(struct intel_display *display, struct intel_irq_regs regs)
 {
        intel_de_write(display, regs.imr, 0xffffffff);
        intel_de_posting_read(display, regs.imr);
@@ -63,7 +63,7 @@ static void assert_iir_is_zero(struct intel_display *display, intel_reg_t reg)
        intel_de_posting_read(display, reg);
 }
 
-static void irq_init(struct intel_display *display, struct i915_irq_regs regs,
+static void irq_init(struct intel_display *display, struct intel_irq_regs regs,
                     u32 imr_val, u32 ier_val)
 {
        assert_iir_is_zero(display, regs.iir);
index cb46863693cd7715cd06f8e29bf0c4776f54d1de..d044967aa6d971be2b1d50e33750a20d0d1feaf0 100644 (file)
 
 typedef i915_reg_t intel_reg_t;
 
+/* A triplet for IMR/IER/IIR registers. */
+struct intel_irq_regs {
+       intel_reg_t imr;
+       intel_reg_t ier;
+       intel_reg_t iir;
+};
+
+#define INTEL_IRQ_REGS(_imr, _ier, _iir) \
+       ((const struct intel_irq_regs){ .imr = (_imr), .ier = (_ier), .iir = (_iir) })
+
 #define VLV_DISPLAY_BASE               0x180000
 
 /*
index bc508995ad8bc3df597852d7bca2ef4076bab923..d1387d98e36497b778a63f873de9d147cd743922 100644 (file)
 #define   ERR_INT_FIFO_UNDERRUN_A      (1 << 0)
 #define   ERR_INT_FIFO_UNDERRUN(pipe)  (1 << ((pipe) * 3))
 
-#define VLV_IRQ_REGS           I915_IRQ_REGS(VLV_IMR, \
-                                             VLV_IER, \
-                                             VLV_IIR)
+#define VLV_IRQ_REGS           INTEL_IRQ_REGS(VLV_IMR, \
+                                              VLV_IER, \
+                                              VLV_IIR)
 
 #define VLV_EIR                _MMIO(VLV_DISPLAY_BASE + 0x20b0)
 #define VLV_EMR                _MMIO(VLV_DISPLAY_BASE + 0x20b4)
 #define DEIIR   _MMIO(0x44008)
 #define DEIER   _MMIO(0x4400c)
 
-#define DE_IRQ_REGS            I915_IRQ_REGS(DEIMR, \
-                                             DEIER, \
-                                             DEIIR)
+#define DE_IRQ_REGS            INTEL_IRQ_REGS(DEIMR, \
+                                              DEIER, \
+                                              DEIIR)
 
 #define DIGITAL_PORT_HOTPLUG_CNTRL     _MMIO(0x44030)
 #define  DIGITAL_PORTA_HOTPLUG_ENABLE          (1 << 4)
 #define  GEN8_PIPE_VSYNC               REG_BIT(1)
 #define  GEN8_PIPE_VBLANK              REG_BIT(0)
 
-#define GEN8_DE_PIPE_IRQ_REGS(pipe)    I915_IRQ_REGS(GEN8_DE_PIPE_IMR(pipe), \
-                                                     GEN8_DE_PIPE_IER(pipe), \
-                                                     GEN8_DE_PIPE_IIR(pipe))
+#define GEN8_DE_PIPE_IRQ_REGS(pipe)    INTEL_IRQ_REGS(GEN8_DE_PIPE_IMR(pipe), \
+                                                      GEN8_DE_PIPE_IER(pipe), \
+                                                      GEN8_DE_PIPE_IIR(pipe))
 
 #define _HPD_PIN_DDI(hpd_pin)  ((hpd_pin) - HPD_PORT_A)
 #define _HPD_PIN_TC(hpd_pin)   ((hpd_pin) - HPD_PORT_TC1)
 #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_PORT_IRQ_REGS          INTEL_IRQ_REGS(GEN8_DE_PORT_IMR, \
+                                                      GEN8_DE_PORT_IER, \
+                                                      GEN8_DE_PORT_IIR)
 
 /* interrupts */
 #define DE_MASTER_IRQ_CONTROL   (1 << 31)
 #define  XELPDP_PMDEMAND_RSP           REG_BIT(3)
 #define  XE2LPD_DBUF_OVERLAP_DETECTED  REG_BIT(1)
 
-#define GEN8_DE_MISC_IRQ_REGS          I915_IRQ_REGS(GEN8_DE_MISC_IMR, \
-                                                     GEN8_DE_MISC_IER, \
-                                                     GEN8_DE_MISC_IIR)
+#define GEN8_DE_MISC_IRQ_REGS          INTEL_IRQ_REGS(GEN8_DE_MISC_IMR, \
+                                                      GEN8_DE_MISC_IER, \
+                                                      GEN8_DE_MISC_IIR)
 
 #define GEN11_DISPLAY_INT_CTL          _MMIO(0x44200)
 #define  GEN11_DISPLAY_IRQ_ENABLE      (1 << 31)
                                                 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_DE_HPD_IRQ_REGS          INTEL_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  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 PICAINTERRUPT_IRQ_REGS                 INTEL_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 SDEIIR  _MMIO(0xc4008)
 #define SDEIER  _MMIO(0xc400c)
 
-#define SDE_IRQ_REGS                   I915_IRQ_REGS(SDEIMR, \
-                                                     SDEIER, \
-                                                     SDEIIR)
+#define SDE_IRQ_REGS                   INTEL_IRQ_REGS(SDEIMR, \
+                                                      SDEIER, \
+                                                      SDEIIR)
 
 #define SERR_INT                       _MMIO(0xc4040)
 #define  SERR_INT_POISON               (1 << 31)