> -----Original Message-----
> From: Intel-gfx <[email protected]> On Behalf Of Jani
> Nikula
> Sent: Tuesday, March 11, 2025 11:31 PM
> To: [email protected]; [email protected]
> Cc: Nikula, Jani <[email protected]>
> Subject: [PATCH 6/9] drm/i915/hotplug: convert intel_hotplug_irq.[ch] to 
> struct
> intel_display
> 
> Going forward, struct intel_display is the main display device data
> pointer. Convert as much as possible of intel_hotplug_irq.[ch] to struct
> intel_display.

Looks Good to me.
Reviewed-by: Uma Shankar <[email protected]>

> Signed-off-by: Jani Nikula <[email protected]>
> ---
>  drivers/gpu/drm/i915/display/intel_crt.c      |   4 +-
>  .../gpu/drm/i915/display/intel_display_irq.c  |  33 +-
>  drivers/gpu/drm/i915/display/intel_hotplug.c  |   6 +-
>  .../gpu/drm/i915/display/intel_hotplug_irq.c  | 474 +++++++++---------
>  .../gpu/drm/i915/display/intel_hotplug_irq.h  |  28 +-
>  drivers/gpu/drm/i915/i915_irq.c               |  18 +-
>  6 files changed, 276 insertions(+), 287 deletions(-)
> 
> diff --git a/drivers/gpu/drm/i915/display/intel_crt.c
> b/drivers/gpu/drm/i915/display/intel_crt.c
> index bca91d49cb96..a7f360f89410 100644
> --- a/drivers/gpu/drm/i915/display/intel_crt.c
> +++ b/drivers/gpu/drm/i915/display/intel_crt.c
> @@ -606,7 +606,7 @@ static bool intel_crt_detect_hotplug(struct
> drm_connector *connector)
> 
>       for (i = 0; i < tries ; i++) {
>               /* turn on the FORCE_DETECT */
> -             i915_hotplug_interrupt_update(dev_priv,
> +             i915_hotplug_interrupt_update(display,
>                                             CRT_HOTPLUG_FORCE_DETECT,
>                                             CRT_HOTPLUG_FORCE_DETECT);
>               /* wait for FORCE_DETECT to go off */
> @@ -624,7 +624,7 @@ static bool intel_crt_detect_hotplug(struct
> drm_connector *connector)
>       intel_de_write(display, PORT_HOTPLUG_STAT(display),
>                      CRT_HOTPLUG_INT_STATUS);
> 
> -     i915_hotplug_interrupt_update(dev_priv,
> CRT_HOTPLUG_FORCE_DETECT, 0);
> +     i915_hotplug_interrupt_update(display, CRT_HOTPLUG_FORCE_DETECT,
> 0);
> 
>       return ret;
>  }
> diff --git a/drivers/gpu/drm/i915/display/intel_display_irq.c
> b/drivers/gpu/drm/i915/display/intel_display_irq.c
> index aa23bb817805..b37bcb8fb2e8 100644
> --- a/drivers/gpu/drm/i915/display/intel_display_irq.c
> +++ b/drivers/gpu/drm/i915/display/intel_display_irq.c
> @@ -675,7 +675,7 @@ static void ibx_irq_handler(struct drm_i915_private
> *dev_priv, u32 pch_iir)
>       enum pipe pipe;
>       u32 hotplug_trigger = pch_iir & SDE_HOTPLUG_MASK;
> 
> -     ibx_hpd_irq_handler(dev_priv, hotplug_trigger);
> +     ibx_hpd_irq_handler(display, hotplug_trigger);
> 
>       if (pch_iir & SDE_AUDIO_POWER_MASK) {
>               int port = ffs((pch_iir & SDE_AUDIO_POWER_MASK) >>
> @@ -812,7 +812,7 @@ static void cpt_irq_handler(struct drm_i915_private
> *dev_priv, u32 pch_iir)
>       enum pipe pipe;
>       u32 hotplug_trigger = pch_iir & SDE_HOTPLUG_MASK_CPT;
> 
> -     ibx_hpd_irq_handler(dev_priv, hotplug_trigger);
> +     ibx_hpd_irq_handler(display, hotplug_trigger);
> 
>       if (pch_iir & SDE_AUDIO_POWER_MASK_CPT) {
>               int port = ffs((pch_iir & SDE_AUDIO_POWER_MASK_CPT) >>
> @@ -901,7 +901,7 @@ void ilk_display_irq_handler(struct drm_i915_private
> *dev_priv, u32 de_iir)
>       u32 hotplug_trigger = de_iir & DE_DP_A_HOTPLUG;
> 
>       if (hotplug_trigger)
> -             ilk_hpd_irq_handler(dev_priv, hotplug_trigger);
> +             ilk_hpd_irq_handler(display, hotplug_trigger);
> 
>       if (de_iir & DE_AUX_CHANNEL_A)
>               intel_dp_aux_irq_handler(display);
> @@ -953,7 +953,7 @@ void ivb_display_irq_handler(struct drm_i915_private
> *dev_priv, u32 de_iir)
>       u32 hotplug_trigger = de_iir & DE_DP_A_HOTPLUG_IVB;
> 
>       if (hotplug_trigger)
> -             ilk_hpd_irq_handler(dev_priv, hotplug_trigger);
> +             ilk_hpd_irq_handler(display, hotplug_trigger);
> 
>       if (de_iir & DE_ERR_INT_IVB)
>               ivb_err_int_handler(dev_priv);
> @@ -1382,7 +1382,7 @@ void gen8_de_irq_handler(struct drm_i915_private
> *dev_priv, u32 master_ctl)
>               iir = intel_de_read(display, GEN11_DE_HPD_IIR);
>               if (iir) {
>                       intel_de_write(display, GEN11_DE_HPD_IIR, iir);
> -                     gen11_hpd_irq_handler(dev_priv, iir);
> +                     gen11_hpd_irq_handler(display, iir);
>               } else {
>                       drm_err_ratelimited(&dev_priv->drm,
>                                           "The master control interrupt lied,
> (DE HPD)!\n");
> @@ -1405,14 +1405,14 @@ void gen8_de_irq_handler(struct drm_i915_private
> *dev_priv, u32 master_ctl)
>                               u32 hotplug_trigger = iir &
> BXT_DE_PORT_HOTPLUG_MASK;
> 
>                               if (hotplug_trigger) {
> -                                     bxt_hpd_irq_handler(dev_priv,
> hotplug_trigger);
> +                                     bxt_hpd_irq_handler(display,
> hotplug_trigger);
>                                       found = true;
>                               }
>                       } else if (IS_BROADWELL(dev_priv)) {
>                               u32 hotplug_trigger = iir &
> BDW_DE_PORT_HOTPLUG_MASK;
> 
>                               if (hotplug_trigger) {
> -                                     ilk_hpd_irq_handler(dev_priv,
> hotplug_trigger);
> +                                     ilk_hpd_irq_handler(display,
> hotplug_trigger);
>                                       found = true;
>                               }
>                       }
> @@ -1498,12 +1498,12 @@ void gen8_de_irq_handler(struct drm_i915_private
> *dev_priv, u32 master_ctl)
>               gen8_read_and_ack_pch_irqs(dev_priv, &iir, &pica_iir);
>               if (iir) {
>                       if (pica_iir)
> -                             xelpdp_pica_irq_handler(dev_priv, pica_iir);
> +                             xelpdp_pica_irq_handler(display, pica_iir);
> 
>                       if (INTEL_PCH_TYPE(dev_priv) >= PCH_ICP)
> -                             icp_irq_handler(dev_priv, iir);
> +                             icp_irq_handler(display, iir);
>                       else if (INTEL_PCH_TYPE(dev_priv) >= PCH_SPT)
> -                             spt_irq_handler(dev_priv, iir);
> +                             spt_irq_handler(display, iir);
>                       else
>                               cpt_irq_handler(dev_priv, iir);
>               } else {
> @@ -1904,7 +1904,7 @@ static void _vlv_display_irq_reset(struct
> drm_i915_private *dev_priv)
>       gen2_error_reset(to_intel_uncore(display->drm),
>                        VLV_ERROR_REGS);
> 
> -     i915_hotplug_interrupt_update_locked(dev_priv, 0xffffffff, 0);
> +     i915_hotplug_interrupt_update_locked(display, 0xffffffff, 0);
>       intel_de_rmw(display, PORT_HOTPLUG_STAT(dev_priv), 0, 0);
> 
>       i9xx_pipestat_irq_reset(dev_priv);
> @@ -1924,7 +1924,7 @@ void i9xx_display_irq_reset(struct drm_i915_private
> *i915)
>       struct intel_display *display = &i915->display;
> 
>       if (I915_HAS_HOTPLUG(i915)) {
> -             i915_hotplug_interrupt_update(i915, 0xffffffff, 0);
> +             i915_hotplug_interrupt_update(display, 0xffffffff, 0);
>               intel_de_rmw(display, PORT_HOTPLUG_STAT(i915), 0, 0);
>       }
> 
> @@ -2348,10 +2348,11 @@ void dg1_de_irq_postinstall(struct drm_i915_private
> *i915)
> 
>  void intel_display_irq_init(struct drm_i915_private *i915)
>  {
> -     i915->drm.vblank_disable_immediate = true;
> +     struct intel_display *display = &i915->display;
> +
> +     display->drm->vblank_disable_immediate = true;
> 
> -     intel_hotplug_irq_init(i915);
> +     intel_hotplug_irq_init(display);
> 
> -     INIT_WORK(&i915->display.irq.vblank_dc_work,
> -               intel_display_vblank_dc_work);
> +     INIT_WORK(&display->irq.vblank_dc_work,
> intel_display_vblank_dc_work);
>  }
> diff --git a/drivers/gpu/drm/i915/display/intel_hotplug.c
> b/drivers/gpu/drm/i915/display/intel_hotplug.c
> index 7683b3ce124d..fcc3f546cb97 100644
> --- a/drivers/gpu/drm/i915/display/intel_hotplug.c
> +++ b/drivers/gpu/drm/i915/display/intel_hotplug.c
> @@ -305,7 +305,7 @@ static void intel_hpd_irq_storm_reenable_work(struct
> work_struct *work)
>                       display->hotplug.stats[pin].state = HPD_ENABLED;
>       }
> 
> -     intel_hpd_irq_setup(dev_priv);
> +     intel_hpd_irq_setup(display);
> 
>       spin_unlock_irq(&dev_priv->irq_lock);
> 
> @@ -696,7 +696,7 @@ void intel_hpd_irq_handler(struct intel_display *display,
>        * happens later in our hotplug work.
>        */
>       if (storm_detected)
> -             intel_hpd_irq_setup(dev_priv);
> +             intel_hpd_irq_setup(display);
> 
>       /*
>        * Our hotplug handler can grab modeset locks (by calling down into the
> @@ -745,7 +745,7 @@ void intel_hpd_init(struct intel_display *display)
>        * just to make the assert_spin_locked checks happy.
>        */
>       spin_lock_irq(&dev_priv->irq_lock);
> -     intel_hpd_irq_setup(dev_priv);
> +     intel_hpd_irq_setup(display);
>       spin_unlock_irq(&dev_priv->irq_lock);
>  }
> 
> diff --git a/drivers/gpu/drm/i915/display/intel_hotplug_irq.c
> b/drivers/gpu/drm/i915/display/intel_hotplug_irq.c
> index f24c65478742..e44ae6acc55f 100644
> --- a/drivers/gpu/drm/i915/display/intel_hotplug_irq.c
> +++ b/drivers/gpu/drm/i915/display/intel_hotplug_irq.c
> @@ -131,30 +131,31 @@ static const u32 hpd_mtp[HPD_NUM_PINS] = {
>       [HPD_PORT_TC4] = SDE_TC_HOTPLUG_ICP(HPD_PORT_TC4),
>  };
> 
> -static void intel_hpd_init_pins(struct drm_i915_private *dev_priv)
> +static void intel_hpd_init_pins(struct intel_display *display)
>  {
> -     struct intel_hotplug *hpd = &dev_priv->display.hotplug;
> +     struct drm_i915_private *dev_priv = to_i915(display->drm);
> +     struct intel_hotplug *hpd = &display->hotplug;
> 
> -     if (HAS_GMCH(dev_priv)) {
> -             if (IS_G4X(dev_priv) || IS_VALLEYVIEW(dev_priv) ||
> -                 IS_CHERRYVIEW(dev_priv))
> +     if (HAS_GMCH(display)) {
> +             if (display->platform.g4x || display->platform.valleyview ||
> +                 display->platform.cherryview)
>                       hpd->hpd = hpd_status_g4x;
>               else
>                       hpd->hpd = hpd_status_i915;
>               return;
>       }
> 
> -     if (DISPLAY_VER(dev_priv) >= 14)
> +     if (DISPLAY_VER(display) >= 14)
>               hpd->hpd = hpd_xelpdp;
> -     else if (DISPLAY_VER(dev_priv) >= 11)
> +     else if (DISPLAY_VER(display) >= 11)
>               hpd->hpd = hpd_gen11;
> -     else if (IS_GEMINILAKE(dev_priv) || IS_BROXTON(dev_priv))
> +     else if (display->platform.geminilake || display->platform.broxton)
>               hpd->hpd = hpd_bxt;
> -     else if (DISPLAY_VER(dev_priv) == 9)
> +     else if (DISPLAY_VER(display) == 9)
>               hpd->hpd = NULL; /* no north HPD on SKL */
> -     else if (DISPLAY_VER(dev_priv) >= 8)
> +     else if (DISPLAY_VER(display) >= 8)
>               hpd->hpd = hpd_bdw;
> -     else if (DISPLAY_VER(dev_priv) >= 7)
> +     else if (DISPLAY_VER(display) >= 7)
>               hpd->hpd = hpd_ivb;
>       else
>               hpd->hpd = hpd_ilk;
> @@ -180,20 +181,20 @@ static void intel_hpd_init_pins(struct drm_i915_private
> *dev_priv)
>  }
> 
>  /* For display hotplug interrupt */
> -void i915_hotplug_interrupt_update_locked(struct drm_i915_private *dev_priv,
> +void i915_hotplug_interrupt_update_locked(struct intel_display *display,
>                                         u32 mask, u32 bits)
>  {
> -     struct intel_display *display = &dev_priv->display;
> +     struct drm_i915_private *dev_priv = to_i915(display->drm);
> 
>       lockdep_assert_held(&dev_priv->irq_lock);
> -     drm_WARN_ON(&dev_priv->drm, bits & ~mask);
> +     drm_WARN_ON(display->drm, bits & ~mask);
> 
>       intel_de_rmw(display, PORT_HOTPLUG_EN(display), mask, bits);
>  }
> 
>  /**
>   * i915_hotplug_interrupt_update - update hotplug interrupt enable
> - * @dev_priv: driver private
> + * @display: display device
>   * @mask: bits to update
>   * @bits: bits to enable
>   * NOTE: the HPD enable bits are modified both inside and outside
> @@ -203,12 +204,14 @@ void i915_hotplug_interrupt_update_locked(struct
> drm_i915_private *dev_priv,
>   * held already, this function acquires the lock itself. A non-locking
>   * version is also available.
>   */
> -void i915_hotplug_interrupt_update(struct drm_i915_private *dev_priv,
> +void i915_hotplug_interrupt_update(struct intel_display *display,
>                                  u32 mask,
>                                  u32 bits)
>  {
> +     struct drm_i915_private *dev_priv = to_i915(display->drm);
> +
>       spin_lock_irq(&dev_priv->irq_lock);
> -     i915_hotplug_interrupt_update_locked(dev_priv, mask, bits);
> +     i915_hotplug_interrupt_update_locked(display, mask, bits);
>       spin_unlock_irq(&dev_priv->irq_lock);
>  }
> 
> @@ -340,7 +343,7 @@ static bool i9xx_port_hotplug_long_detect(enum hpd_pin
> pin, u32 val)
>   *
>   * Note that the caller is expected to zero out the masks initially.
>   */
> -static void intel_get_hpd_pins(struct drm_i915_private *dev_priv,
> +static void intel_get_hpd_pins(struct intel_display *display,
>                              u32 *pin_mask, u32 *long_mask,
>                              u32 hotplug_trigger, u32 dig_hotplug_reg,
>                              const u32 hpd[HPD_NUM_PINS],
> @@ -360,37 +363,37 @@ static void intel_get_hpd_pins(struct drm_i915_private
> *dev_priv,
>                       *long_mask |= BIT(pin);
>       }
> 
> -     drm_dbg(&dev_priv->drm,
> -             "hotplug event received, stat 0x%08x, dig 0x%08x, pins 0x%08x,
> long 0x%08x\n",
> -             hotplug_trigger, dig_hotplug_reg, *pin_mask, *long_mask);
> +     drm_dbg_kms(display->drm,
> +                 "hotplug event received, stat 0x%08x, dig 0x%08x, pins
> 0x%08x, long 0x%08x\n",
> +                 hotplug_trigger, dig_hotplug_reg, *pin_mask, *long_mask);
>  }
> 
> -static u32 intel_hpd_enabled_irqs(struct drm_i915_private *dev_priv,
> +static u32 intel_hpd_enabled_irqs(struct intel_display *display,
>                                 const u32 hpd[HPD_NUM_PINS])
>  {
>       struct intel_encoder *encoder;
>       u32 enabled_irqs = 0;
> 
> -     for_each_intel_encoder(&dev_priv->drm, encoder)
> -             if (dev_priv->display.hotplug.stats[encoder->hpd_pin].state ==
> HPD_ENABLED)
> +     for_each_intel_encoder(display->drm, encoder)
> +             if (display->hotplug.stats[encoder->hpd_pin].state ==
> HPD_ENABLED)
>                       enabled_irqs |= hpd[encoder->hpd_pin];
> 
>       return enabled_irqs;
>  }
> 
> -static u32 intel_hpd_hotplug_irqs(struct drm_i915_private *dev_priv,
> +static u32 intel_hpd_hotplug_irqs(struct intel_display *display,
>                                 const u32 hpd[HPD_NUM_PINS])
>  {
>       struct intel_encoder *encoder;
>       u32 hotplug_irqs = 0;
> 
> -     for_each_intel_encoder(&dev_priv->drm, encoder)
> +     for_each_intel_encoder(display->drm, encoder)
>               hotplug_irqs |= hpd[encoder->hpd_pin];
> 
>       return hotplug_irqs;
>  }
> 
> -static u32 intel_hpd_hotplug_mask(struct drm_i915_private *i915,
> +static u32 intel_hpd_hotplug_mask(struct intel_display *display,
>                                 hotplug_mask_func hotplug_mask)
>  {
>       enum hpd_pin pin;
> @@ -402,26 +405,25 @@ static u32 intel_hpd_hotplug_mask(struct
> drm_i915_private *i915,
>       return hotplug;
>  }
> 
> -static u32 intel_hpd_hotplug_enables(struct drm_i915_private *i915,
> +static u32 intel_hpd_hotplug_enables(struct intel_display *display,
>                                    hotplug_enables_func hotplug_enables)
>  {
>       struct intel_encoder *encoder;
>       u32 hotplug = 0;
> 
> -     for_each_intel_encoder(&i915->drm, encoder)
> +     for_each_intel_encoder(display->drm, encoder)
>               hotplug |= hotplug_enables(encoder);
> 
>       return hotplug;
>  }
> 
> -u32 i9xx_hpd_irq_ack(struct drm_i915_private *dev_priv)
> +u32 i9xx_hpd_irq_ack(struct intel_display *display)
>  {
> -     struct intel_display *display = &dev_priv->display;
>       u32 hotplug_status = 0, hotplug_status_mask;
>       int i;
> 
> -     if (IS_G4X(dev_priv) ||
> -         IS_VALLEYVIEW(dev_priv) || IS_CHERRYVIEW(dev_priv))
> +     if (display->platform.g4x ||
> +         display->platform.valleyview || display->platform.cherryview)
>               hotplug_status_mask = HOTPLUG_INT_STATUS_G4X |
>                       DP_AUX_CHANNEL_MASK_INT_STATUS_G4X;
>       else
> @@ -448,43 +450,41 @@ u32 i9xx_hpd_irq_ack(struct drm_i915_private
> *dev_priv)
>                              hotplug_status);
>       }
> 
> -     drm_WARN_ONCE(&dev_priv->drm, 1,
> +     drm_WARN_ONCE(display->drm, 1,
>                     "PORT_HOTPLUG_STAT did not clear (0x%08x)\n",
>                     intel_de_read(display, PORT_HOTPLUG_STAT(display)));
> 
>       return hotplug_status;
>  }
> 
> -void i9xx_hpd_irq_handler(struct drm_i915_private *dev_priv, u32
> hotplug_status)
> +void i9xx_hpd_irq_handler(struct intel_display *display, u32 hotplug_status)
>  {
> -     struct intel_display *display = &dev_priv->display;
>       u32 pin_mask = 0, long_mask = 0;
>       u32 hotplug_trigger;
> 
> -     if (IS_G4X(dev_priv) ||
> -         IS_VALLEYVIEW(dev_priv) || IS_CHERRYVIEW(dev_priv))
> +     if (display->platform.g4x ||
> +         display->platform.valleyview || display->platform.cherryview)
>               hotplug_trigger = hotplug_status & HOTPLUG_INT_STATUS_G4X;
>       else
>               hotplug_trigger = hotplug_status & HOTPLUG_INT_STATUS_I915;
> 
>       if (hotplug_trigger) {
> -             intel_get_hpd_pins(dev_priv, &pin_mask, &long_mask,
> +             intel_get_hpd_pins(display, &pin_mask, &long_mask,
>                                  hotplug_trigger, hotplug_trigger,
> -                                dev_priv->display.hotplug.hpd,
> +                                display->hotplug.hpd,
>                                  i9xx_port_hotplug_long_detect);
> 
>               intel_hpd_irq_handler(display, pin_mask, long_mask);
>       }
> 
> -     if ((IS_G4X(dev_priv) ||
> -          IS_VALLEYVIEW(dev_priv) || IS_CHERRYVIEW(dev_priv)) &&
> +     if ((display->platform.g4x ||
> +          display->platform.valleyview || display->platform.cherryview) &&
>           hotplug_status & DP_AUX_CHANNEL_MASK_INT_STATUS_G4X)
>               intel_dp_aux_irq_handler(display);
>  }
> 
> -void ibx_hpd_irq_handler(struct drm_i915_private *dev_priv, u32
> hotplug_trigger)
> +void ibx_hpd_irq_handler(struct intel_display *display, u32 hotplug_trigger)
>  {
> -     struct intel_display *display = &dev_priv->display;
>       u32 dig_hotplug_reg, pin_mask = 0, long_mask = 0;
> 
>       /*
> @@ -506,44 +506,43 @@ void ibx_hpd_irq_handler(struct drm_i915_private
> *dev_priv, u32 hotplug_trigger)
>       if (!hotplug_trigger)
>               return;
> 
> -     intel_get_hpd_pins(dev_priv, &pin_mask, &long_mask,
> +     intel_get_hpd_pins(display, &pin_mask, &long_mask,
>                          hotplug_trigger, dig_hotplug_reg,
> -                        dev_priv->display.hotplug.pch_hpd,
> +                        display->hotplug.pch_hpd,
>                          pch_port_hotplug_long_detect);
> 
>       intel_hpd_irq_handler(display, pin_mask, long_mask);
>  }
> 
> -void xelpdp_pica_irq_handler(struct drm_i915_private *i915, u32 iir)
> +void xelpdp_pica_irq_handler(struct intel_display *display, u32 iir)
>  {
> -     struct intel_display *display = &i915->display;
>       enum hpd_pin pin;
>       u32 hotplug_trigger = iir & (XELPDP_DP_ALT_HOTPLUG_MASK |
> XELPDP_TBT_HOTPLUG_MASK);
>       u32 trigger_aux = iir & XELPDP_AUX_TC_MASK;
>       u32 pin_mask = 0, long_mask = 0;
> 
> -     if (DISPLAY_VER(i915) >= 20)
> +     if (DISPLAY_VER(display) >= 20)
>               trigger_aux |= iir & XE2LPD_AUX_DDI_MASK;
> 
>       for (pin = HPD_PORT_TC1; pin <= HPD_PORT_TC4; pin++) {
>               u32 val;
> 
> -             if (!(i915->display.hotplug.hpd[pin] & hotplug_trigger))
> +             if (!(display->hotplug.hpd[pin] & hotplug_trigger))
>                       continue;
> 
>               pin_mask |= BIT(pin);
> 
> -             val = intel_de_read(i915, XELPDP_PORT_HOTPLUG_CTL(pin));
> -             intel_de_write(i915, XELPDP_PORT_HOTPLUG_CTL(pin), val);
> +             val = intel_de_read(display, XELPDP_PORT_HOTPLUG_CTL(pin));
> +             intel_de_write(display, XELPDP_PORT_HOTPLUG_CTL(pin), val);
> 
>               if (val & (XELPDP_DP_ALT_HPD_LONG_DETECT |
> XELPDP_TBT_HPD_LONG_DETECT))
>                       long_mask |= BIT(pin);
>       }
> 
>       if (pin_mask) {
> -             drm_dbg(&i915->drm,
> -                     "pica hotplug event received, stat 0x%08x, pins 0x%08x,
> long 0x%08x\n",
> -                     hotplug_trigger, pin_mask, long_mask);
> +             drm_dbg_kms(display->drm,
> +                         "pica hotplug event received, stat 0x%08x, pins
> 0x%08x, long 0x%08x\n",
> +                         hotplug_trigger, pin_mask, long_mask);
> 
>               intel_hpd_irq_handler(display, pin_mask, long_mask);
>       }
> @@ -552,13 +551,13 @@ void xelpdp_pica_irq_handler(struct drm_i915_private
> *i915, u32 iir)
>               intel_dp_aux_irq_handler(display);
> 
>       if (!pin_mask && !trigger_aux)
> -             drm_err(&i915->drm,
> +             drm_err(display->drm,
>                       "Unexpected DE HPD/AUX interrupt 0x%08x\n", iir);
>  }
> 
> -void icp_irq_handler(struct drm_i915_private *dev_priv, u32 pch_iir)
> +void icp_irq_handler(struct intel_display *display, u32 pch_iir)
>  {
> -     struct intel_display *display = &dev_priv->display;
> +     struct drm_i915_private *dev_priv = to_i915(display->drm);
>       u32 ddi_hotplug_trigger = pch_iir & SDE_DDI_HOTPLUG_MASK_ICP;
>       u32 tc_hotplug_trigger = pch_iir & SDE_TC_HOTPLUG_MASK_ICP;
>       u32 pin_mask = 0, long_mask = 0;
> @@ -571,9 +570,9 @@ void icp_irq_handler(struct drm_i915_private *dev_priv,
> u32 pch_iir)
>               dig_hotplug_reg = intel_de_rmw(display, SHOTPLUG_CTL_DDI, 0,
> 0);
>               spin_unlock(&dev_priv->irq_lock);
> 
> -             intel_get_hpd_pins(dev_priv, &pin_mask, &long_mask,
> +             intel_get_hpd_pins(display, &pin_mask, &long_mask,
>                                  ddi_hotplug_trigger, dig_hotplug_reg,
> -                                dev_priv->display.hotplug.pch_hpd,
> +                                display->hotplug.pch_hpd,
>                                  icp_ddi_port_hotplug_long_detect);
>       }
> 
> @@ -582,9 +581,9 @@ void icp_irq_handler(struct drm_i915_private *dev_priv,
> u32 pch_iir)
> 
>               dig_hotplug_reg = intel_de_rmw(display, SHOTPLUG_CTL_TC, 0,
> 0);
> 
> -             intel_get_hpd_pins(dev_priv, &pin_mask, &long_mask,
> +             intel_get_hpd_pins(display, &pin_mask, &long_mask,
>                                  tc_hotplug_trigger, dig_hotplug_reg,
> -                                dev_priv->display.hotplug.pch_hpd,
> +                                display->hotplug.pch_hpd,
>                                  icp_tc_port_hotplug_long_detect);
>       }
> 
> @@ -595,9 +594,8 @@ void icp_irq_handler(struct drm_i915_private *dev_priv,
> u32 pch_iir)
>               intel_gmbus_irq_handler(display);
>  }
> 
> -void spt_irq_handler(struct drm_i915_private *dev_priv, u32 pch_iir)
> +void spt_irq_handler(struct intel_display *display, u32 pch_iir)
>  {
> -     struct intel_display *display = &dev_priv->display;
>       u32 hotplug_trigger = pch_iir & SDE_HOTPLUG_MASK_SPT &
>               ~SDE_PORTE_HOTPLUG_SPT;
>       u32 hotplug2_trigger = pch_iir & SDE_PORTE_HOTPLUG_SPT;
> @@ -608,9 +606,9 @@ void spt_irq_handler(struct drm_i915_private *dev_priv,
> u32 pch_iir)
> 
>               dig_hotplug_reg = intel_de_rmw(display, PCH_PORT_HOTPLUG,
> 0, 0);
> 
> -             intel_get_hpd_pins(dev_priv, &pin_mask, &long_mask,
> +             intel_get_hpd_pins(display, &pin_mask, &long_mask,
>                                  hotplug_trigger, dig_hotplug_reg,
> -                                dev_priv->display.hotplug.pch_hpd,
> +                                display->hotplug.pch_hpd,
>                                  spt_port_hotplug_long_detect);
>       }
> 
> @@ -619,9 +617,9 @@ void spt_irq_handler(struct drm_i915_private *dev_priv,
> u32 pch_iir)
> 
>               dig_hotplug_reg = intel_de_rmw(display, PCH_PORT_HOTPLUG2,
> 0, 0);
> 
> -             intel_get_hpd_pins(dev_priv, &pin_mask, &long_mask,
> +             intel_get_hpd_pins(display, &pin_mask, &long_mask,
>                                  hotplug2_trigger, dig_hotplug_reg,
> -                                dev_priv->display.hotplug.pch_hpd,
> +                                display->hotplug.pch_hpd,
>                                  spt_port_hotplug2_long_detect);
>       }
> 
> @@ -632,39 +630,36 @@ void spt_irq_handler(struct drm_i915_private
> *dev_priv, u32 pch_iir)
>               intel_gmbus_irq_handler(display);
>  }
> 
> -void ilk_hpd_irq_handler(struct drm_i915_private *dev_priv, u32
> hotplug_trigger)
> +void ilk_hpd_irq_handler(struct intel_display *display, u32 hotplug_trigger)
>  {
> -     struct intel_display *display = &dev_priv->display;
>       u32 dig_hotplug_reg, pin_mask = 0, long_mask = 0;
> 
>       dig_hotplug_reg = intel_de_rmw(display,
> DIGITAL_PORT_HOTPLUG_CNTRL, 0, 0);
> 
> -     intel_get_hpd_pins(dev_priv, &pin_mask, &long_mask,
> +     intel_get_hpd_pins(display, &pin_mask, &long_mask,
>                          hotplug_trigger, dig_hotplug_reg,
> -                        dev_priv->display.hotplug.hpd,
> +                        display->hotplug.hpd,
>                          ilk_port_hotplug_long_detect);
> 
>       intel_hpd_irq_handler(display, pin_mask, long_mask);
>  }
> 
> -void bxt_hpd_irq_handler(struct drm_i915_private *dev_priv, u32
> hotplug_trigger)
> +void bxt_hpd_irq_handler(struct intel_display *display, u32 hotplug_trigger)
>  {
> -     struct intel_display *display = &dev_priv->display;
>       u32 dig_hotplug_reg, pin_mask = 0, long_mask = 0;
> 
>       dig_hotplug_reg = intel_de_rmw(display, PCH_PORT_HOTPLUG, 0, 0);
> 
> -     intel_get_hpd_pins(dev_priv, &pin_mask, &long_mask,
> +     intel_get_hpd_pins(display, &pin_mask, &long_mask,
>                          hotplug_trigger, dig_hotplug_reg,
> -                        dev_priv->display.hotplug.hpd,
> +                        display->hotplug.hpd,
>                          bxt_port_hotplug_long_detect);
> 
>       intel_hpd_irq_handler(display, pin_mask, long_mask);
>  }
> 
> -void gen11_hpd_irq_handler(struct drm_i915_private *dev_priv, u32 iir)
> +void gen11_hpd_irq_handler(struct intel_display *display, u32 iir)
>  {
> -     struct intel_display *display = &dev_priv->display;
>       u32 pin_mask = 0, long_mask = 0;
>       u32 trigger_tc = iir & GEN11_DE_TC_HOTPLUG_MASK;
>       u32 trigger_tbt = iir & GEN11_DE_TBT_HOTPLUG_MASK;
> @@ -674,9 +669,9 @@ void gen11_hpd_irq_handler(struct drm_i915_private
> *dev_priv, u32 iir)
> 
>               dig_hotplug_reg = intel_de_rmw(display,
> GEN11_TC_HOTPLUG_CTL, 0, 0);
> 
> -             intel_get_hpd_pins(dev_priv, &pin_mask, &long_mask,
> +             intel_get_hpd_pins(display, &pin_mask, &long_mask,
>                                  trigger_tc, dig_hotplug_reg,
> -                                dev_priv->display.hotplug.hpd,
> +                                display->hotplug.hpd,
>                                  gen11_port_hotplug_long_detect);
>       }
> 
> @@ -685,16 +680,16 @@ void gen11_hpd_irq_handler(struct drm_i915_private
> *dev_priv, u32 iir)
> 
>               dig_hotplug_reg = intel_de_rmw(display,
> GEN11_TBT_HOTPLUG_CTL, 0, 0);
> 
> -             intel_get_hpd_pins(dev_priv, &pin_mask, &long_mask,
> +             intel_get_hpd_pins(display, &pin_mask, &long_mask,
>                                  trigger_tbt, dig_hotplug_reg,
> -                                dev_priv->display.hotplug.hpd,
> +                                display->hotplug.hpd,
>                                  gen11_port_hotplug_long_detect);
>       }
> 
>       if (pin_mask)
>               intel_hpd_irq_handler(display, pin_mask, long_mask);
>       else
> -             drm_err(&dev_priv->drm,
> +             drm_err(display->drm,
>                       "Unexpected DE HPD interrupt 0x%08x\n", iir);
>  }
> 
> @@ -740,18 +735,16 @@ static u32 ibx_hotplug_enables(struct intel_encoder
> *encoder)
>       }
>  }
> 
> -static void ibx_hpd_detection_setup(struct drm_i915_private *dev_priv)
> +static void ibx_hpd_detection_setup(struct intel_display *display)
>  {
> -     struct intel_display *display = &dev_priv->display;
> -
>       /*
>        * Enable digital hotplug on the PCH, and configure the DP short pulse
>        * duration to 2ms (which is the minimum in the Display Port spec).
>        * The pulse duration bits are reserved on LPT+.
>        */
>       intel_de_rmw(display, PCH_PORT_HOTPLUG,
> -                  intel_hpd_hotplug_mask(dev_priv, ibx_hotplug_mask),
> -                  intel_hpd_hotplug_enables(dev_priv, ibx_hotplug_enables));
> +                  intel_hpd_hotplug_mask(display, ibx_hotplug_mask),
> +                  intel_hpd_hotplug_enables(display, ibx_hotplug_enables));
>  }
> 
>  static void ibx_hpd_enable_detection(struct intel_encoder *encoder)
> @@ -763,16 +756,17 @@ static void ibx_hpd_enable_detection(struct
> intel_encoder *encoder)
>                    ibx_hotplug_enables(encoder));
>  }
> 
> -static void ibx_hpd_irq_setup(struct drm_i915_private *dev_priv)
> +static void ibx_hpd_irq_setup(struct intel_display *display)
>  {
> +     struct drm_i915_private *dev_priv = to_i915(display->drm);
>       u32 hotplug_irqs, enabled_irqs;
> 
> -     enabled_irqs = intel_hpd_enabled_irqs(dev_priv, dev_priv-
> >display.hotplug.pch_hpd);
> -     hotplug_irqs = intel_hpd_hotplug_irqs(dev_priv, dev_priv-
> >display.hotplug.pch_hpd);
> +     enabled_irqs = intel_hpd_enabled_irqs(display, display-
> >hotplug.pch_hpd);
> +     hotplug_irqs = intel_hpd_hotplug_irqs(display, 
> display->hotplug.pch_hpd);
> 
>       ibx_display_interrupt_update(dev_priv, hotplug_irqs, enabled_irqs);
> 
> -     ibx_hpd_detection_setup(dev_priv);
> +     ibx_hpd_detection_setup(display);
>  }
> 
>  static u32 icp_ddi_hotplug_mask(enum hpd_pin hpd_pin)
> @@ -813,13 +807,11 @@ static u32 icp_tc_hotplug_enables(struct
> intel_encoder *encoder)
>       return icp_tc_hotplug_mask(encoder->hpd_pin);
>  }
> 
> -static void icp_ddi_hpd_detection_setup(struct drm_i915_private *dev_priv)
> +static void icp_ddi_hpd_detection_setup(struct intel_display *display)
>  {
> -     struct intel_display *display = &dev_priv->display;
> -
>       intel_de_rmw(display, SHOTPLUG_CTL_DDI,
> -                  intel_hpd_hotplug_mask(dev_priv, icp_ddi_hotplug_mask),
> -                  intel_hpd_hotplug_enables(dev_priv,
> icp_ddi_hotplug_enables));
> +                  intel_hpd_hotplug_mask(display, icp_ddi_hotplug_mask),
> +                  intel_hpd_hotplug_enables(display,
> icp_ddi_hotplug_enables));
>  }
> 
>  static void icp_ddi_hpd_enable_detection(struct intel_encoder *encoder)
> @@ -831,13 +823,11 @@ static void icp_ddi_hpd_enable_detection(struct
> intel_encoder *encoder)
>                    icp_ddi_hotplug_enables(encoder));
>  }
> 
> -static void icp_tc_hpd_detection_setup(struct drm_i915_private *dev_priv)
> +static void icp_tc_hpd_detection_setup(struct intel_display *display)
>  {
> -     struct intel_display *display = &dev_priv->display;
> -
>       intel_de_rmw(display, SHOTPLUG_CTL_TC,
> -                  intel_hpd_hotplug_mask(dev_priv, icp_tc_hotplug_mask),
> -                  intel_hpd_hotplug_enables(dev_priv,
> icp_tc_hotplug_enables));
> +                  intel_hpd_hotplug_mask(display, icp_tc_hotplug_mask),
> +                  intel_hpd_hotplug_enables(display, 
> icp_tc_hotplug_enables));
>  }
> 
>  static void icp_tc_hpd_enable_detection(struct intel_encoder *encoder)
> @@ -855,13 +845,13 @@ static void icp_hpd_enable_detection(struct
> intel_encoder *encoder)
>       icp_tc_hpd_enable_detection(encoder);
>  }
> 
> -static void icp_hpd_irq_setup(struct drm_i915_private *dev_priv)
> +static void icp_hpd_irq_setup(struct intel_display *display)
>  {
> -     struct intel_display *display = &dev_priv->display;
> +     struct drm_i915_private *dev_priv = to_i915(display->drm);
>       u32 hotplug_irqs, enabled_irqs;
> 
> -     enabled_irqs = intel_hpd_enabled_irqs(dev_priv, dev_priv-
> >display.hotplug.pch_hpd);
> -     hotplug_irqs = intel_hpd_hotplug_irqs(dev_priv, dev_priv-
> >display.hotplug.pch_hpd);
> +     enabled_irqs = intel_hpd_enabled_irqs(display, display-
> >hotplug.pch_hpd);
> +     hotplug_irqs = intel_hpd_hotplug_irqs(display, 
> display->hotplug.pch_hpd);
> 
>       /*
>        * We reduce the value to 250us to be able to detect SHPD when an
> external display
> @@ -871,8 +861,8 @@ static void icp_hpd_irq_setup(struct drm_i915_private
> *dev_priv)
> 
>       ibx_display_interrupt_update(dev_priv, hotplug_irqs, enabled_irqs);
> 
> -     icp_ddi_hpd_detection_setup(dev_priv);
> -     icp_tc_hpd_detection_setup(dev_priv);
> +     icp_ddi_hpd_detection_setup(display);
> +     icp_tc_hpd_detection_setup(display);
>  }
> 
>  static u32 gen11_hotplug_mask(enum hpd_pin hpd_pin)
> @@ -895,9 +885,8 @@ static u32 gen11_hotplug_enables(struct intel_encoder
> *encoder)
>       return gen11_hotplug_mask(encoder->hpd_pin);
>  }
> 
> -static void dg1_hpd_invert(struct drm_i915_private *i915)
> +static void dg1_hpd_invert(struct intel_display *display)
>  {
> -     struct intel_display *display = &i915->display;
>       u32 val = (INVERT_DDIA_HPD |
>                  INVERT_DDIB_HPD |
>                  INVERT_DDIC_HPD |
> @@ -907,25 +896,23 @@ static void dg1_hpd_invert(struct drm_i915_private
> *i915)
> 
>  static void dg1_hpd_enable_detection(struct intel_encoder *encoder)
>  {
> -     struct drm_i915_private *i915 = to_i915(encoder->base.dev);
> +     struct intel_display *display = to_intel_display(encoder);
> 
> -     dg1_hpd_invert(i915);
> +     dg1_hpd_invert(display);
>       icp_hpd_enable_detection(encoder);
>  }
> 
> -static void dg1_hpd_irq_setup(struct drm_i915_private *dev_priv)
> +static void dg1_hpd_irq_setup(struct intel_display *display)
>  {
> -     dg1_hpd_invert(dev_priv);
> -     icp_hpd_irq_setup(dev_priv);
> +     dg1_hpd_invert(display);
> +     icp_hpd_irq_setup(display);
>  }
> 
> -static void gen11_tc_hpd_detection_setup(struct drm_i915_private *dev_priv)
> +static void gen11_tc_hpd_detection_setup(struct intel_display *display)
>  {
> -     struct intel_display *display = &dev_priv->display;
> -
>       intel_de_rmw(display, GEN11_TC_HOTPLUG_CTL,
> -                  intel_hpd_hotplug_mask(dev_priv, gen11_hotplug_mask),
> -                  intel_hpd_hotplug_enables(dev_priv,
> gen11_hotplug_enables));
> +                  intel_hpd_hotplug_mask(display, gen11_hotplug_mask),
> +                  intel_hpd_hotplug_enables(display, gen11_hotplug_enables));
>  }
> 
>  static void gen11_tc_hpd_enable_detection(struct intel_encoder *encoder)
> @@ -937,13 +924,11 @@ static void gen11_tc_hpd_enable_detection(struct
> intel_encoder *encoder)
>                    gen11_hotplug_enables(encoder));
>  }
> 
> -static void gen11_tbt_hpd_detection_setup(struct drm_i915_private *dev_priv)
> +static void gen11_tbt_hpd_detection_setup(struct intel_display *display)
>  {
> -     struct intel_display *display = &dev_priv->display;
> -
>       intel_de_rmw(display, GEN11_TBT_HOTPLUG_CTL,
> -                  intel_hpd_hotplug_mask(dev_priv, gen11_hotplug_mask),
> -                  intel_hpd_hotplug_enables(dev_priv,
> gen11_hotplug_enables));
> +                  intel_hpd_hotplug_mask(display, gen11_hotplug_mask),
> +                  intel_hpd_hotplug_enables(display, gen11_hotplug_enables));
>  }
> 
>  static void gen11_tbt_hpd_enable_detection(struct intel_encoder *encoder)
> @@ -966,23 +951,23 @@ static void gen11_hpd_enable_detection(struct
> intel_encoder *encoder)
>               icp_hpd_enable_detection(encoder);
>  }
> 
> -static void gen11_hpd_irq_setup(struct drm_i915_private *dev_priv)
> +static void gen11_hpd_irq_setup(struct intel_display *display)
>  {
> -     struct intel_display *display = &dev_priv->display;
> +     struct drm_i915_private *dev_priv = to_i915(display->drm);
>       u32 hotplug_irqs, enabled_irqs;
> 
> -     enabled_irqs = intel_hpd_enabled_irqs(dev_priv, dev_priv-
> >display.hotplug.hpd);
> -     hotplug_irqs = intel_hpd_hotplug_irqs(dev_priv, dev_priv-
> >display.hotplug.hpd);
> +     enabled_irqs = intel_hpd_enabled_irqs(display, display->hotplug.hpd);
> +     hotplug_irqs = intel_hpd_hotplug_irqs(display, display->hotplug.hpd);
> 
>       intel_de_rmw(display, GEN11_DE_HPD_IMR, hotplug_irqs,
>                    ~enabled_irqs & hotplug_irqs);
>       intel_de_posting_read(display, GEN11_DE_HPD_IMR);
> 
> -     gen11_tc_hpd_detection_setup(dev_priv);
> -     gen11_tbt_hpd_detection_setup(dev_priv);
> +     gen11_tc_hpd_detection_setup(display);
> +     gen11_tbt_hpd_detection_setup(display);
> 
>       if (INTEL_PCH_TYPE(dev_priv) >= PCH_ICP)
> -             icp_hpd_irq_setup(dev_priv);
> +             icp_hpd_irq_setup(display);
>  }
> 
>  static u32 mtp_ddi_hotplug_mask(enum hpd_pin hpd_pin)
> @@ -1019,39 +1004,39 @@ static u32 mtp_tc_hotplug_enables(struct
> intel_encoder *encoder)
>       return mtp_tc_hotplug_mask(encoder->hpd_pin);
>  }
> 
> -static void mtp_ddi_hpd_detection_setup(struct drm_i915_private *i915)
> +static void mtp_ddi_hpd_detection_setup(struct intel_display *display)
>  {
> -     intel_de_rmw(i915, SHOTPLUG_CTL_DDI,
> -                  intel_hpd_hotplug_mask(i915, mtp_ddi_hotplug_mask),
> -                  intel_hpd_hotplug_enables(i915, mtp_ddi_hotplug_enables));
> +     intel_de_rmw(display, SHOTPLUG_CTL_DDI,
> +                  intel_hpd_hotplug_mask(display, mtp_ddi_hotplug_mask),
> +                  intel_hpd_hotplug_enables(display,
> mtp_ddi_hotplug_enables));
>  }
> 
>  static void mtp_ddi_hpd_enable_detection(struct intel_encoder *encoder)
>  {
> -     struct drm_i915_private *i915 = to_i915(encoder->base.dev);
> +     struct intel_display *display = to_intel_display(encoder);
> 
> -     intel_de_rmw(i915, SHOTPLUG_CTL_DDI,
> +     intel_de_rmw(display, SHOTPLUG_CTL_DDI,
>                    mtp_ddi_hotplug_mask(encoder->hpd_pin),
>                    mtp_ddi_hotplug_enables(encoder));
>  }
> 
> -static void mtp_tc_hpd_detection_setup(struct drm_i915_private *i915)
> +static void mtp_tc_hpd_detection_setup(struct intel_display *display)
>  {
> -     intel_de_rmw(i915, SHOTPLUG_CTL_TC,
> -                  intel_hpd_hotplug_mask(i915, mtp_tc_hotplug_mask),
> -                  intel_hpd_hotplug_enables(i915, mtp_tc_hotplug_enables));
> +     intel_de_rmw(display, SHOTPLUG_CTL_TC,
> +                  intel_hpd_hotplug_mask(display, mtp_tc_hotplug_mask),
> +                  intel_hpd_hotplug_enables(display,
> mtp_tc_hotplug_enables));
>  }
> 
>  static void mtp_tc_hpd_enable_detection(struct intel_encoder *encoder)
>  {
> -     struct drm_i915_private *i915 = to_i915(encoder->base.dev);
> +     struct intel_display *display = to_intel_display(encoder);
> 
> -     intel_de_rmw(i915, SHOTPLUG_CTL_DDI,
> +     intel_de_rmw(display, SHOTPLUG_CTL_DDI,
>                    mtp_tc_hotplug_mask(encoder->hpd_pin),
>                    mtp_tc_hotplug_enables(encoder));
>  }
> 
> -static void mtp_hpd_invert(struct drm_i915_private *i915)
> +static void mtp_hpd_invert(struct intel_display *display)
>  {
>       u32 val = (INVERT_DDIA_HPD |
>                  INVERT_DDIB_HPD |
> @@ -1062,49 +1047,51 @@ static void mtp_hpd_invert(struct drm_i915_private
> *i915)
>                  INVERT_TC4_HPD |
>                  INVERT_DDID_HPD_MTP |
>                  INVERT_DDIE_HPD);
> -     intel_de_rmw(i915, SOUTH_CHICKEN1, 0, val);
> +     intel_de_rmw(display, SOUTH_CHICKEN1, 0, val);
>  }
> 
>  static void mtp_hpd_enable_detection(struct intel_encoder *encoder)
>  {
> -     struct drm_i915_private *i915 = to_i915(encoder->base.dev);
> +     struct intel_display *display = to_intel_display(encoder);
> 
> -     mtp_hpd_invert(i915);
> +     mtp_hpd_invert(display);
>       mtp_ddi_hpd_enable_detection(encoder);
>       mtp_tc_hpd_enable_detection(encoder);
>  }
> 
> -static void mtp_hpd_irq_setup(struct drm_i915_private *i915)
> +static void mtp_hpd_irq_setup(struct intel_display *display)
>  {
> +     struct drm_i915_private *i915 = to_i915(display->drm);
>       u32 hotplug_irqs, enabled_irqs;
> 
> -     enabled_irqs = intel_hpd_enabled_irqs(i915, i915-
> >display.hotplug.pch_hpd);
> -     hotplug_irqs = intel_hpd_hotplug_irqs(i915, i915-
> >display.hotplug.pch_hpd);
> +     enabled_irqs = intel_hpd_enabled_irqs(display, display-
> >hotplug.pch_hpd);
> +     hotplug_irqs = intel_hpd_hotplug_irqs(display, 
> display->hotplug.pch_hpd);
> 
>       /*
>        * Use 250us here to align with the DP1.4a(Table 3-4) spec as to what 
> the
>        * SHPD_FILTER_CNT value should be.
>        */
> -     intel_de_write(i915, SHPD_FILTER_CNT, SHPD_FILTER_CNT_250);
> +     intel_de_write(display, SHPD_FILTER_CNT, SHPD_FILTER_CNT_250);
> 
> -     mtp_hpd_invert(i915);
> +     mtp_hpd_invert(display);
>       ibx_display_interrupt_update(i915, hotplug_irqs, enabled_irqs);
> 
> -     mtp_ddi_hpd_detection_setup(i915);
> -     mtp_tc_hpd_detection_setup(i915);
> +     mtp_ddi_hpd_detection_setup(display);
> +     mtp_tc_hpd_detection_setup(display);
>  }
> 
> -static void xe2lpd_sde_hpd_irq_setup(struct drm_i915_private *i915)
> +static void xe2lpd_sde_hpd_irq_setup(struct intel_display *display)
>  {
> +     struct drm_i915_private *i915 = to_i915(display->drm);
>       u32 hotplug_irqs, enabled_irqs;
> 
> -     enabled_irqs = intel_hpd_enabled_irqs(i915, i915-
> >display.hotplug.pch_hpd);
> -     hotplug_irqs = intel_hpd_hotplug_irqs(i915, i915-
> >display.hotplug.pch_hpd);
> +     enabled_irqs = intel_hpd_enabled_irqs(display, display-
> >hotplug.pch_hpd);
> +     hotplug_irqs = intel_hpd_hotplug_irqs(display, 
> display->hotplug.pch_hpd);
> 
>       ibx_display_interrupt_update(i915, hotplug_irqs, enabled_irqs);
> 
> -     mtp_ddi_hpd_detection_setup(i915);
> -     mtp_tc_hpd_detection_setup(i915);
> +     mtp_ddi_hpd_detection_setup(display);
> +     mtp_tc_hpd_detection_setup(display);
>  }
> 
>  static bool is_xelpdp_pica_hpd_pin(enum hpd_pin hpd_pin)
> @@ -1112,7 +1099,7 @@ static bool is_xelpdp_pica_hpd_pin(enum hpd_pin
> hpd_pin)
>       return hpd_pin >= HPD_PORT_TC1 && hpd_pin <= HPD_PORT_TC4;
>  }
> 
> -static void _xelpdp_pica_hpd_detection_setup(struct drm_i915_private *i915,
> +static void _xelpdp_pica_hpd_detection_setup(struct intel_display *display,
>                                            enum hpd_pin hpd_pin, bool enable)
>  {
>       u32 mask = XELPDP_TBT_HOTPLUG_ENABLE |
> @@ -1121,18 +1108,18 @@ static void
> _xelpdp_pica_hpd_detection_setup(struct drm_i915_private *i915,
>       if (!is_xelpdp_pica_hpd_pin(hpd_pin))
>               return;
> 
> -     intel_de_rmw(i915, XELPDP_PORT_HOTPLUG_CTL(hpd_pin),
> +     intel_de_rmw(display, XELPDP_PORT_HOTPLUG_CTL(hpd_pin),
>                    mask, enable ? mask : 0);
>  }
> 
>  static void xelpdp_pica_hpd_enable_detection(struct intel_encoder *encoder)
>  {
> -     struct drm_i915_private *i915 = to_i915(encoder->base.dev);
> +     struct intel_display *display = to_intel_display(encoder);
> 
> -     _xelpdp_pica_hpd_detection_setup(i915, encoder->hpd_pin, true);
> +     _xelpdp_pica_hpd_detection_setup(display, encoder->hpd_pin, true);
>  }
> 
> -static void xelpdp_pica_hpd_detection_setup(struct drm_i915_private *i915)
> +static void xelpdp_pica_hpd_detection_setup(struct intel_display *display)
>  {
>       struct intel_encoder *encoder;
>       u32 available_pins = 0;
> @@ -1140,11 +1127,11 @@ static void xelpdp_pica_hpd_detection_setup(struct
> drm_i915_private *i915)
> 
>       BUILD_BUG_ON(BITS_PER_TYPE(available_pins) < HPD_NUM_PINS);
> 
> -     for_each_intel_encoder(&i915->drm, encoder)
> +     for_each_intel_encoder(display->drm, encoder)
>               available_pins |= BIT(encoder->hpd_pin);
> 
>       for_each_hpd_pin(pin)
> -             _xelpdp_pica_hpd_detection_setup(i915, pin, available_pins &
> BIT(pin));
> +             _xelpdp_pica_hpd_detection_setup(display, pin, available_pins &
> BIT(pin));
>  }
> 
>  static void xelpdp_hpd_enable_detection(struct intel_encoder *encoder)
> @@ -1153,24 +1140,24 @@ static void xelpdp_hpd_enable_detection(struct
> intel_encoder *encoder)
>       mtp_hpd_enable_detection(encoder);
>  }
> 
> -static void xelpdp_hpd_irq_setup(struct drm_i915_private *i915)
> +static void xelpdp_hpd_irq_setup(struct intel_display *display)
>  {
> -     struct intel_display *display = &i915->display;
> +     struct drm_i915_private *i915 = to_i915(display->drm);
>       u32 hotplug_irqs, enabled_irqs;
> 
> -     enabled_irqs = intel_hpd_enabled_irqs(i915, i915->display.hotplug.hpd);
> -     hotplug_irqs = intel_hpd_hotplug_irqs(i915, i915->display.hotplug.hpd);
> +     enabled_irqs = intel_hpd_enabled_irqs(display, display->hotplug.hpd);
> +     hotplug_irqs = intel_hpd_hotplug_irqs(display, display->hotplug.hpd);
> 
> -     intel_de_rmw(i915, PICAINTERRUPT_IMR, hotplug_irqs,
> +     intel_de_rmw(display, PICAINTERRUPT_IMR, hotplug_irqs,
>                    ~enabled_irqs & hotplug_irqs);
>       intel_de_posting_read(display, PICAINTERRUPT_IMR);
> 
> -     xelpdp_pica_hpd_detection_setup(i915);
> +     xelpdp_pica_hpd_detection_setup(display);
> 
>       if (INTEL_PCH_TYPE(i915) >= PCH_LNL)
> -             xe2lpd_sde_hpd_irq_setup(i915);
> +             xe2lpd_sde_hpd_irq_setup(display);
>       else if (INTEL_PCH_TYPE(i915) >= PCH_MTL)
> -             mtp_hpd_irq_setup(i915);
> +             mtp_hpd_irq_setup(display);
>  }
> 
>  static u32 spt_hotplug_mask(enum hpd_pin hpd_pin)
> @@ -1209,9 +1196,9 @@ static u32 spt_hotplug2_enables(struct intel_encoder
> *encoder)
>       return spt_hotplug2_mask(encoder->hpd_pin);
>  }
> 
> -static void spt_hpd_detection_setup(struct drm_i915_private *dev_priv)
> +static void spt_hpd_detection_setup(struct intel_display *display)
>  {
> -     struct intel_display *display = &dev_priv->display;
> +     struct drm_i915_private *dev_priv = to_i915(display->drm);
> 
>       /* Display WA #1179 WaHardHangonHotPlug: cnp */
>       if (HAS_PCH_CNP(dev_priv)) {
> @@ -1221,12 +1208,12 @@ static void spt_hpd_detection_setup(struct
> drm_i915_private *dev_priv)
> 
>       /* Enable digital hotplug on the PCH */
>       intel_de_rmw(display, PCH_PORT_HOTPLUG,
> -                  intel_hpd_hotplug_mask(dev_priv, spt_hotplug_mask),
> -                  intel_hpd_hotplug_enables(dev_priv, spt_hotplug_enables));
> +                  intel_hpd_hotplug_mask(display, spt_hotplug_mask),
> +                  intel_hpd_hotplug_enables(display, spt_hotplug_enables));
> 
>       intel_de_rmw(display, PCH_PORT_HOTPLUG2,
> -                  intel_hpd_hotplug_mask(dev_priv, spt_hotplug2_mask),
> -                  intel_hpd_hotplug_enables(dev_priv, spt_hotplug2_enables));
> +                  intel_hpd_hotplug_mask(display, spt_hotplug2_mask),
> +                  intel_hpd_hotplug_enables(display, spt_hotplug2_enables));
>  }
> 
>  static void spt_hpd_enable_detection(struct intel_encoder *encoder)
> @@ -1250,20 +1237,20 @@ static void spt_hpd_enable_detection(struct
> intel_encoder *encoder)
>                    spt_hotplug2_enables(encoder));
>  }
> 
> -static void spt_hpd_irq_setup(struct drm_i915_private *dev_priv)
> +static void spt_hpd_irq_setup(struct intel_display *display)
>  {
> -     struct intel_display *display = &dev_priv->display;
> +     struct drm_i915_private *dev_priv = to_i915(display->drm);
>       u32 hotplug_irqs, enabled_irqs;
> 
>       if (INTEL_PCH_TYPE(dev_priv) >= PCH_CNP)
>               intel_de_write(display, SHPD_FILTER_CNT,
> SHPD_FILTER_CNT_500_ADJ);
> 
> -     enabled_irqs = intel_hpd_enabled_irqs(dev_priv, dev_priv-
> >display.hotplug.pch_hpd);
> -     hotplug_irqs = intel_hpd_hotplug_irqs(dev_priv, dev_priv-
> >display.hotplug.pch_hpd);
> +     enabled_irqs = intel_hpd_enabled_irqs(display, display-
> >hotplug.pch_hpd);
> +     hotplug_irqs = intel_hpd_hotplug_irqs(display, 
> display->hotplug.pch_hpd);
> 
>       ibx_display_interrupt_update(dev_priv, hotplug_irqs, enabled_irqs);
> 
> -     spt_hpd_detection_setup(dev_priv);
> +     spt_hpd_detection_setup(display);
>  }
> 
>  static u32 ilk_hotplug_mask(enum hpd_pin hpd_pin)
> @@ -1288,18 +1275,16 @@ static u32 ilk_hotplug_enables(struct intel_encoder
> *encoder)
>       }
>  }
> 
> -static void ilk_hpd_detection_setup(struct drm_i915_private *dev_priv)
> +static void ilk_hpd_detection_setup(struct intel_display *display)
>  {
> -     struct intel_display *display = &dev_priv->display;
> -
>       /*
>        * Enable digital hotplug on the CPU, and configure the DP short pulse
>        * duration to 2ms (which is the minimum in the Display Port spec)
>        * The pulse duration bits are reserved on HSW+.
>        */
>       intel_de_rmw(display, DIGITAL_PORT_HOTPLUG_CNTRL,
> -                  intel_hpd_hotplug_mask(dev_priv, ilk_hotplug_mask),
> -                  intel_hpd_hotplug_enables(dev_priv, ilk_hotplug_enables));
> +                  intel_hpd_hotplug_mask(display, ilk_hotplug_mask),
> +                  intel_hpd_hotplug_enables(display, ilk_hotplug_enables));
>  }
> 
>  static void ilk_hpd_enable_detection(struct intel_encoder *encoder)
> @@ -1313,21 +1298,22 @@ static void ilk_hpd_enable_detection(struct
> intel_encoder *encoder)
>       ibx_hpd_enable_detection(encoder);
>  }
> 
> -static void ilk_hpd_irq_setup(struct drm_i915_private *dev_priv)
> +static void ilk_hpd_irq_setup(struct intel_display *display)
>  {
> +     struct drm_i915_private *dev_priv = to_i915(display->drm);
>       u32 hotplug_irqs, enabled_irqs;
> 
> -     enabled_irqs = intel_hpd_enabled_irqs(dev_priv, dev_priv-
> >display.hotplug.hpd);
> -     hotplug_irqs = intel_hpd_hotplug_irqs(dev_priv, dev_priv-
> >display.hotplug.hpd);
> +     enabled_irqs = intel_hpd_enabled_irqs(display, display->hotplug.hpd);
> +     hotplug_irqs = intel_hpd_hotplug_irqs(display, display->hotplug.hpd);
> 
> -     if (DISPLAY_VER(dev_priv) >= 8)
> +     if (DISPLAY_VER(display) >= 8)
>               bdw_update_port_irq(dev_priv, hotplug_irqs, enabled_irqs);
>       else
>               ilk_update_display_irq(dev_priv, hotplug_irqs, enabled_irqs);
> 
> -     ilk_hpd_detection_setup(dev_priv);
> +     ilk_hpd_detection_setup(display);
> 
> -     ibx_hpd_irq_setup(dev_priv);
> +     ibx_hpd_irq_setup(display);
>  }
> 
>  static u32 bxt_hotplug_mask(enum hpd_pin hpd_pin)
> @@ -1369,13 +1355,11 @@ static u32 bxt_hotplug_enables(struct intel_encoder
> *encoder)
>       }
>  }
> 
> -static void bxt_hpd_detection_setup(struct drm_i915_private *dev_priv)
> +static void bxt_hpd_detection_setup(struct intel_display *display)
>  {
> -     struct intel_display *display = &dev_priv->display;
> -
>       intel_de_rmw(display, PCH_PORT_HOTPLUG,
> -                  intel_hpd_hotplug_mask(dev_priv, bxt_hotplug_mask),
> -                  intel_hpd_hotplug_enables(dev_priv, bxt_hotplug_enables));
> +                  intel_hpd_hotplug_mask(display, bxt_hotplug_mask),
> +                  intel_hpd_hotplug_enables(display, bxt_hotplug_enables));
>  }
> 
>  static void bxt_hpd_enable_detection(struct intel_encoder *encoder)
> @@ -1387,42 +1371,44 @@ static void bxt_hpd_enable_detection(struct
> intel_encoder *encoder)
>                    bxt_hotplug_enables(encoder));
>  }
> 
> -static void bxt_hpd_irq_setup(struct drm_i915_private *dev_priv)
> +static void bxt_hpd_irq_setup(struct intel_display *display)
>  {
> +     struct drm_i915_private *dev_priv = to_i915(display->drm);
>       u32 hotplug_irqs, enabled_irqs;
> 
> -     enabled_irqs = intel_hpd_enabled_irqs(dev_priv, dev_priv-
> >display.hotplug.hpd);
> -     hotplug_irqs = intel_hpd_hotplug_irqs(dev_priv, dev_priv-
> >display.hotplug.hpd);
> +     enabled_irqs = intel_hpd_enabled_irqs(display, display->hotplug.hpd);
> +     hotplug_irqs = intel_hpd_hotplug_irqs(display, display->hotplug.hpd);
> 
>       bdw_update_port_irq(dev_priv, hotplug_irqs, enabled_irqs);
> 
> -     bxt_hpd_detection_setup(dev_priv);
> +     bxt_hpd_detection_setup(display);
>  }
> 
> -static void g45_hpd_peg_band_gap_wa(struct drm_i915_private *i915)
> +static void g45_hpd_peg_band_gap_wa(struct intel_display *display)
>  {
>       /*
>        * For G4X desktop chip, PEG_BAND_GAP_DATA 3:0 must first be written
>        * 0xd.  Failure to do so will result in spurious interrupts being
>        * generated on the port when a cable is not attached.
>        */
> -     intel_de_rmw(i915, PEG_BAND_GAP_DATA, 0xf, 0xd);
> +     intel_de_rmw(display, PEG_BAND_GAP_DATA, 0xf, 0xd);
>  }
> 
>  static void i915_hpd_enable_detection(struct intel_encoder *encoder)
>  {
> -     struct drm_i915_private *i915 = to_i915(encoder->base.dev);
> +     struct intel_display *display = to_intel_display(encoder);
>       u32 hotplug_en = hpd_mask_i915[encoder->hpd_pin];
> 
> -     if (IS_G45(i915))
> -             g45_hpd_peg_band_gap_wa(i915);
> +     if (display->platform.g45)
> +             g45_hpd_peg_band_gap_wa(display);
> 
>       /* HPD sense and interrupt enable are one and the same */
> -     i915_hotplug_interrupt_update(i915, hotplug_en, hotplug_en);
> +     i915_hotplug_interrupt_update(display, hotplug_en, hotplug_en);
>  }
> 
> -static void i915_hpd_irq_setup(struct drm_i915_private *dev_priv)
> +static void i915_hpd_irq_setup(struct intel_display *display)
>  {
> +     struct drm_i915_private *dev_priv = to_i915(display->drm);
>       u32 hotplug_en;
> 
>       lockdep_assert_held(&dev_priv->irq_lock);
> @@ -1431,20 +1417,20 @@ static void i915_hpd_irq_setup(struct
> drm_i915_private *dev_priv)
>        * Note HDMI and DP share hotplug bits. Enable bits are the same for all
>        * generations.
>        */
> -     hotplug_en = intel_hpd_enabled_irqs(dev_priv, hpd_mask_i915);
> +     hotplug_en = intel_hpd_enabled_irqs(display, hpd_mask_i915);
>       /*
>        * Programming the CRT detection parameters tends to generate a
> spurious
>        * hotplug event about three seconds later. So just do it once.
>        */
> -     if (IS_G4X(dev_priv))
> +     if (display->platform.g4x)
>               hotplug_en |= CRT_HOTPLUG_ACTIVATION_PERIOD_64;
>       hotplug_en |= CRT_HOTPLUG_VOLTAGE_COMPARE_50;
> 
> -     if (IS_G45(dev_priv))
> -             g45_hpd_peg_band_gap_wa(dev_priv);
> +     if (display->platform.g45)
> +             g45_hpd_peg_band_gap_wa(display);
> 
>       /* Ignore TV since it's buggy */
> -     i915_hotplug_interrupt_update_locked(dev_priv,
> +     i915_hotplug_interrupt_update_locked(display,
>                                            HOTPLUG_INT_EN_MASK |
> 
> CRT_HOTPLUG_VOLTAGE_COMPARE_MASK |
> 
> CRT_HOTPLUG_ACTIVATION_PERIOD_64,
> @@ -1453,7 +1439,7 @@ static void i915_hpd_irq_setup(struct
> drm_i915_private *dev_priv)
> 
>  struct intel_hotplug_funcs {
>       /* Enable HPD sense and interrupts for all present encoders */
> -     void (*hpd_irq_setup)(struct drm_i915_private *i915);
> +     void (*hpd_irq_setup)(struct intel_display *display);
>       /* Enable HPD sense for a single encoder */
>       void (*hpd_enable_detection)(struct intel_encoder *encoder);
>  };
> @@ -1476,49 +1462,49 @@ HPD_FUNCS(ilk);
> 
>  void intel_hpd_enable_detection(struct intel_encoder *encoder)
>  {
> -     struct drm_i915_private *i915 = to_i915(encoder->base.dev);
> +     struct intel_display *display = to_intel_display(encoder);
> 
> -     if (i915->display.funcs.hotplug)
> -             i915->display.funcs.hotplug->hpd_enable_detection(encoder);
> +     if (display->funcs.hotplug)
> +             display->funcs.hotplug->hpd_enable_detection(encoder);
>  }
> 
> -void intel_hpd_irq_setup(struct drm_i915_private *i915)
> +void intel_hpd_irq_setup(struct intel_display *display)
>  {
> -     if ((IS_VALLEYVIEW(i915) || IS_CHERRYVIEW(i915)) &&
> -         !i915->display.irq.vlv_display_irqs_enabled)
> +     if ((display->platform.valleyview || display->platform.cherryview) &&
> +         !display->irq.vlv_display_irqs_enabled)
>               return;
> 
> -     if (i915->display.funcs.hotplug)
> -             i915->display.funcs.hotplug->hpd_irq_setup(i915);
> +     if (display->funcs.hotplug)
> +             display->funcs.hotplug->hpd_irq_setup(display);
>  }
> 
> -void intel_hotplug_irq_init(struct drm_i915_private *i915)
> +void intel_hotplug_irq_init(struct intel_display *display)
>  {
> -     struct intel_display *display = &i915->display;
> +     struct drm_i915_private *i915 = to_i915(display->drm);
> 
> -     intel_hpd_init_pins(i915);
> +     intel_hpd_init_pins(display);
> 
>       intel_hpd_init_early(display);
> 
> -     if (HAS_GMCH(i915)) {
> -             if (I915_HAS_HOTPLUG(i915))
> -                     i915->display.funcs.hotplug = &i915_hpd_funcs;
> +     if (HAS_GMCH(display)) {
> +             if (I915_HAS_HOTPLUG(display))
> +                     display->funcs.hotplug = &i915_hpd_funcs;
>       } else {
>               if (HAS_PCH_DG2(i915))
> -                     i915->display.funcs.hotplug = &icp_hpd_funcs;
> +                     display->funcs.hotplug = &icp_hpd_funcs;
>               else if (HAS_PCH_DG1(i915))
> -                     i915->display.funcs.hotplug = &dg1_hpd_funcs;
> -             else if (DISPLAY_VER(i915) >= 14)
> -                     i915->display.funcs.hotplug = &xelpdp_hpd_funcs;
> -             else if (DISPLAY_VER(i915) >= 11)
> -                     i915->display.funcs.hotplug = &gen11_hpd_funcs;
> -             else if (IS_GEMINILAKE(i915) || IS_BROXTON(i915))
> -                     i915->display.funcs.hotplug = &bxt_hpd_funcs;
> +                     display->funcs.hotplug = &dg1_hpd_funcs;
> +             else if (DISPLAY_VER(display) >= 14)
> +                     display->funcs.hotplug = &xelpdp_hpd_funcs;
> +             else if (DISPLAY_VER(display) >= 11)
> +                     display->funcs.hotplug = &gen11_hpd_funcs;
> +             else if (display->platform.geminilake || display-
> >platform.broxton)
> +                     display->funcs.hotplug = &bxt_hpd_funcs;
>               else if (INTEL_PCH_TYPE(i915) >= PCH_ICP)
> -                     i915->display.funcs.hotplug = &icp_hpd_funcs;
> +                     display->funcs.hotplug = &icp_hpd_funcs;
>               else if (INTEL_PCH_TYPE(i915) >= PCH_SPT)
> -                     i915->display.funcs.hotplug = &spt_hpd_funcs;
> +                     display->funcs.hotplug = &spt_hpd_funcs;
>               else
> -                     i915->display.funcs.hotplug = &ilk_hpd_funcs;
> +                     display->funcs.hotplug = &ilk_hpd_funcs;
>       }
>  }
> diff --git a/drivers/gpu/drm/i915/display/intel_hotplug_irq.h
> b/drivers/gpu/drm/i915/display/intel_hotplug_irq.h
> index e4db752df096..9063bb02a2e9 100644
> --- a/drivers/gpu/drm/i915/display/intel_hotplug_irq.h
> +++ b/drivers/gpu/drm/i915/display/intel_hotplug_irq.h
> @@ -8,28 +8,28 @@
> 
>  #include <linux/types.h>
> 
> -struct drm_i915_private;
> +struct intel_display;
>  struct intel_encoder;
> 
> -u32 i9xx_hpd_irq_ack(struct drm_i915_private *i915);
> +u32 i9xx_hpd_irq_ack(struct intel_display *display);
> 
> -void i9xx_hpd_irq_handler(struct drm_i915_private *i915, u32 hotplug_status);
> -void ibx_hpd_irq_handler(struct drm_i915_private *i915, u32 hotplug_trigger);
> -void ilk_hpd_irq_handler(struct drm_i915_private *i915, u32 hotplug_trigger);
> -void gen11_hpd_irq_handler(struct drm_i915_private *i915, u32 iir);
> -void bxt_hpd_irq_handler(struct drm_i915_private *i915, u32 hotplug_trigger);
> -void xelpdp_pica_irq_handler(struct drm_i915_private *i915, u32 iir);
> -void icp_irq_handler(struct drm_i915_private *i915, u32 pch_iir);
> -void spt_irq_handler(struct drm_i915_private *i915, u32 pch_iir);
> +void i9xx_hpd_irq_handler(struct intel_display *display, u32 hotplug_status);
> +void ibx_hpd_irq_handler(struct intel_display *display, u32 hotplug_trigger);
> +void ilk_hpd_irq_handler(struct intel_display *display, u32 hotplug_trigger);
> +void gen11_hpd_irq_handler(struct intel_display *display, u32 iir);
> +void bxt_hpd_irq_handler(struct intel_display *display, u32 hotplug_trigger);
> +void xelpdp_pica_irq_handler(struct intel_display *display, u32 iir);
> +void icp_irq_handler(struct intel_display *display, u32 pch_iir);
> +void spt_irq_handler(struct intel_display *display, u32 pch_iir);
> 
> -void i915_hotplug_interrupt_update_locked(struct drm_i915_private *i915,
> +void i915_hotplug_interrupt_update_locked(struct intel_display *display,
>                                         u32 mask, u32 bits);
> -void i915_hotplug_interrupt_update(struct drm_i915_private *i915,
> +void i915_hotplug_interrupt_update(struct intel_display *display,
>                                  u32 mask, u32 bits);
> 
>  void intel_hpd_enable_detection(struct intel_encoder *encoder);
> -void intel_hpd_irq_setup(struct drm_i915_private *i915);
> +void intel_hpd_irq_setup(struct intel_display *display);
> 
> -void intel_hotplug_irq_init(struct drm_i915_private *i915);
> +void intel_hotplug_irq_init(struct intel_display *display);
> 
>  #endif /* __INTEL_HOTPLUG_IRQ_H__ */
> diff --git a/drivers/gpu/drm/i915/i915_irq.c b/drivers/gpu/drm/i915/i915_irq.c
> index de53615571be..3b05eb3f9cbc 100644
> --- a/drivers/gpu/drm/i915/i915_irq.c
> +++ b/drivers/gpu/drm/i915/i915_irq.c
> @@ -277,7 +277,7 @@ static irqreturn_t valleyview_irq_handler(int irq, void
> *arg)
>                       intel_uncore_write(&dev_priv->uncore, GEN6_PMIIR,
> pm_iir);
> 
>               if (iir & I915_DISPLAY_PORT_INTERRUPT)
> -                     hotplug_status = i9xx_hpd_irq_ack(dev_priv);
> +                     hotplug_status = i9xx_hpd_irq_ack(display);
> 
>               if (iir & I915_MASTER_ERROR_INTERRUPT)
>                       vlv_display_error_irq_ack(display, &eir, &dpinvgtt);
> @@ -306,7 +306,7 @@ static irqreturn_t valleyview_irq_handler(int irq, void
> *arg)
>                       gen6_rps_irq_handler(&to_gt(dev_priv)->rps, pm_iir);
> 
>               if (hotplug_status)
> -                     i9xx_hpd_irq_handler(dev_priv, hotplug_status);
> +                     i9xx_hpd_irq_handler(display, hotplug_status);
> 
>               if (iir & I915_MASTER_ERROR_INTERRUPT)
>                       vlv_display_error_irq_handler(display, eir, dpinvgtt);
> @@ -367,7 +367,7 @@ static irqreturn_t cherryview_irq_handler(int irq, void
> *arg)
>               gen8_gt_irq_handler(to_gt(dev_priv), master_ctl);
> 
>               if (iir & I915_DISPLAY_PORT_INTERRUPT)
> -                     hotplug_status = i9xx_hpd_irq_ack(dev_priv);
> +                     hotplug_status = i9xx_hpd_irq_ack(display);
> 
>               if (iir & I915_MASTER_ERROR_INTERRUPT)
>                       vlv_display_error_irq_ack(display, &eir, &dpinvgtt);
> @@ -392,7 +392,7 @@ static irqreturn_t cherryview_irq_handler(int irq, void
> *arg)
>               intel_uncore_write(&dev_priv->uncore, GEN8_MASTER_IRQ,
> GEN8_MASTER_IRQ_CONTROL);
> 
>               if (hotplug_status)
> -                     i9xx_hpd_irq_handler(dev_priv, hotplug_status);
> +                     i9xx_hpd_irq_handler(display, hotplug_status);
> 
>               if (iir & I915_MASTER_ERROR_INTERRUPT)
>                       vlv_display_error_irq_handler(display, eir, dpinvgtt);
> @@ -952,6 +952,7 @@ static void i915_irq_postinstall(struct drm_i915_private
> *dev_priv)
>  static irqreturn_t i915_irq_handler(int irq, void *arg)
>  {
>       struct drm_i915_private *dev_priv = arg;
> +     struct intel_display *display = &dev_priv->display;
>       irqreturn_t ret = IRQ_NONE;
> 
>       if (!intel_irqs_enabled(dev_priv))
> @@ -974,7 +975,7 @@ static irqreturn_t i915_irq_handler(int irq, void *arg)
> 
>               if (I915_HAS_HOTPLUG(dev_priv) &&
>                   iir & I915_DISPLAY_PORT_INTERRUPT)
> -                     hotplug_status = i9xx_hpd_irq_ack(dev_priv);
> +                     hotplug_status = i9xx_hpd_irq_ack(display);
> 
>               /* Call regardless, as some status bits might not be
>                * signalled in IIR */
> @@ -992,7 +993,7 @@ static irqreturn_t i915_irq_handler(int irq, void *arg)
>                       i9xx_error_irq_handler(dev_priv, eir, eir_stuck);
> 
>               if (hotplug_status)
> -                     i9xx_hpd_irq_handler(dev_priv, hotplug_status);
> +                     i9xx_hpd_irq_handler(display, hotplug_status);
> 
>               i915_pipestat_irq_handler(dev_priv, iir, pipe_stats);
>       } while (0);
> @@ -1075,6 +1076,7 @@ static void i965_irq_postinstall(struct
> drm_i915_private *dev_priv)
>  static irqreturn_t i965_irq_handler(int irq, void *arg)
>  {
>       struct drm_i915_private *dev_priv = arg;
> +     struct intel_display *display = &dev_priv->display;
>       irqreturn_t ret = IRQ_NONE;
> 
>       if (!intel_irqs_enabled(dev_priv))
> @@ -1096,7 +1098,7 @@ static irqreturn_t i965_irq_handler(int irq, void *arg)
>               ret = IRQ_HANDLED;
> 
>               if (iir & I915_DISPLAY_PORT_INTERRUPT)
> -                     hotplug_status = i9xx_hpd_irq_ack(dev_priv);
> +                     hotplug_status = i9xx_hpd_irq_ack(display);
> 
>               /* Call regardless, as some status bits might not be
>                * signalled in IIR */
> @@ -1119,7 +1121,7 @@ static irqreturn_t i965_irq_handler(int irq, void *arg)
>                       i9xx_error_irq_handler(dev_priv, eir, eir_stuck);
> 
>               if (hotplug_status)
> -                     i9xx_hpd_irq_handler(dev_priv, hotplug_status);
> +                     i9xx_hpd_irq_handler(display, hotplug_status);
> 
>               i965_pipestat_irq_handler(dev_priv, iir, pipe_stats);
>       } while (0);
> --
> 2.39.5

Reply via email to