]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/i915/display: define and use intel_reg_{offset, equal, valid}() helpers
authorJani Nikula <jani.nikula@intel.com>
Tue, 5 May 2026 09:16:48 +0000 (12:16 +0300)
committerJani Nikula <jani.nikula@intel.com>
Wed, 13 May 2026 13:03:18 +0000 (16:03 +0300)
Add display specific helpers for getting the register offset, checking
for equality and validity. Add them as static inlines for increased type
safety.

Reviewed-by: Michał Grzelak <michal.grzelak@intel.com>
Acked-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patch.msgid.link/7fe12d4e5465778209ccf29359767a197b031dd9.1777972548.git.jani.nikula@intel.com
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
drivers/gpu/drm/i915/display/intel_de.h
drivers/gpu/drm/i915/display/intel_display_device.c
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_types.h
drivers/gpu/drm/i915/display/intel_dmc.c
drivers/gpu/drm/i915/display/intel_dmc_wl.c
drivers/gpu/drm/i915/display/intel_dpll_mgr.c
drivers/gpu/drm/i915/display/intel_dsb.c
drivers/gpu/drm/i915/display/intel_mchbar.c
drivers/gpu/drm/i915/display/intel_pps.c

index d17f14843f98fe3e1b37bce6dd7dce12880a6ef0..1029790194296297d69c8434e97e397e2faa4ae3 100644 (file)
@@ -56,7 +56,7 @@ intel_de_read64_2x32_volatile(struct intel_display *display,
 static inline u64
 intel_de_read64_2x32(struct intel_display *display, intel_reg_t reg)
 {
-       intel_reg_t upper_reg = _MMIO(i915_mmio_reg_offset(reg) + 4);
+       intel_reg_t upper_reg = _MMIO(intel_reg_offset(reg) + 4);
        u32 lower, upper;
 
        lower = intel_de_read(display, reg);
index 7260990038dd59a1679a388bca74a30c2910a2d3..69a9f782935cf6ffdefac1a450e6a8db2aac14f4 100644 (file)
@@ -1525,7 +1525,7 @@ probe_gmdid_display(struct intel_display *display, struct intel_display_ip_ver *
        u32 val;
        int i;
 
-       addr = pci_iomap_range(pdev, 0, i915_mmio_reg_offset(GMD_ID_DISPLAY), sizeof(u32));
+       addr = pci_iomap_range(pdev, 0, intel_reg_offset(GMD_ID_DISPLAY), sizeof(u32));
        if (!addr) {
                drm_err(display->drm,
                        "Cannot map MMIO BAR to read display GMD_ID\n");
index b679992cb1e673b4ebc70f3d95e50d17e5c40510..27fb72e5cefb381d19e319f248432727b86248d7 100644 (file)
@@ -56,7 +56,7 @@ static void assert_iir_is_zero(struct intel_display *display, intel_reg_t reg)
 
        drm_WARN(display->drm, 1,
                 "Interrupt register 0x%x is not zero: 0x%08x\n",
-                i915_mmio_reg_offset(reg), val);
+                intel_reg_offset(reg), val);
        intel_de_write(display, reg, 0xffffffff);
        intel_de_posting_read(display, reg);
        intel_de_write(display, reg, 0xffffffff);
index a56f8ed055f6f84fc254bfc61748ce04302927ee..9220fcbfcb2441b7e8cb185811185a0b53341a63 100644 (file)
 
 typedef i915_reg_t intel_reg_t;
 
+static inline u32 intel_reg_offset(intel_reg_t r)
+{
+       return r.reg;
+}
+
+static inline bool intel_reg_equal(intel_reg_t a, intel_reg_t b)
+{
+       return intel_reg_offset(a) == intel_reg_offset(b);
+}
+
+static inline bool intel_reg_valid(intel_reg_t r)
+{
+       return !intel_reg_equal(r, INVALID_MMIO_REG);
+}
+
 /* A triplet for IMR/IER/IIR registers. */
 struct intel_irq_regs {
        intel_reg_t imr;
index 7fcee3ee319cf5ea5c00b231444ae71ee03b6c56..c9e69f8a3626f77c9abbe6d72e75928b66778c83 100644 (file)
@@ -2117,7 +2117,7 @@ static inline bool intel_encoder_is_dp(struct intel_encoder *encoder)
                return true;
        case INTEL_OUTPUT_DDI:
                /* Skip pure HDMI/DVI DDI encoders */
-               return i915_mmio_reg_valid(enc_to_intel_dp(encoder)->output_reg);
+               return intel_reg_valid(enc_to_intel_dp(encoder)->output_reg);
        default:
                return false;
        }
@@ -2130,7 +2130,7 @@ static inline bool intel_encoder_is_hdmi(struct intel_encoder *encoder)
                return true;
        case INTEL_OUTPUT_DDI:
                /* See if the HDMI encoder is valid. */
-               return i915_mmio_reg_valid(enc_to_intel_hdmi(encoder)->hdmi_reg);
+               return intel_reg_valid(enc_to_intel_hdmi(encoder)->hdmi_reg);
        default:
                return false;
        }
index 6a39ad19b33925c514a29eb07d1029bbca6b251f..481fb65b7110279f72ccf0b50af73277c683540e 100644 (file)
@@ -540,9 +540,9 @@ static u32 dmc_evt_ctl_disable(u32 dmc_evt_ctl)
 static bool is_dmc_evt_ctl_reg(struct intel_display *display,
                               enum intel_dmc_id dmc_id, intel_reg_t reg)
 {
-       u32 offset = i915_mmio_reg_offset(reg);
-       u32 start = i915_mmio_reg_offset(DMC_EVT_CTL(display, dmc_id, 0));
-       u32 end = i915_mmio_reg_offset(DMC_EVT_CTL(display, dmc_id, DMC_EVENT_HANDLER_COUNT_GEN12));
+       u32 offset = intel_reg_offset(reg);
+       u32 start = intel_reg_offset(DMC_EVT_CTL(display, dmc_id, 0));
+       u32 end = intel_reg_offset(DMC_EVT_CTL(display, dmc_id, DMC_EVENT_HANDLER_COUNT_GEN12));
 
        return offset >= start && offset < end;
 }
@@ -550,9 +550,9 @@ static bool is_dmc_evt_ctl_reg(struct intel_display *display,
 static bool is_dmc_evt_htp_reg(struct intel_display *display,
                               enum intel_dmc_id dmc_id, intel_reg_t reg)
 {
-       u32 offset = i915_mmio_reg_offset(reg);
-       u32 start = i915_mmio_reg_offset(DMC_EVT_HTP(display, dmc_id, 0));
-       u32 end = i915_mmio_reg_offset(DMC_EVT_HTP(display, dmc_id, DMC_EVENT_HANDLER_COUNT_GEN12));
+       u32 offset = intel_reg_offset(reg);
+       u32 start = intel_reg_offset(DMC_EVT_HTP(display, dmc_id, 0));
+       u32 end = intel_reg_offset(DMC_EVT_HTP(display, dmc_id, DMC_EVENT_HANDLER_COUNT_GEN12));
 
        return offset >= start && offset < end;
 }
@@ -578,8 +578,8 @@ static bool fixup_dmc_evt(struct intel_display *display,
                return false;
 
        /* make sure reg_ctl and reg_htp are for the same event */
-       if (i915_mmio_reg_offset(reg_ctl) - i915_mmio_reg_offset(DMC_EVT_CTL(display, dmc_id, 0)) !=
-           i915_mmio_reg_offset(reg_htp) - i915_mmio_reg_offset(DMC_EVT_HTP(display, dmc_id, 0)))
+       if (intel_reg_offset(reg_ctl) - intel_reg_offset(DMC_EVT_CTL(display, dmc_id, 0)) !=
+           intel_reg_offset(reg_htp) - intel_reg_offset(DMC_EVT_HTP(display, dmc_id, 0)))
                return false;
 
        /*
@@ -703,7 +703,7 @@ static void assert_dmc_loaded(struct intel_display *display,
 
                drm_WARN(display->drm, found != expected,
                         "DMC %d mmio[%d]/0x%x incorrect (expected 0x%x, current 0x%x)\n",
-                        dmc_id, i, i915_mmio_reg_offset(reg), expected, found);
+                        dmc_id, i, intel_reg_offset(reg), expected, found);
        }
 }
 
@@ -1146,17 +1146,17 @@ static u32 parse_dmc_fw_header(struct intel_dmc *dmc,
 
                drm_dbg_kms(display->drm,
                            " mmio[%d]: 0x%x = 0x%x->0x%x (EVT_CTL)\n",
-                           i, i915_mmio_reg_offset(dmc_info->mmioaddr[i]),
+                           i, intel_reg_offset(dmc_info->mmioaddr[i]),
                            orig_mmiodata[0], dmc_info->mmiodata[i]);
                drm_dbg_kms(display->drm,
                            " mmio[%d]: 0x%x = 0x%x->0x%x (EVT_HTP)\n",
-                           i+1, i915_mmio_reg_offset(dmc_info->mmioaddr[i+1]),
+                           i+1, intel_reg_offset(dmc_info->mmioaddr[i+1]),
                            orig_mmiodata[1], dmc_info->mmiodata[i+1]);
        }
 
        for (i = 0; i < mmio_count; i++) {
                drm_dbg_kms(display->drm, " mmio[%d]: 0x%x = 0x%x%s%s\n",
-                           i, i915_mmio_reg_offset(dmc_info->mmioaddr[i]), dmc_info->mmiodata[i],
+                           i, intel_reg_offset(dmc_info->mmioaddr[i]), dmc_info->mmiodata[i],
                            is_dmc_evt_ctl_reg(display, dmc_id, dmc_info->mmioaddr[i]) ? " (EVT_CTL)" :
                            is_dmc_evt_htp_reg(display, dmc_id, dmc_info->mmioaddr[i]) ? " (EVT_HTP)" : "",
                            disable_dmc_evt(display, dmc_id, dmc_info->mmioaddr[i],
@@ -1672,7 +1672,7 @@ static int intel_dmc_debugfs_status_show(struct seq_file *m, void *unused)
        if (intel_dmc_get_dc6_allowed_count(display, &dc6_allowed_count))
                seq_printf(m, "DC5 -> DC6 allowed count: %d\n",
                           dc6_allowed_count);
-       else if (i915_mmio_reg_valid(dc6_reg))
+       else if (intel_reg_valid(dc6_reg))
                seq_printf(m, "DC5 -> DC6 count: %d\n",
                           intel_de_read(display, dc6_reg));
 
index 82afb60fa9734c478027e2ebddb1a9cce627db64..605a4a5556018e48b8d7e9a6d233ce2fd32bd6c3 100644 (file)
@@ -227,7 +227,7 @@ static void __intel_dmc_wl_take(struct intel_display *display)
 static bool intel_dmc_wl_reg_in_range(intel_reg_t reg,
                                      const struct intel_dmc_wl_range ranges[])
 {
-       u32 offset = i915_mmio_reg_offset(reg);
+       u32 offset = intel_reg_offset(reg);
 
        for (int i = 0; ranges[i].start; i++) {
                u32 end = ranges[i].end ?: ranges[i].start;
@@ -441,7 +441,7 @@ void intel_dmc_wl_get(struct intel_display *display, intel_reg_t reg)
 
        spin_lock_irqsave(&wl->lock, flags);
 
-       if (i915_mmio_reg_valid(reg) &&
+       if (intel_reg_valid(reg) &&
            !intel_dmc_wl_check_range(display, reg, wl->dc_state))
                goto out_unlock;
 
@@ -474,7 +474,7 @@ void intel_dmc_wl_put(struct intel_display *display, intel_reg_t reg)
 
        spin_lock_irqsave(&wl->lock, flags);
 
-       if (i915_mmio_reg_valid(reg) &&
+       if (intel_reg_valid(reg) &&
            !intel_dmc_wl_check_range(display, reg, wl->dc_state))
                goto out_unlock;
 
index 6acdfa97deaa78491372a1cb42889ef4228cd0d3..e2e2a1c2a6e37a82da3898bf9a33f302adadc38f 100644 (file)
@@ -3842,9 +3842,9 @@ static void icl_dpll_write(struct intel_display *display,
        intel_de_write(display, cfgcr0_reg, hw_state->cfgcr0);
        intel_de_write(display, cfgcr1_reg, hw_state->cfgcr1);
        drm_WARN_ON_ONCE(display->drm, display->vbt.override_afc_startup &&
-                        !i915_mmio_reg_valid(div0_reg));
+                        !intel_reg_valid(div0_reg));
        if (display->vbt.override_afc_startup &&
-           i915_mmio_reg_valid(div0_reg))
+           intel_reg_valid(div0_reg))
                intel_de_rmw(display, div0_reg,
                             TGL_DPLL0_DIV0_AFC_STARTUP_MASK, hw_state->div0);
        intel_de_posting_read(display, cfgcr1_reg);
index ce4d452ae695bcdf7ba00885201a9bc66eeba3d3..fec8a56e21eafe7b75754bef3875892a305fff9a 100644 (file)
@@ -341,7 +341,7 @@ static bool intel_dsb_prev_ins_is_write(struct intel_dsb *dsb,
        prev_opcode = dsb->ins[1] & ~DSB_REG_VALUE_MASK;
        prev_reg =  dsb->ins[1] & DSB_REG_VALUE_MASK;
 
-       return prev_opcode == opcode && prev_reg == i915_mmio_reg_offset(reg);
+       return prev_opcode == opcode && prev_reg == intel_reg_offset(reg);
 }
 
 static bool intel_dsb_prev_ins_is_indexed_write(struct intel_dsb *dsb, intel_reg_t reg)
@@ -386,7 +386,7 @@ void intel_dsb_reg_write_indexed(struct intel_dsb *dsb,
        if (!intel_dsb_prev_ins_is_indexed_write(dsb, reg))
                intel_dsb_emit(dsb, 0, /* count */
                               (DSB_OPCODE_INDEXED_WRITE << DSB_OPCODE_SHIFT) |
-                              i915_mmio_reg_offset(reg));
+                              intel_reg_offset(reg));
 
        if (!assert_dsb_has_room(dsb))
                return;
@@ -407,7 +407,7 @@ void intel_dsb_reg_write(struct intel_dsb *dsb,
        intel_dsb_emit(dsb, val,
                       (DSB_OPCODE_MMIO_WRITE << DSB_OPCODE_SHIFT) |
                       (DSB_BYTE_EN << DSB_BYTE_EN_SHIFT) |
-                      i915_mmio_reg_offset(reg));
+                      intel_reg_offset(reg));
 }
 
 static u32 intel_dsb_mask_to_byte_en(u32 mask)
@@ -425,7 +425,7 @@ void intel_dsb_reg_write_masked(struct intel_dsb *dsb,
        intel_dsb_emit(dsb, val,
                       (DSB_OPCODE_MMIO_WRITE << DSB_OPCODE_SHIFT) |
                       (intel_dsb_mask_to_byte_en(mask) << DSB_BYTE_EN_SHIFT) |
-                      i915_mmio_reg_offset(reg));
+                      intel_reg_offset(reg));
 }
 
 void intel_dsb_noop(struct intel_dsb *dsb, int count)
@@ -565,7 +565,7 @@ void intel_dsb_poll(struct intel_dsb *dsb,
 
        intel_dsb_emit(dsb, val,
                       (DSB_OPCODE_POLL << DSB_OPCODE_SHIFT) |
-                      i915_mmio_reg_offset(reg));
+                      intel_reg_offset(reg));
 }
 
 static void intel_dsb_align_tail(struct intel_dsb *dsb)
index 8cfcee4a08a419c9abb12e8068c6659f012b8543..a3a69e11c390e8079e0f839ec5db27c1e15c795e 100644 (file)
@@ -44,7 +44,7 @@ static u32 mchbar_mirror_len(struct intel_display *display)
 static bool is_mchbar_reg(struct intel_display *display, intel_reg_t reg)
 {
        return has_mchbar_mirror(display) &&
-               in_range32(i915_mmio_reg_offset(reg),
+               in_range32(intel_reg_offset(reg),
                           mchbar_mirror_base(display),
                           mchbar_mirror_len(display));
 }
@@ -53,7 +53,7 @@ static void assert_is_mchbar_reg(struct intel_display *display, intel_reg_t reg)
 {
        drm_WARN(display->drm, !is_mchbar_reg(display, reg),
                 "Reading non-MCHBAR register 0x%x\n",
-                i915_mmio_reg_offset(reg));
+                intel_reg_offset(reg));
 }
 
 u16 intel_mchbar_read16(struct intel_display *display, intel_reg_t reg)
index ea5e8f75acef4bf70b9f19ac314ecb66e2f37c3f..d4c98b150fa2b7c9736cf5071e67ac55d73f17cb 100644 (file)
@@ -1388,7 +1388,7 @@ intel_pps_readout_hw_state(struct intel_dp *intel_dp, struct intel_pps_delays *s
        seq->backlight_off = REG_FIELD_GET(PANEL_LIGHT_OFF_DELAY_MASK, pp_off);
        seq->power_down = REG_FIELD_GET(PANEL_POWER_DOWN_DELAY_MASK, pp_off);
 
-       if (i915_mmio_reg_valid(regs.pp_div)) {
+       if (intel_reg_valid(regs.pp_div)) {
                u32 pp_div;
 
                pp_div = intel_de_read(display, regs.pp_div);
@@ -1647,7 +1647,7 @@ static void pps_init_registers(struct intel_dp *intel_dp, bool force_disable_vdd
        /*
         * Compute the divisor for the pp clock, simply match the Bspec formula.
         */
-       if (i915_mmio_reg_valid(regs.pp_div))
+       if (intel_reg_valid(regs.pp_div))
                intel_de_write(display, regs.pp_div,
                               REG_FIELD_PREP(PP_REFERENCE_DIVIDER_MASK,
                                              (100 * div) / 2 - 1) |
@@ -1662,7 +1662,7 @@ static void pps_init_registers(struct intel_dp *intel_dp, bool force_disable_vdd
                    "panel power sequencer register settings: PP_ON %#x, PP_OFF %#x, PP_DIV %#x\n",
                    intel_de_read(display, regs.pp_on),
                    intel_de_read(display, regs.pp_off),
-                   i915_mmio_reg_valid(regs.pp_div) ?
+                   intel_reg_valid(regs.pp_div) ?
                    intel_de_read(display, regs.pp_div) :
                    (intel_de_read(display, regs.pp_ctrl) & BXT_POWER_CYCLE_DELAY_MASK));
 }