diff mbox series

drm/i915/backlight: convert to use struct intel_display

Message ID 20250204132423.2910978-1-jani.nikula@intel.com (mailing list archive)
State New
Headers show
Series drm/i915/backlight: convert to use struct intel_display | expand

Commit Message

Jani Nikula Feb. 4, 2025, 1:24 p.m. UTC
Going forward, struct intel_display will be the main display data
structure. Convert as much as possible of backlight code to use it.

There are some stragglers mainly around PCH checks.

Signed-off-by: Jani Nikula <jani.nikula@intel.com>
---
 .../gpu/drm/i915/display/intel_backlight.c    | 494 +++++++++---------
 1 file changed, 260 insertions(+), 234 deletions(-)

Comments

Kandpal, Suraj Feb. 5, 2025, 9:11 a.m. UTC | #1
> -----Original Message-----
> From: Intel-gfx <intel-gfx-bounces@lists.freedesktop.org> On Behalf Of Jani
> Nikula
> Sent: Tuesday, February 4, 2025 6:54 PM
> To: intel-gfx@lists.freedesktop.org; intel-xe@lists.freedesktop.org
> Cc: Nikula, Jani <jani.nikula@intel.com>
> Subject: [PATCH] drm/i915/backlight: convert to use struct intel_display
> 
> Going forward, struct intel_display will be the main display data
> structure. Convert as much as possible of backlight code to use it.
> 
> There are some stragglers mainly around PCH checks.
> 
> Signed-off-by: Jani Nikula <jani.nikula@intel.com>

LGTM,
Reviewed-by: Suraj Kandpal <suraj.kandpal@intel.com>

> ---
>  .../gpu/drm/i915/display/intel_backlight.c    | 494 +++++++++---------
>  1 file changed, 260 insertions(+), 234 deletions(-)
> 
> diff --git a/drivers/gpu/drm/i915/display/intel_backlight.c
> b/drivers/gpu/drm/i915/display/intel_backlight.c
> index 7e6ce905bdaf..477b21af71a4 100644
> --- a/drivers/gpu/drm/i915/display/intel_backlight.c
> +++ b/drivers/gpu/drm/i915/display/intel_backlight.c
> @@ -104,20 +104,20 @@ u32 intel_backlight_invert_pwm_level(struct
> intel_connector *connector, u32 val)
>  void intel_backlight_set_pwm_level(const struct drm_connector_state
> *conn_state, u32 val)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
> 
> -	drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] set backlight PWM
> = %d\n",
> +	drm_dbg_kms(display->drm, "[CONNECTOR:%d:%s] set backlight
> PWM = %d\n",
>  		    connector->base.base.id, connector->base.name, val);
>  	panel->backlight.pwm_funcs->set(conn_state, val);
>  }
> 
>  u32 intel_backlight_level_to_pwm(struct intel_connector *connector, u32
> val)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
> 
> -	drm_WARN_ON_ONCE(&i915->drm,
> +	drm_WARN_ON_ONCE(display->drm,
>  			 panel->backlight.max == 0 || panel-
> >backlight.pwm_level_max == 0);
> 
>  	val = scale(val, panel->backlight.min, panel->backlight.max,
> @@ -145,32 +145,33 @@ u32 intel_backlight_level_from_pwm(struct
> intel_connector *connector, u32 val)
> 
>  static u32 lpt_get_backlight(struct intel_connector *connector, enum pipe
> unused)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
> 
> -	return intel_de_read(i915, BLC_PWM_PCH_CTL2) &
> BACKLIGHT_DUTY_CYCLE_MASK;
> +	return intel_de_read(display, BLC_PWM_PCH_CTL2) &
> BACKLIGHT_DUTY_CYCLE_MASK;
>  }
> 
>  static u32 pch_get_backlight(struct intel_connector *connector, enum pipe
> unused)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
> 
> -	return intel_de_read(i915, BLC_PWM_CPU_CTL) &
> BACKLIGHT_DUTY_CYCLE_MASK;
> +	return intel_de_read(display, BLC_PWM_CPU_CTL) &
> BACKLIGHT_DUTY_CYCLE_MASK;
>  }
> 
>  static u32 i9xx_get_backlight(struct intel_connector *connector, enum pipe
> unused)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	u32 val;
> 
> -	val = intel_de_read(i915, BLC_PWM_CTL) &
> BACKLIGHT_DUTY_CYCLE_MASK;
> -	if (DISPLAY_VER(i915) < 4)
> +	val = intel_de_read(display, BLC_PWM_CTL) &
> BACKLIGHT_DUTY_CYCLE_MASK;
> +	if (DISPLAY_VER(display) < 4)
>  		val >>= 1;
> 
>  	if (panel->backlight.combination_mode) {
> +		struct pci_dev *pdev = to_pci_dev(display->drm->dev);
>  		u8 lbpc;
> 
> -		pci_read_config_byte(to_pci_dev(i915->drm.dev), LBPC,
> &lbpc);
> +		pci_read_config_byte(pdev, LBPC, &lbpc);
>  		val *= lbpc;
>  	}
> 
> @@ -179,20 +180,20 @@ static u32 i9xx_get_backlight(struct intel_connector
> *connector, enum pipe unuse
> 
>  static u32 vlv_get_backlight(struct intel_connector *connector, enum pipe
> pipe)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
> 
> -	if (drm_WARN_ON(&i915->drm, pipe != PIPE_A && pipe != PIPE_B))
> +	if (drm_WARN_ON(display->drm, pipe != PIPE_A && pipe != PIPE_B))
>  		return 0;
> 
> -	return intel_de_read(i915, VLV_BLC_PWM_CTL(pipe)) &
> BACKLIGHT_DUTY_CYCLE_MASK;
> +	return intel_de_read(display, VLV_BLC_PWM_CTL(pipe)) &
> BACKLIGHT_DUTY_CYCLE_MASK;
>  }
> 
>  static u32 bxt_get_backlight(struct intel_connector *connector, enum pipe
> unused)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
> 
> -	return intel_de_read(i915, BXT_BLC_PWM_DUTY(panel-
> >backlight.controller));
> +	return intel_de_read(display, BXT_BLC_PWM_DUTY(panel-
> >backlight.controller));
>  }
> 
>  static u32 ext_pwm_get_backlight(struct intel_connector *connector, enum
> pipe unused)
> @@ -207,69 +208,70 @@ static u32 ext_pwm_get_backlight(struct
> intel_connector *connector, enum pipe un
>  static void lpt_set_backlight(const struct drm_connector_state *conn_state,
> u32 level)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	u32 val;
> 
> -	val = intel_de_read(i915, BLC_PWM_PCH_CTL2) &
> ~BACKLIGHT_DUTY_CYCLE_MASK;
> -	intel_de_write(i915, BLC_PWM_PCH_CTL2, val | level);
> +	val = intel_de_read(display, BLC_PWM_PCH_CTL2) &
> ~BACKLIGHT_DUTY_CYCLE_MASK;
> +	intel_de_write(display, BLC_PWM_PCH_CTL2, val | level);
>  }
> 
>  static void pch_set_backlight(const struct drm_connector_state *conn_state,
> u32 level)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	u32 tmp;
> 
> -	tmp = intel_de_read(i915, BLC_PWM_CPU_CTL) &
> ~BACKLIGHT_DUTY_CYCLE_MASK;
> -	intel_de_write(i915, BLC_PWM_CPU_CTL, tmp | level);
> +	tmp = intel_de_read(display, BLC_PWM_CPU_CTL) &
> ~BACKLIGHT_DUTY_CYCLE_MASK;
> +	intel_de_write(display, BLC_PWM_CPU_CTL, tmp | level);
>  }
> 
>  static void i9xx_set_backlight(const struct drm_connector_state *conn_state,
> u32 level)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	u32 tmp, mask;
> 
> -	drm_WARN_ON(&i915->drm, panel->backlight.pwm_level_max == 0);
> +	drm_WARN_ON(display->drm, panel->backlight.pwm_level_max ==
> 0);
> 
>  	if (panel->backlight.combination_mode) {
> +		struct pci_dev *pdev = to_pci_dev(display->drm->dev);
>  		u8 lbpc;
> 
>  		lbpc = level * 0xfe / panel->backlight.pwm_level_max + 1;
>  		level /= lbpc;
> -		pci_write_config_byte(to_pci_dev(i915->drm.dev), LBPC,
> lbpc);
> +		pci_write_config_byte(pdev, LBPC, lbpc);
>  	}
> 
> -	if (DISPLAY_VER(i915) == 4) {
> +	if (DISPLAY_VER(display) == 4) {
>  		mask = BACKLIGHT_DUTY_CYCLE_MASK;
>  	} else {
>  		level <<= 1;
>  		mask = BACKLIGHT_DUTY_CYCLE_MASK_PNV;
>  	}
> 
> -	tmp = intel_de_read(i915, BLC_PWM_CTL) & ~mask;
> -	intel_de_write(i915, BLC_PWM_CTL, tmp | level);
> +	tmp = intel_de_read(display, BLC_PWM_CTL) & ~mask;
> +	intel_de_write(display, BLC_PWM_CTL, tmp | level);
>  }
> 
>  static void vlv_set_backlight(const struct drm_connector_state *conn_state,
> u32 level)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	enum pipe pipe = to_intel_crtc(conn_state->crtc)->pipe;
>  	u32 tmp;
> 
> -	tmp = intel_de_read(i915, VLV_BLC_PWM_CTL(pipe)) &
> ~BACKLIGHT_DUTY_CYCLE_MASK;
> -	intel_de_write(i915, VLV_BLC_PWM_CTL(pipe), tmp | level);
> +	tmp = intel_de_read(display, VLV_BLC_PWM_CTL(pipe)) &
> ~BACKLIGHT_DUTY_CYCLE_MASK;
> +	intel_de_write(display, VLV_BLC_PWM_CTL(pipe), tmp | level);
>  }
> 
>  static void bxt_set_backlight(const struct drm_connector_state *conn_state,
> u32 level)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
> 
> -	intel_de_write(i915, BXT_BLC_PWM_DUTY(panel-
> >backlight.controller), level);
> +	intel_de_write(display, BXT_BLC_PWM_DUTY(panel-
> >backlight.controller), level);
>  }
> 
>  static void ext_pwm_set_backlight(const struct drm_connector_state
> *conn_state, u32 level)
> @@ -284,10 +286,10 @@ static void
>  intel_panel_actually_set_backlight(const struct drm_connector_state
> *conn_state, u32 level)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
> 
> -	drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] set backlight level
> = %d\n",
> +	drm_dbg_kms(display->drm, "[CONNECTOR:%d:%s] set backlight level
> = %d\n",
>  		    connector->base.base.id, connector->base.name, level);
> 
>  	panel->backlight.funcs->set(conn_state, level);
> @@ -300,7 +302,7 @@ void intel_backlight_set_acpi(const struct
> drm_connector_state *conn_state,
>  			      u32 user_level, u32 user_max)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	u32 hw_level;
> 
> @@ -313,9 +315,9 @@ void intel_backlight_set_acpi(const struct
> drm_connector_state *conn_state,
>  	if (!panel->backlight.present || !conn_state->crtc)
>  		return;
> 
> -	mutex_lock(&i915->display.backlight.lock);
> +	mutex_lock(&display->backlight.lock);
> 
> -	drm_WARN_ON(&i915->drm, panel->backlight.max == 0);
> +	drm_WARN_ON(display->drm, panel->backlight.max == 0);
> 
>  	hw_level = clamp_user_to_hw(connector, user_level, user_max);
>  	panel->backlight.level = hw_level;
> @@ -329,13 +331,13 @@ void intel_backlight_set_acpi(const struct
> drm_connector_state *conn_state,
>  	if (panel->backlight.enabled)
>  		intel_panel_actually_set_backlight(conn_state, hw_level);
> 
> -	mutex_unlock(&i915->display.backlight.lock);
> +	mutex_unlock(&display->backlight.lock);
>  }
> 
>  static void lpt_disable_backlight(const struct drm_connector_state
> *old_conn_state, u32 level)
>  {
>  	struct intel_connector *connector =
> to_intel_connector(old_conn_state->connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	u32 tmp;
> 
>  	intel_backlight_set_pwm_level(old_conn_state, level);
> @@ -348,26 +350,26 @@ static void lpt_disable_backlight(const struct
> drm_connector_state *old_conn_sta
>  	 * This needs rework if we need to add support for CPU PWM on PCH
> split
>  	 * platforms.
>  	 */
> -	tmp = intel_de_read(i915, BLC_PWM_CPU_CTL2);
> +	tmp = intel_de_read(display, BLC_PWM_CPU_CTL2);
>  	if (tmp & BLM_PWM_ENABLE) {
> -		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] CPU
> backlight was enabled, disabling\n",
> +		drm_dbg_kms(display->drm, "[CONNECTOR:%d:%s] CPU
> backlight was enabled, disabling\n",
>  			    connector->base.base.id, connector->base.name);
> -		intel_de_write(i915, BLC_PWM_CPU_CTL2, tmp &
> ~BLM_PWM_ENABLE);
> +		intel_de_write(display, BLC_PWM_CPU_CTL2, tmp &
> ~BLM_PWM_ENABLE);
>  	}
> 
> -	intel_de_rmw(i915, BLC_PWM_PCH_CTL1, BLM_PCH_PWM_ENABLE,
> 0);
> +	intel_de_rmw(display, BLC_PWM_PCH_CTL1,
> BLM_PCH_PWM_ENABLE, 0);
>  }
> 
>  static void pch_disable_backlight(const struct drm_connector_state
> *old_conn_state, u32 val)
>  {
>  	struct intel_connector *connector =
> to_intel_connector(old_conn_state->connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
> 
>  	intel_backlight_set_pwm_level(old_conn_state, val);
> 
> -	intel_de_rmw(i915, BLC_PWM_CPU_CTL2, BLM_PWM_ENABLE, 0);
> +	intel_de_rmw(display, BLC_PWM_CPU_CTL2, BLM_PWM_ENABLE, 0);
> 
> -	intel_de_rmw(i915, BLC_PWM_PCH_CTL1, BLM_PCH_PWM_ENABLE,
> 0);
> +	intel_de_rmw(display, BLC_PWM_PCH_CTL1,
> BLM_PCH_PWM_ENABLE, 0);
>  }
> 
>  static void i9xx_disable_backlight(const struct drm_connector_state
> *old_conn_state, u32 val)
> @@ -377,48 +379,49 @@ static void i9xx_disable_backlight(const struct
> drm_connector_state *old_conn_st
> 
>  static void i965_disable_backlight(const struct drm_connector_state
> *old_conn_state, u32 val)
>  {
> -	struct drm_i915_private *i915 = to_i915(old_conn_state->connector-
> >dev);
> +	struct intel_connector *connector =
> to_intel_connector(old_conn_state->connector);
> +	struct intel_display *display = to_intel_display(connector);
> 
>  	intel_backlight_set_pwm_level(old_conn_state, val);
> 
> -	intel_de_rmw(i915, BLC_PWM_CTL2, BLM_PWM_ENABLE, 0);
> +	intel_de_rmw(display, BLC_PWM_CTL2, BLM_PWM_ENABLE, 0);
>  }
> 
>  static void vlv_disable_backlight(const struct drm_connector_state
> *old_conn_state, u32 val)
>  {
>  	struct intel_connector *connector =
> to_intel_connector(old_conn_state->connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	enum pipe pipe = to_intel_crtc(old_conn_state->crtc)->pipe;
> 
>  	intel_backlight_set_pwm_level(old_conn_state, val);
> 
> -	intel_de_rmw(i915, VLV_BLC_PWM_CTL2(pipe), BLM_PWM_ENABLE,
> 0);
> +	intel_de_rmw(display, VLV_BLC_PWM_CTL2(pipe),
> BLM_PWM_ENABLE, 0);
>  }
> 
>  static void bxt_disable_backlight(const struct drm_connector_state
> *old_conn_state, u32 val)
>  {
>  	struct intel_connector *connector =
> to_intel_connector(old_conn_state->connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
> 
>  	intel_backlight_set_pwm_level(old_conn_state, val);
> 
> -	intel_de_rmw(i915, BXT_BLC_PWM_CTL(panel->backlight.controller),
> +	intel_de_rmw(display, BXT_BLC_PWM_CTL(panel-
> >backlight.controller),
>  		     BXT_BLC_PWM_ENABLE, 0);
> 
>  	if (panel->backlight.controller == 1)
> -		intel_de_rmw(i915, UTIL_PIN_CTL, UTIL_PIN_ENABLE, 0);
> +		intel_de_rmw(display, UTIL_PIN_CTL, UTIL_PIN_ENABLE, 0);
>  }
> 
>  static void cnp_disable_backlight(const struct drm_connector_state
> *old_conn_state, u32 val)
>  {
>  	struct intel_connector *connector =
> to_intel_connector(old_conn_state->connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
> 
>  	intel_backlight_set_pwm_level(old_conn_state, val);
> 
> -	intel_de_rmw(i915, BXT_BLC_PWM_CTL(panel->backlight.controller),
> +	intel_de_rmw(display, BXT_BLC_PWM_CTL(panel-
> >backlight.controller),
>  		     BXT_BLC_PWM_ENABLE, 0);
>  }
> 
> @@ -436,7 +439,7 @@ static void ext_pwm_disable_backlight(const struct
> drm_connector_state *old_conn
>  void intel_backlight_disable(const struct drm_connector_state
> *old_conn_state)
>  {
>  	struct intel_connector *connector =
> to_intel_connector(old_conn_state->connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
> 
>  	if (!panel->backlight.present)
> @@ -448,49 +451,51 @@ void intel_backlight_disable(const struct
> drm_connector_state *old_conn_state)
>  	 * backlight. This will leave the backlight on unnecessarily when
>  	 * another client is not activated.
>  	 */
> -	if (i915->drm.switch_power_state ==
> DRM_SWITCH_POWER_CHANGING) {
> -		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] Skipping
> backlight disable on vga switch\n",
> +	if (display->drm->switch_power_state ==
> DRM_SWITCH_POWER_CHANGING) {
> +		drm_dbg_kms(display->drm, "[CONNECTOR:%d:%s] Skipping
> backlight disable on vga switch\n",
>  			    connector->base.base.id, connector->base.name);
>  		return;
>  	}
> 
> -	mutex_lock(&i915->display.backlight.lock);
> +	mutex_lock(&display->backlight.lock);
> 
>  	if (panel->backlight.device)
>  		panel->backlight.device->props.power =
> BACKLIGHT_POWER_OFF;
>  	panel->backlight.enabled = false;
>  	panel->backlight.funcs->disable(old_conn_state, 0);
> 
> -	mutex_unlock(&i915->display.backlight.lock);
> +	mutex_unlock(&display->backlight.lock);
>  }
> 
>  static void lpt_enable_backlight(const struct intel_crtc_state *crtc_state,
>  				 const struct drm_connector_state
> *conn_state, u32 level)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct drm_i915_private *i915 = to_i915(connector->base.dev);
>  	struct intel_panel *panel = &connector->panel;
>  	u32 pch_ctl1, pch_ctl2;
> 
> -	pch_ctl1 = intel_de_read(i915, BLC_PWM_PCH_CTL1);
> +	pch_ctl1 = intel_de_read(display, BLC_PWM_PCH_CTL1);
>  	if (pch_ctl1 & BLM_PCH_PWM_ENABLE) {
> -		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] PCH
> backlight already enabled\n",
> +		drm_dbg_kms(display->drm,
> +			    "[CONNECTOR:%d:%s] PCH backlight already
> enabled\n",
>  			    connector->base.base.id, connector->base.name);
>  		pch_ctl1 &= ~BLM_PCH_PWM_ENABLE;
> -		intel_de_write(i915, BLC_PWM_PCH_CTL1, pch_ctl1);
> +		intel_de_write(display, BLC_PWM_PCH_CTL1, pch_ctl1);
>  	}
> 
>  	if (HAS_PCH_LPT(i915))
> -		intel_de_rmw(i915, SOUTH_CHICKEN2,
> LPT_PWM_GRANULARITY,
> +		intel_de_rmw(display, SOUTH_CHICKEN2,
> LPT_PWM_GRANULARITY,
>  			     panel->backlight.alternate_pwm_increment ?
>  			     LPT_PWM_GRANULARITY : 0);
>  	else
> -		intel_de_rmw(i915, SOUTH_CHICKEN1,
> SPT_PWM_GRANULARITY,
> +		intel_de_rmw(display, SOUTH_CHICKEN1,
> SPT_PWM_GRANULARITY,
>  			     panel->backlight.alternate_pwm_increment ?
>  			     SPT_PWM_GRANULARITY : 0);
> 
>  	pch_ctl2 = panel->backlight.pwm_level_max << 16;
> -	intel_de_write(i915, BLC_PWM_PCH_CTL2, pch_ctl2);
> +	intel_de_write(display, BLC_PWM_PCH_CTL2, pch_ctl2);
> 
>  	pch_ctl1 = 0;
>  	if (panel->backlight.active_low_pwm)
> @@ -500,9 +505,9 @@ static void lpt_enable_backlight(const struct
> intel_crtc_state *crtc_state,
>  	if (HAS_PCH_LPT(i915))
>  		pch_ctl1 |= BLM_PCH_OVERRIDE_ENABLE;
> 
> -	intel_de_write(i915, BLC_PWM_PCH_CTL1, pch_ctl1);
> -	intel_de_posting_read(i915, BLC_PWM_PCH_CTL1);
> -	intel_de_write(i915, BLC_PWM_PCH_CTL1, pch_ctl1 |
> BLM_PCH_PWM_ENABLE);
> +	intel_de_write(display, BLC_PWM_PCH_CTL1, pch_ctl1);
> +	intel_de_posting_read(display, BLC_PWM_PCH_CTL1);
> +	intel_de_write(display, BLC_PWM_PCH_CTL1, pch_ctl1 |
> BLM_PCH_PWM_ENABLE);
> 
>  	/* This won't stick until the above enable. */
>  	intel_backlight_set_pwm_level(conn_state, level);
> @@ -512,63 +517,66 @@ static void pch_enable_backlight(const struct
> intel_crtc_state *crtc_state,
>  				 const struct drm_connector_state
> *conn_state, u32 level)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	enum transcoder cpu_transcoder = crtc_state->cpu_transcoder;
>  	u32 cpu_ctl2, pch_ctl1, pch_ctl2;
> 
> -	cpu_ctl2 = intel_de_read(i915, BLC_PWM_CPU_CTL2);
> +	cpu_ctl2 = intel_de_read(display, BLC_PWM_CPU_CTL2);
>  	if (cpu_ctl2 & BLM_PWM_ENABLE) {
> -		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] CPU
> backlight already enabled\n",
> +		drm_dbg_kms(display->drm,
> +			    "[CONNECTOR:%d:%s] CPU backlight already
> enabled\n",
>  			    connector->base.base.id, connector->base.name);
>  		cpu_ctl2 &= ~BLM_PWM_ENABLE;
> -		intel_de_write(i915, BLC_PWM_CPU_CTL2, cpu_ctl2);
> +		intel_de_write(display, BLC_PWM_CPU_CTL2, cpu_ctl2);
>  	}
> 
> -	pch_ctl1 = intel_de_read(i915, BLC_PWM_PCH_CTL1);
> +	pch_ctl1 = intel_de_read(display, BLC_PWM_PCH_CTL1);
>  	if (pch_ctl1 & BLM_PCH_PWM_ENABLE) {
> -		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] PCH
> backlight already enabled\n",
> +		drm_dbg_kms(display->drm,
> +			    "[CONNECTOR:%d:%s] PCH backlight already
> enabled\n",
>  			    connector->base.base.id, connector->base.name);
>  		pch_ctl1 &= ~BLM_PCH_PWM_ENABLE;
> -		intel_de_write(i915, BLC_PWM_PCH_CTL1, pch_ctl1);
> +		intel_de_write(display, BLC_PWM_PCH_CTL1, pch_ctl1);
>  	}
> 
>  	if (cpu_transcoder == TRANSCODER_EDP)
>  		cpu_ctl2 = BLM_TRANSCODER_EDP;
>  	else
>  		cpu_ctl2 = BLM_PIPE(cpu_transcoder);
> -	intel_de_write(i915, BLC_PWM_CPU_CTL2, cpu_ctl2);
> -	intel_de_posting_read(i915, BLC_PWM_CPU_CTL2);
> -	intel_de_write(i915, BLC_PWM_CPU_CTL2, cpu_ctl2 |
> BLM_PWM_ENABLE);
> +	intel_de_write(display, BLC_PWM_CPU_CTL2, cpu_ctl2);
> +	intel_de_posting_read(display, BLC_PWM_CPU_CTL2);
> +	intel_de_write(display, BLC_PWM_CPU_CTL2, cpu_ctl2 |
> BLM_PWM_ENABLE);
> 
>  	/* This won't stick until the above enable. */
>  	intel_backlight_set_pwm_level(conn_state, level);
> 
>  	pch_ctl2 = panel->backlight.pwm_level_max << 16;
> -	intel_de_write(i915, BLC_PWM_PCH_CTL2, pch_ctl2);
> +	intel_de_write(display, BLC_PWM_PCH_CTL2, pch_ctl2);
> 
>  	pch_ctl1 = 0;
>  	if (panel->backlight.active_low_pwm)
>  		pch_ctl1 |= BLM_PCH_POLARITY;
> 
> -	intel_de_write(i915, BLC_PWM_PCH_CTL1, pch_ctl1);
> -	intel_de_posting_read(i915, BLC_PWM_PCH_CTL1);
> -	intel_de_write(i915, BLC_PWM_PCH_CTL1, pch_ctl1 |
> BLM_PCH_PWM_ENABLE);
> +	intel_de_write(display, BLC_PWM_PCH_CTL1, pch_ctl1);
> +	intel_de_posting_read(display, BLC_PWM_PCH_CTL1);
> +	intel_de_write(display, BLC_PWM_PCH_CTL1, pch_ctl1 |
> BLM_PCH_PWM_ENABLE);
>  }
> 
>  static void i9xx_enable_backlight(const struct intel_crtc_state *crtc_state,
>  				  const struct drm_connector_state
> *conn_state, u32 level)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	u32 ctl, freq;
> 
> -	ctl = intel_de_read(i915, BLC_PWM_CTL);
> +	ctl = intel_de_read(display, BLC_PWM_CTL);
>  	if (ctl & BACKLIGHT_DUTY_CYCLE_MASK_PNV) {
> -		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] backlight
> already enabled\n",
> +		drm_dbg_kms(display->drm,
> +			    "[CONNECTOR:%d:%s] backlight already
> enabled\n",
>  			    connector->base.base.id, connector->base.name);
> -		intel_de_write(i915, BLC_PWM_CTL, 0);
> +		intel_de_write(display, BLC_PWM_CTL, 0);
>  	}
> 
>  	freq = panel->backlight.pwm_level_max;
> @@ -578,11 +586,11 @@ static void i9xx_enable_backlight(const struct
> intel_crtc_state *crtc_state,
>  	ctl = freq << 17;
>  	if (panel->backlight.combination_mode)
>  		ctl |= BLM_LEGACY_MODE;
> -	if (IS_PINEVIEW(i915) && panel->backlight.active_low_pwm)
> +	if (display->platform.pineview && panel->backlight.active_low_pwm)
>  		ctl |= BLM_POLARITY_PNV;
> 
> -	intel_de_write(i915, BLC_PWM_CTL, ctl);
> -	intel_de_posting_read(i915, BLC_PWM_CTL);
> +	intel_de_write(display, BLC_PWM_CTL, ctl);
> +	intel_de_posting_read(display, BLC_PWM_CTL);
> 
>  	/* XXX: combine this into above write? */
>  	intel_backlight_set_pwm_level(conn_state, level);
> @@ -592,25 +600,26 @@ static void i9xx_enable_backlight(const struct
> intel_crtc_state *crtc_state,
>  	 * 855gm only, but checking for gen2 is safe, as 855gm is the only gen2
>  	 * that has backlight.
>  	 */
> -	if (DISPLAY_VER(i915) == 2)
> -		intel_de_write(i915, BLC_HIST_CTL,
> BLM_HISTOGRAM_ENABLE);
> +	if (DISPLAY_VER(display) == 2)
> +		intel_de_write(display, BLC_HIST_CTL,
> BLM_HISTOGRAM_ENABLE);
>  }
> 
>  static void i965_enable_backlight(const struct intel_crtc_state *crtc_state,
>  				  const struct drm_connector_state
> *conn_state, u32 level)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	enum pipe pipe = to_intel_crtc(conn_state->crtc)->pipe;
>  	u32 ctl, ctl2, freq;
> 
> -	ctl2 = intel_de_read(i915, BLC_PWM_CTL2);
> +	ctl2 = intel_de_read(display, BLC_PWM_CTL2);
>  	if (ctl2 & BLM_PWM_ENABLE) {
> -		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] backlight
> already enabled\n",
> +		drm_dbg_kms(display->drm,
> +			    "[CONNECTOR:%d:%s] backlight already
> enabled\n",
>  			    connector->base.base.id, connector->base.name);
>  		ctl2 &= ~BLM_PWM_ENABLE;
> -		intel_de_write(i915, BLC_PWM_CTL2, ctl2);
> +		intel_de_write(display, BLC_PWM_CTL2, ctl2);
>  	}
> 
>  	freq = panel->backlight.pwm_level_max;
> @@ -618,16 +627,16 @@ static void i965_enable_backlight(const struct
> intel_crtc_state *crtc_state,
>  		freq /= 0xff;
> 
>  	ctl = freq << 16;
> -	intel_de_write(i915, BLC_PWM_CTL, ctl);
> +	intel_de_write(display, BLC_PWM_CTL, ctl);
> 
>  	ctl2 = BLM_PIPE(pipe);
>  	if (panel->backlight.combination_mode)
>  		ctl2 |= BLM_COMBINATION_MODE;
>  	if (panel->backlight.active_low_pwm)
>  		ctl2 |= BLM_POLARITY_I965;
> -	intel_de_write(i915, BLC_PWM_CTL2, ctl2);
> -	intel_de_posting_read(i915, BLC_PWM_CTL2);
> -	intel_de_write(i915, BLC_PWM_CTL2, ctl2 | BLM_PWM_ENABLE);
> +	intel_de_write(display, BLC_PWM_CTL2, ctl2);
> +	intel_de_posting_read(display, BLC_PWM_CTL2);
> +	intel_de_write(display, BLC_PWM_CTL2, ctl2 | BLM_PWM_ENABLE);
> 
>  	intel_backlight_set_pwm_level(conn_state, level);
>  }
> @@ -636,21 +645,22 @@ static void vlv_enable_backlight(const struct
> intel_crtc_state *crtc_state,
>  				 const struct drm_connector_state
> *conn_state, u32 level)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	enum pipe pipe = to_intel_crtc(crtc_state->uapi.crtc)->pipe;
>  	u32 ctl, ctl2;
> 
> -	ctl2 = intel_de_read(i915, VLV_BLC_PWM_CTL2(pipe));
> +	ctl2 = intel_de_read(display, VLV_BLC_PWM_CTL2(pipe));
>  	if (ctl2 & BLM_PWM_ENABLE) {
> -		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] backlight
> already enabled\n",
> +		drm_dbg_kms(display->drm,
> +			    "[CONNECTOR:%d:%s] backlight already
> enabled\n",
>  			    connector->base.base.id, connector->base.name);
>  		ctl2 &= ~BLM_PWM_ENABLE;
> -		intel_de_write(i915, VLV_BLC_PWM_CTL2(pipe), ctl2);
> +		intel_de_write(display, VLV_BLC_PWM_CTL2(pipe), ctl2);
>  	}
> 
>  	ctl = panel->backlight.pwm_level_max << 16;
> -	intel_de_write(i915, VLV_BLC_PWM_CTL(pipe), ctl);
> +	intel_de_write(display, VLV_BLC_PWM_CTL(pipe), ctl);
> 
>  	/* XXX: combine this into above write? */
>  	intel_backlight_set_pwm_level(conn_state, level);
> @@ -658,47 +668,49 @@ static void vlv_enable_backlight(const struct
> intel_crtc_state *crtc_state,
>  	ctl2 = 0;
>  	if (panel->backlight.active_low_pwm)
>  		ctl2 |= BLM_POLARITY_I965;
> -	intel_de_write(i915, VLV_BLC_PWM_CTL2(pipe), ctl2);
> -	intel_de_posting_read(i915, VLV_BLC_PWM_CTL2(pipe));
> -	intel_de_write(i915, VLV_BLC_PWM_CTL2(pipe), ctl2 |
> BLM_PWM_ENABLE);
> +	intel_de_write(display, VLV_BLC_PWM_CTL2(pipe), ctl2);
> +	intel_de_posting_read(display, VLV_BLC_PWM_CTL2(pipe));
> +	intel_de_write(display, VLV_BLC_PWM_CTL2(pipe), ctl2 |
> BLM_PWM_ENABLE);
>  }
> 
>  static void bxt_enable_backlight(const struct intel_crtc_state *crtc_state,
>  				 const struct drm_connector_state
> *conn_state, u32 level)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	enum pipe pipe = to_intel_crtc(crtc_state->uapi.crtc)->pipe;
>  	u32 pwm_ctl, val;
> 
>  	/* Controller 1 uses the utility pin. */
>  	if (panel->backlight.controller == 1) {
> -		val = intel_de_read(i915, UTIL_PIN_CTL);
> +		val = intel_de_read(display, UTIL_PIN_CTL);
>  		if (val & UTIL_PIN_ENABLE) {
> -			drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s]
> utility pin already enabled\n",
> +			drm_dbg_kms(display->drm,
> +				    "[CONNECTOR:%d:%s] utility pin already
> enabled\n",
>  				    connector->base.base.id, connector-
> >base.name);
>  			val &= ~UTIL_PIN_ENABLE;
> -			intel_de_write(i915, UTIL_PIN_CTL, val);
> +			intel_de_write(display, UTIL_PIN_CTL, val);
>  		}
> 
>  		val = 0;
>  		if (panel->backlight.util_pin_active_low)
>  			val |= UTIL_PIN_POLARITY;
> -		intel_de_write(i915, UTIL_PIN_CTL,
> +		intel_de_write(display, UTIL_PIN_CTL,
>  			       val | UTIL_PIN_PIPE(pipe) |
> UTIL_PIN_MODE_PWM | UTIL_PIN_ENABLE);
>  	}
> 
> -	pwm_ctl = intel_de_read(i915, BXT_BLC_PWM_CTL(panel-
> >backlight.controller));
> +	pwm_ctl = intel_de_read(display, BXT_BLC_PWM_CTL(panel-
> >backlight.controller));
>  	if (pwm_ctl & BXT_BLC_PWM_ENABLE) {
> -		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] backlight
> already enabled\n",
> +		drm_dbg_kms(display->drm,
> +			    "[CONNECTOR:%d:%s] backlight already
> enabled\n",
>  			    connector->base.base.id, connector->base.name);
>  		pwm_ctl &= ~BXT_BLC_PWM_ENABLE;
> -		intel_de_write(i915, BXT_BLC_PWM_CTL(panel-
> >backlight.controller),
> +		intel_de_write(display, BXT_BLC_PWM_CTL(panel-
> >backlight.controller),
>  			       pwm_ctl);
>  	}
> 
> -	intel_de_write(i915, BXT_BLC_PWM_FREQ(panel-
> >backlight.controller),
> +	intel_de_write(display, BXT_BLC_PWM_FREQ(panel-
> >backlight.controller),
>  		       panel->backlight.pwm_level_max);
> 
>  	intel_backlight_set_pwm_level(conn_state, level);
> @@ -707,9 +719,9 @@ static void bxt_enable_backlight(const struct
> intel_crtc_state *crtc_state,
>  	if (panel->backlight.active_low_pwm)
>  		pwm_ctl |= BXT_BLC_PWM_POLARITY;
> 
> -	intel_de_write(i915, BXT_BLC_PWM_CTL(panel->backlight.controller),
> pwm_ctl);
> -	intel_de_posting_read(i915, BXT_BLC_PWM_CTL(panel-
> >backlight.controller));
> -	intel_de_write(i915, BXT_BLC_PWM_CTL(panel->backlight.controller),
> +	intel_de_write(display, BXT_BLC_PWM_CTL(panel-
> >backlight.controller), pwm_ctl);
> +	intel_de_posting_read(display, BXT_BLC_PWM_CTL(panel-
> >backlight.controller));
> +	intel_de_write(display, BXT_BLC_PWM_CTL(panel-
> >backlight.controller),
>  		       pwm_ctl | BXT_BLC_PWM_ENABLE);
>  }
> 
> @@ -717,19 +729,19 @@ static void cnp_enable_backlight(const struct
> intel_crtc_state *crtc_state,
>  				 const struct drm_connector_state
> *conn_state, u32 level)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	u32 pwm_ctl;
> 
> -	pwm_ctl = intel_de_read(i915, BXT_BLC_PWM_CTL(panel-
> >backlight.controller));
> +	pwm_ctl = intel_de_read(display, BXT_BLC_PWM_CTL(panel-
> >backlight.controller));
>  	if (pwm_ctl & BXT_BLC_PWM_ENABLE) {
> -		drm_dbg_kms(&i915->drm, "backlight already enabled\n");
> +		drm_dbg_kms(display->drm, "backlight already enabled\n");
>  		pwm_ctl &= ~BXT_BLC_PWM_ENABLE;
> -		intel_de_write(i915, BXT_BLC_PWM_CTL(panel-
> >backlight.controller),
> +		intel_de_write(display, BXT_BLC_PWM_CTL(panel-
> >backlight.controller),
>  			       pwm_ctl);
>  	}
> 
> -	intel_de_write(i915, BXT_BLC_PWM_FREQ(panel-
> >backlight.controller),
> +	intel_de_write(display, BXT_BLC_PWM_FREQ(panel-
> >backlight.controller),
>  		       panel->backlight.pwm_level_max);
> 
>  	intel_backlight_set_pwm_level(conn_state, level);
> @@ -738,9 +750,9 @@ static void cnp_enable_backlight(const struct
> intel_crtc_state *crtc_state,
>  	if (panel->backlight.active_low_pwm)
>  		pwm_ctl |= BXT_BLC_PWM_POLARITY;
> 
> -	intel_de_write(i915, BXT_BLC_PWM_CTL(panel->backlight.controller),
> pwm_ctl);
> -	intel_de_posting_read(i915, BXT_BLC_PWM_CTL(panel-
> >backlight.controller));
> -	intel_de_write(i915, BXT_BLC_PWM_CTL(panel->backlight.controller),
> +	intel_de_write(display, BXT_BLC_PWM_CTL(panel-
> >backlight.controller), pwm_ctl);
> +	intel_de_posting_read(display, BXT_BLC_PWM_CTL(panel-
> >backlight.controller));
> +	intel_de_write(display, BXT_BLC_PWM_CTL(panel-
> >backlight.controller),
>  		       pwm_ctl | BXT_BLC_PWM_ENABLE);
>  }
> 
> @@ -782,37 +794,37 @@ void intel_backlight_enable(const struct
> intel_crtc_state *crtc_state,
>  			    const struct drm_connector_state *conn_state)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	enum pipe pipe = to_intel_crtc(crtc_state->uapi.crtc)->pipe;
> 
>  	if (!panel->backlight.present)
>  		return;
> 
> -	drm_dbg_kms(&i915->drm, "pipe %c\n", pipe_name(pipe));
> +	drm_dbg_kms(display->drm, "pipe %c\n", pipe_name(pipe));
> 
> -	mutex_lock(&i915->display.backlight.lock);
> +	mutex_lock(&display->backlight.lock);
> 
>  	__intel_backlight_enable(crtc_state, conn_state);
> 
> -	mutex_unlock(&i915->display.backlight.lock);
> +	mutex_unlock(&display->backlight.lock);
>  }
> 
>  #if IS_ENABLED(CONFIG_BACKLIGHT_CLASS_DEVICE)
>  static u32 intel_panel_get_backlight(struct intel_connector *connector)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	u32 val = 0;
> 
> -	mutex_lock(&i915->display.backlight.lock);
> +	mutex_lock(&display->backlight.lock);
> 
>  	if (panel->backlight.enabled)
>  		val = panel->backlight.funcs->get(connector,
> intel_connector_get_pipe(connector));
> 
> -	mutex_unlock(&i915->display.backlight.lock);
> +	mutex_unlock(&display->backlight.lock);
> 
> -	drm_dbg_kms(&i915->drm, "get backlight PWM = %d\n", val);
> +	drm_dbg_kms(display->drm, "get backlight PWM = %d\n", val);
>  	return val;
>  }
> 
> @@ -831,16 +843,16 @@ static void intel_panel_set_backlight(const struct
> drm_connector_state *conn_sta
>  				      u32 user_level, u32 user_max)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	u32 hw_level;
> 
>  	if (!panel->backlight.present)
>  		return;
> 
> -	mutex_lock(&i915->display.backlight.lock);
> +	mutex_lock(&display->backlight.lock);
> 
> -	drm_WARN_ON(&i915->drm, panel->backlight.max == 0);
> +	drm_WARN_ON(display->drm, panel->backlight.max == 0);
> 
>  	hw_level = scale_user_to_hw(connector, user_level, user_max);
>  	panel->backlight.level = hw_level;
> @@ -848,18 +860,18 @@ static void intel_panel_set_backlight(const struct
> drm_connector_state *conn_sta
>  	if (panel->backlight.enabled)
>  		intel_panel_actually_set_backlight(conn_state, hw_level);
> 
> -	mutex_unlock(&i915->display.backlight.lock);
> +	mutex_unlock(&display->backlight.lock);
>  }
> 
>  static int intel_backlight_device_update_status(struct backlight_device *bd)
>  {
>  	struct intel_connector *connector = bl_get_data(bd);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
> 
> -	drm_modeset_lock(&i915->drm.mode_config.connection_mutex,
> NULL);
> +	drm_modeset_lock(&display->drm-
> >mode_config.connection_mutex, NULL);
> 
> -	drm_dbg_kms(&i915->drm, "updating intel_backlight,
> brightness=%d/%d\n",
> +	drm_dbg_kms(display->drm, "updating intel_backlight,
> brightness=%d/%d\n",
>  		    bd->props.brightness, bd->props.max_brightness);
>  	intel_panel_set_backlight(connector->base.state, bd-
> >props.brightness,
>  				  bd->props.max_brightness);
> @@ -880,7 +892,7 @@ static int intel_backlight_device_update_status(struct
> backlight_device *bd)
>  		bd->props.power = BACKLIGHT_POWER_OFF;
>  	}
> 
> -	drm_modeset_unlock(&i915->drm.mode_config.connection_mutex);
> +	drm_modeset_unlock(&display->drm-
> >mode_config.connection_mutex);
> 
>  	return 0;
>  }
> @@ -888,6 +900,7 @@ static int intel_backlight_device_update_status(struct
> backlight_device *bd)
>  static int intel_backlight_device_get_brightness(struct backlight_device *bd)
>  {
>  	struct intel_connector *connector = bl_get_data(bd);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct drm_i915_private *i915 = to_i915(connector->base.dev);
>  	intel_wakeref_t wakeref;
>  	int ret = 0;
> @@ -895,13 +908,13 @@ static int
> intel_backlight_device_get_brightness(struct backlight_device *bd)
>  	with_intel_runtime_pm(&i915->runtime_pm, wakeref) {
>  		u32 hw_level;
> 
> -		drm_modeset_lock(&i915-
> >drm.mode_config.connection_mutex, NULL);
> +		drm_modeset_lock(&display->drm-
> >mode_config.connection_mutex, NULL);
> 
>  		hw_level = intel_panel_get_backlight(connector);
>  		ret = scale_hw_to_user(connector,
>  				       hw_level, bd->props.max_brightness);
> 
> -		drm_modeset_unlock(&i915-
> >drm.mode_config.connection_mutex);
> +		drm_modeset_unlock(&display->drm-
> >mode_config.connection_mutex);
>  	}
> 
>  	return ret;
> @@ -914,7 +927,7 @@ static const struct backlight_ops
> intel_backlight_device_ops = {
> 
>  int intel_backlight_device_register(struct intel_connector *connector)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	struct backlight_properties props;
>  	struct backlight_device *bd;
> @@ -930,7 +943,8 @@ int intel_backlight_device_register(struct
> intel_connector *connector)
>  	WARN_ON(panel->backlight.max == 0);
> 
>  	if (!acpi_video_backlight_use_native()) {
> -		drm_info(&i915->drm, "Skipping intel_backlight
> registration\n");
> +		drm_info(display->drm,
> +			 "Skipping intel_backlight registration\n");
>  		return 0;
>  	}
> 
> @@ -967,7 +981,8 @@ int intel_backlight_device_register(struct
> intel_connector *connector)
>  		 */
>  		kfree(name);
>  		name = kasprintf(GFP_KERNEL, "card%d-%s-backlight",
> -				 i915->drm.primary->index, connector-
> >base.name);
> +				 display->drm->primary->index,
> +				 connector->base.name);
>  		if (!name)
>  			return -ENOMEM;
>  	}
> @@ -975,7 +990,7 @@ int intel_backlight_device_register(struct
> intel_connector *connector)
>  				       &intel_backlight_device_ops, &props);
> 
>  	if (IS_ERR(bd)) {
> -		drm_err(&i915->drm,
> +		drm_err(display->drm,
>  			"[CONNECTOR:%d:%s] backlight device %s register
> failed: %ld\n",
>  			connector->base.base.id, connector->base.name,
> name, PTR_ERR(bd));
>  		ret = PTR_ERR(bd);
> @@ -984,7 +999,7 @@ int intel_backlight_device_register(struct
> intel_connector *connector)
> 
>  	panel->backlight.device = bd;
> 
> -	drm_dbg_kms(&i915->drm,
> +	drm_dbg_kms(display->drm,
>  		    "[CONNECTOR:%d:%s] backlight device %s registered\n",
>  		    connector->base.base.id, connector->base.name, name);
> 
> @@ -1011,9 +1026,9 @@ void intel_backlight_device_unregister(struct
> intel_connector *connector)
>   */
>  static u32 cnp_hz_to_pwm(struct intel_connector *connector, u32
> pwm_freq_hz)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
> 
> -	return DIV_ROUND_CLOSEST(KHz(DISPLAY_RUNTIME_INFO(i915)-
> >rawclk_freq),
> +	return DIV_ROUND_CLOSEST(KHz(DISPLAY_RUNTIME_INFO(display)-
> >rawclk_freq),
>  				 pwm_freq_hz);
>  }
> 
> @@ -1073,9 +1088,9 @@ static u32 lpt_hz_to_pwm(struct intel_connector
> *connector, u32 pwm_freq_hz)
>   */
>  static u32 pch_hz_to_pwm(struct intel_connector *connector, u32
> pwm_freq_hz)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
> 
> -	return DIV_ROUND_CLOSEST(KHz(DISPLAY_RUNTIME_INFO(i915)-
> >rawclk_freq),
> +	return DIV_ROUND_CLOSEST(KHz(DISPLAY_RUNTIME_INFO(display)-
> >rawclk_freq),
>  				 pwm_freq_hz * 128);
>  }
> 
> @@ -1089,13 +1104,13 @@ static u32 pch_hz_to_pwm(struct
> intel_connector *connector, u32 pwm_freq_hz)
>   */
>  static u32 i9xx_hz_to_pwm(struct intel_connector *connector, u32
> pwm_freq_hz)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	int clock;
> 
> -	if (IS_PINEVIEW(i915))
> -		clock = KHz(DISPLAY_RUNTIME_INFO(i915)->rawclk_freq);
> +	if (display->platform.pineview)
> +		clock = KHz(DISPLAY_RUNTIME_INFO(display)->rawclk_freq);
>  	else
> -		clock = KHz(i915->display.cdclk.hw.cdclk);
> +		clock = KHz(display->cdclk.hw.cdclk);
> 
>  	return DIV_ROUND_CLOSEST(clock, pwm_freq_hz * 32);
>  }
> @@ -1107,13 +1122,13 @@ static u32 i9xx_hz_to_pwm(struct
> intel_connector *connector, u32 pwm_freq_hz)
>   */
>  static u32 i965_hz_to_pwm(struct intel_connector *connector, u32
> pwm_freq_hz)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	int clock;
> 
> -	if (IS_G4X(i915))
> -		clock = KHz(DISPLAY_RUNTIME_INFO(i915)->rawclk_freq);
> +	if (display->platform.g4x)
> +		clock = KHz(DISPLAY_RUNTIME_INFO(display)->rawclk_freq);
>  	else
> -		clock = KHz(i915->display.cdclk.hw.cdclk);
> +		clock = KHz(display->cdclk.hw.cdclk);
> 
>  	return DIV_ROUND_CLOSEST(clock, pwm_freq_hz * 128);
>  }
> @@ -1125,17 +1140,17 @@ static u32 i965_hz_to_pwm(struct
> intel_connector *connector, u32 pwm_freq_hz)
>   */
>  static u32 vlv_hz_to_pwm(struct intel_connector *connector, u32
> pwm_freq_hz)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	int mul, clock;
> 
> -	if ((intel_de_read(i915, CBR1_VLV) &
> CBR_PWM_CLOCK_MUX_SELECT) == 0) {
> -		if (IS_CHERRYVIEW(i915))
> +	if ((intel_de_read(display, CBR1_VLV) &
> CBR_PWM_CLOCK_MUX_SELECT) == 0) {
> +		if (display->platform.cherryview)
>  			clock = KHz(19200);
>  		else
>  			clock = MHz(25);
>  		mul = 16;
>  	} else {
> -		clock = KHz(DISPLAY_RUNTIME_INFO(i915)->rawclk_freq);
> +		clock = KHz(DISPLAY_RUNTIME_INFO(display)->rawclk_freq);
>  		mul = 128;
>  	}
> 
> @@ -1144,16 +1159,16 @@ static u32 vlv_hz_to_pwm(struct intel_connector
> *connector, u32 pwm_freq_hz)
> 
>  static u16 get_vbt_pwm_freq(struct intel_connector *connector)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	u16 pwm_freq_hz = connector->panel.vbt.backlight.pwm_freq_hz;
> 
>  	if (pwm_freq_hz) {
> -		drm_dbg_kms(&i915->drm,
> +		drm_dbg_kms(display->drm,
>  			    "VBT defined backlight frequency %u Hz\n",
>  			    pwm_freq_hz);
>  	} else {
>  		pwm_freq_hz = 200;
> -		drm_dbg_kms(&i915->drm,
> +		drm_dbg_kms(display->drm,
>  			    "default backlight frequency %u Hz\n",
>  			    pwm_freq_hz);
>  	}
> @@ -1163,20 +1178,20 @@ static u16 get_vbt_pwm_freq(struct
> intel_connector *connector)
> 
>  static u32 get_backlight_max_vbt(struct intel_connector *connector)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	u16 pwm_freq_hz = get_vbt_pwm_freq(connector);
>  	u32 pwm;
> 
>  	if (!panel->backlight.pwm_funcs->hz_to_pwm) {
> -		drm_dbg_kms(&i915->drm,
> +		drm_dbg_kms(display->drm,
>  			    "backlight frequency conversion not supported\n");
>  		return 0;
>  	}
> 
>  	pwm = panel->backlight.pwm_funcs->hz_to_pwm(connector,
> pwm_freq_hz);
>  	if (!pwm) {
> -		drm_dbg_kms(&i915->drm,
> +		drm_dbg_kms(display->drm,
>  			    "backlight frequency conversion failed\n");
>  		return 0;
>  	}
> @@ -1189,11 +1204,11 @@ static u32 get_backlight_max_vbt(struct
> intel_connector *connector)
>   */
>  static u32 get_backlight_min_vbt(struct intel_connector *connector)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	int min;
> 
> -	drm_WARN_ON(&i915->drm, panel->backlight.pwm_level_max == 0);
> +	drm_WARN_ON(display->drm, panel->backlight.pwm_level_max ==
> 0);
> 
>  	/*
>  	 * XXX: If the vbt value is 255, it makes min equal to max, which leads
> @@ -1204,7 +1219,7 @@ static u32 get_backlight_min_vbt(struct
> intel_connector *connector)
>  	 */
>  	min = clamp_t(int, connector->panel.vbt.backlight.min_brightness, 0,
> 64);
>  	if (min != connector->panel.vbt.backlight.min_brightness) {
> -		drm_dbg_kms(&i915->drm,
> +		drm_dbg_kms(display->drm,
>  			    "clamping VBT min backlight %d/255 to %d/255\n",
>  			    connector->panel.vbt.backlight.min_brightness,
> min);
>  	}
> @@ -1215,24 +1230,25 @@ static u32 get_backlight_min_vbt(struct
> intel_connector *connector)
> 
>  static int lpt_setup_backlight(struct intel_connector *connector, enum pipe
> unused)
>  {
> +	struct intel_display *display = to_intel_display(connector);
>  	struct drm_i915_private *i915 = to_i915(connector->base.dev);
>  	struct intel_panel *panel = &connector->panel;
>  	u32 cpu_ctl2, pch_ctl1, pch_ctl2, val;
>  	bool alt, cpu_mode;
> 
>  	if (HAS_PCH_LPT(i915))
> -		alt = intel_de_read(i915, SOUTH_CHICKEN2) &
> LPT_PWM_GRANULARITY;
> +		alt = intel_de_read(display, SOUTH_CHICKEN2) &
> LPT_PWM_GRANULARITY;
>  	else
> -		alt = intel_de_read(i915, SOUTH_CHICKEN1) &
> SPT_PWM_GRANULARITY;
> +		alt = intel_de_read(display, SOUTH_CHICKEN1) &
> SPT_PWM_GRANULARITY;
>  	panel->backlight.alternate_pwm_increment = alt;
> 
> -	pch_ctl1 = intel_de_read(i915, BLC_PWM_PCH_CTL1);
> +	pch_ctl1 = intel_de_read(display, BLC_PWM_PCH_CTL1);
>  	panel->backlight.active_low_pwm = pch_ctl1 & BLM_PCH_POLARITY;
> 
> -	pch_ctl2 = intel_de_read(i915, BLC_PWM_PCH_CTL2);
> +	pch_ctl2 = intel_de_read(display, BLC_PWM_PCH_CTL2);
>  	panel->backlight.pwm_level_max = pch_ctl2 >> 16;
> 
> -	cpu_ctl2 = intel_de_read(i915, BLC_PWM_CPU_CTL2);
> +	cpu_ctl2 = intel_de_read(display, BLC_PWM_CPU_CTL2);
> 
>  	if (!panel->backlight.pwm_level_max)
>  		panel->backlight.pwm_level_max =
> get_backlight_max_vbt(connector);
> @@ -1251,19 +1267,19 @@ static int lpt_setup_backlight(struct
> intel_connector *connector, enum pipe unus
>  	if (cpu_mode) {
>  		val = pch_get_backlight(connector, unused);
> 
> -		drm_dbg_kms(&i915->drm,
> +		drm_dbg_kms(display->drm,
>  			    "CPU backlight register was enabled, switching to
> PCH override\n");
> 
>  		/* Write converted CPU PWM value to PCH override register
> */
>  		lpt_set_backlight(connector->base.state, val);
> -		intel_de_write(i915, BLC_PWM_PCH_CTL1,
> +		intel_de_write(display, BLC_PWM_PCH_CTL1,
>  			       pch_ctl1 | BLM_PCH_OVERRIDE_ENABLE);
> 
> -		intel_de_write(i915, BLC_PWM_CPU_CTL2,
> +		intel_de_write(display, BLC_PWM_CPU_CTL2,
>  			       cpu_ctl2 & ~BLM_PWM_ENABLE);
>  	}
> 
> -	drm_dbg_kms(&i915->drm,
> +	drm_dbg_kms(display->drm,
>  		    "[CONNECTOR:%d:%s] Using native PCH PWM for backlight
> control\n",
>  		    connector->base.base.id, connector->base.name);
> 
> @@ -1272,14 +1288,14 @@ static int lpt_setup_backlight(struct
> intel_connector *connector, enum pipe unus
> 
>  static int pch_setup_backlight(struct intel_connector *connector, enum pipe
> unused)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	u32 cpu_ctl2, pch_ctl1, pch_ctl2;
> 
> -	pch_ctl1 = intel_de_read(i915, BLC_PWM_PCH_CTL1);
> +	pch_ctl1 = intel_de_read(display, BLC_PWM_PCH_CTL1);
>  	panel->backlight.active_low_pwm = pch_ctl1 & BLM_PCH_POLARITY;
> 
> -	pch_ctl2 = intel_de_read(i915, BLC_PWM_PCH_CTL2);
> +	pch_ctl2 = intel_de_read(display, BLC_PWM_PCH_CTL2);
>  	panel->backlight.pwm_level_max = pch_ctl2 >> 16;
> 
>  	if (!panel->backlight.pwm_level_max)
> @@ -1290,11 +1306,11 @@ static int pch_setup_backlight(struct
> intel_connector *connector, enum pipe unus
> 
>  	panel->backlight.pwm_level_min =
> get_backlight_min_vbt(connector);
> 
> -	cpu_ctl2 = intel_de_read(i915, BLC_PWM_CPU_CTL2);
> +	cpu_ctl2 = intel_de_read(display, BLC_PWM_CPU_CTL2);
>  	panel->backlight.pwm_enabled = (cpu_ctl2 & BLM_PWM_ENABLE)
> &&
>  		(pch_ctl1 & BLM_PCH_PWM_ENABLE);
> 
> -	drm_dbg_kms(&i915->drm,
> +	drm_dbg_kms(display->drm,
>  		    "[CONNECTOR:%d:%s] Using native PCH PWM for backlight
> control\n",
>  		    connector->base.base.id, connector->base.name);
> 
> @@ -1303,16 +1319,16 @@ static int pch_setup_backlight(struct
> intel_connector *connector, enum pipe unus
> 
>  static int i9xx_setup_backlight(struct intel_connector *connector, enum pipe
> unused)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	u32 ctl, val;
> 
> -	ctl = intel_de_read(i915, BLC_PWM_CTL);
> +	ctl = intel_de_read(display, BLC_PWM_CTL);
> 
> -	if (DISPLAY_VER(i915) == 2 || IS_I915GM(i915) || IS_I945GM(i915))
> +	if (DISPLAY_VER(display) == 2 || display->platform.i915gm || display-
> >platform.i945gm)
>  		panel->backlight.combination_mode = ctl &
> BLM_LEGACY_MODE;
> 
> -	if (IS_PINEVIEW(i915))
> +	if (display->platform.pineview)
>  		panel->backlight.active_low_pwm = ctl &
> BLM_POLARITY_PNV;
> 
>  	panel->backlight.pwm_level_max = ctl >> 17;
> @@ -1336,7 +1352,7 @@ static int i9xx_setup_backlight(struct
> intel_connector *connector, enum pipe unu
> 
>  	panel->backlight.pwm_enabled = val != 0;
> 
> -	drm_dbg_kms(&i915->drm,
> +	drm_dbg_kms(display->drm,
>  		    "[CONNECTOR:%d:%s] Using native PWM for backlight
> control\n",
>  		    connector->base.base.id, connector->base.name);
> 
> @@ -1345,15 +1361,15 @@ static int i9xx_setup_backlight(struct
> intel_connector *connector, enum pipe unu
> 
>  static int i965_setup_backlight(struct intel_connector *connector, enum pipe
> unused)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	u32 ctl, ctl2;
> 
> -	ctl2 = intel_de_read(i915, BLC_PWM_CTL2);
> +	ctl2 = intel_de_read(display, BLC_PWM_CTL2);
>  	panel->backlight.combination_mode = ctl2 &
> BLM_COMBINATION_MODE;
>  	panel->backlight.active_low_pwm = ctl2 & BLM_POLARITY_I965;
> 
> -	ctl = intel_de_read(i915, BLC_PWM_CTL);
> +	ctl = intel_de_read(display, BLC_PWM_CTL);
>  	panel->backlight.pwm_level_max = ctl >> 16;
> 
>  	if (!panel->backlight.pwm_level_max)
> @@ -1369,7 +1385,7 @@ static int i965_setup_backlight(struct
> intel_connector *connector, enum pipe unu
> 
>  	panel->backlight.pwm_enabled = ctl2 & BLM_PWM_ENABLE;
> 
> -	drm_dbg_kms(&i915->drm,
> +	drm_dbg_kms(display->drm,
>  		    "[CONNECTOR:%d:%s] Using native PWM for backlight
> control\n",
>  		    connector->base.base.id, connector->base.name);
> 
> @@ -1378,17 +1394,17 @@ static int i965_setup_backlight(struct
> intel_connector *connector, enum pipe unu
> 
>  static int vlv_setup_backlight(struct intel_connector *connector, enum pipe
> pipe)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	u32 ctl, ctl2;
> 
> -	if (drm_WARN_ON(&i915->drm, pipe != PIPE_A && pipe != PIPE_B))
> +	if (drm_WARN_ON(display->drm, pipe != PIPE_A && pipe != PIPE_B))
>  		return -ENODEV;
> 
> -	ctl2 = intel_de_read(i915, VLV_BLC_PWM_CTL2(pipe));
> +	ctl2 = intel_de_read(display, VLV_BLC_PWM_CTL2(pipe));
>  	panel->backlight.active_low_pwm = ctl2 & BLM_POLARITY_I965;
> 
> -	ctl = intel_de_read(i915, VLV_BLC_PWM_CTL(pipe));
> +	ctl = intel_de_read(display, VLV_BLC_PWM_CTL(pipe));
>  	panel->backlight.pwm_level_max = ctl >> 16;
> 
>  	if (!panel->backlight.pwm_level_max)
> @@ -1401,7 +1417,7 @@ static int vlv_setup_backlight(struct intel_connector
> *connector, enum pipe pipe
> 
>  	panel->backlight.pwm_enabled = ctl2 & BLM_PWM_ENABLE;
> 
> -	drm_dbg_kms(&i915->drm,
> +	drm_dbg_kms(display->drm,
>  		    "[CONNECTOR:%d:%s] Using native PWM for backlight
> control (on pipe %c)\n",
>  		    connector->base.base.id, connector->base.name,
> pipe_name(pipe));
> 
> @@ -1411,25 +1427,25 @@ static int vlv_setup_backlight(struct
> intel_connector *connector, enum pipe pipe
>  static int
>  bxt_setup_backlight(struct intel_connector *connector, enum pipe unused)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	u32 pwm_ctl, val;
> 
>  	panel->backlight.controller = connector-
> >panel.vbt.backlight.controller;
> 
> -	pwm_ctl = intel_de_read(i915,
> +	pwm_ctl = intel_de_read(display,
>  				BXT_BLC_PWM_CTL(panel-
> >backlight.controller));
> 
>  	/* Controller 1 uses the utility pin. */
>  	if (panel->backlight.controller == 1) {
> -		val = intel_de_read(i915, UTIL_PIN_CTL);
> +		val = intel_de_read(display, UTIL_PIN_CTL);
>  		panel->backlight.util_pin_active_low =
>  					val & UTIL_PIN_POLARITY;
>  	}
> 
>  	panel->backlight.active_low_pwm = pwm_ctl &
> BXT_BLC_PWM_POLARITY;
>  	panel->backlight.pwm_level_max =
> -		intel_de_read(i915, BXT_BLC_PWM_FREQ(panel-
> >backlight.controller));
> +		intel_de_read(display, BXT_BLC_PWM_FREQ(panel-
> >backlight.controller));
> 
>  	if (!panel->backlight.pwm_level_max)
>  		panel->backlight.pwm_level_max =
> get_backlight_max_vbt(connector);
> @@ -1441,7 +1457,7 @@ bxt_setup_backlight(struct intel_connector
> *connector, enum pipe unused)
> 
>  	panel->backlight.pwm_enabled = pwm_ctl & BXT_BLC_PWM_ENABLE;
> 
> -	drm_dbg_kms(&i915->drm,
> +	drm_dbg_kms(display->drm,
>  		    "[CONNECTOR:%d:%s] Using native PWM for backlight
> control (controller=%d)\n",
>  		    connector->base.base.id, connector->base.name,
>  		    panel->backlight.controller);
> @@ -1449,8 +1465,10 @@ bxt_setup_backlight(struct intel_connector
> *connector, enum pipe unused)
>  	return 0;
>  }
> 
> -static int cnp_num_backlight_controllers(struct drm_i915_private *i915)
> +static int cnp_num_backlight_controllers(struct intel_display *display)
>  {
> +	struct drm_i915_private *i915 = to_i915(display->drm);
> +
>  	if (INTEL_PCH_TYPE(i915) >= PCH_MTL)
>  		return 2;
> 
> @@ -1463,15 +1481,17 @@ static int cnp_num_backlight_controllers(struct
> drm_i915_private *i915)
>  	return 1;
>  }
> 
> -static bool cnp_backlight_controller_is_valid(struct drm_i915_private *i915,
> int controller)
> +static bool cnp_backlight_controller_is_valid(struct intel_display *display, int
> controller)
>  {
> -	if (controller < 0 || controller >=
> cnp_num_backlight_controllers(i915))
> +	struct drm_i915_private *i915 = to_i915(display->drm);
> +
> +	if (controller < 0 || controller >=
> cnp_num_backlight_controllers(display))
>  		return false;
> 
>  	if (controller == 1 &&
>  	    INTEL_PCH_TYPE(i915) >= PCH_ICP &&
>  	    INTEL_PCH_TYPE(i915) <= PCH_ADP)
> -		return intel_de_read(i915, SOUTH_CHICKEN1) &
> ICP_SECOND_PPS_IO_SELECT;
> +		return intel_de_read(display, SOUTH_CHICKEN1) &
> ICP_SECOND_PPS_IO_SELECT;
> 
>  	return true;
>  }
> @@ -1479,7 +1499,7 @@ static bool cnp_backlight_controller_is_valid(struct
> drm_i915_private *i915, int
>  static int
>  cnp_setup_backlight(struct intel_connector *connector, enum pipe unused)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	u32 pwm_ctl;
> 
> @@ -1488,19 +1508,20 @@ cnp_setup_backlight(struct intel_connector
> *connector, enum pipe unused)
>  	 * controller. ICP+ can have two controllers, depending on pin muxing.
>  	 */
>  	panel->backlight.controller = connector-
> >panel.vbt.backlight.controller;
> -	if (!cnp_backlight_controller_is_valid(i915, panel-
> >backlight.controller)) {
> -		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] Invalid
> backlight controller %d, assuming 0\n",
> +	if (!cnp_backlight_controller_is_valid(display, panel-
> >backlight.controller)) {
> +		drm_dbg_kms(display->drm,
> +			    "[CONNECTOR:%d:%s] Invalid backlight controller
> %d, assuming 0\n",
>  			    connector->base.base.id, connector->base.name,
>  			    panel->backlight.controller);
>  		panel->backlight.controller = 0;
>  	}
> 
> -	pwm_ctl = intel_de_read(i915,
> +	pwm_ctl = intel_de_read(display,
>  				BXT_BLC_PWM_CTL(panel-
> >backlight.controller));
> 
>  	panel->backlight.active_low_pwm = pwm_ctl &
> BXT_BLC_PWM_POLARITY;
>  	panel->backlight.pwm_level_max =
> -		intel_de_read(i915, BXT_BLC_PWM_FREQ(panel-
> >backlight.controller));
> +		intel_de_read(display, BXT_BLC_PWM_FREQ(panel-
> >backlight.controller));
> 
>  	if (!panel->backlight.pwm_level_max)
>  		panel->backlight.pwm_level_max =
> get_backlight_max_vbt(connector);
> @@ -1512,7 +1533,7 @@ cnp_setup_backlight(struct intel_connector
> *connector, enum pipe unused)
> 
>  	panel->backlight.pwm_enabled = pwm_ctl & BXT_BLC_PWM_ENABLE;
> 
> -	drm_dbg_kms(&i915->drm,
> +	drm_dbg_kms(display->drm,
>  		    "[CONNECTOR:%d:%s] Using native PCH PWM for backlight
> control (controller=%d)\n",
>  		    connector->base.base.id, connector->base.name,
>  		    panel->backlight.controller);
> @@ -1523,22 +1544,25 @@ cnp_setup_backlight(struct intel_connector
> *connector, enum pipe unused)
>  static int ext_pwm_setup_backlight(struct intel_connector *connector,
>  				   enum pipe pipe)
>  {
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
>  	const char *desc;
>  	u32 level;
> 
>  	/* Get the right PWM chip for DSI backlight according to VBT */
>  	if (connector->panel.vbt.dsi.config->pwm_blc == PPS_BLC_PMIC) {
> -		panel->backlight.pwm = pwm_get(i915->drm.dev,
> "pwm_pmic_backlight");
> +		panel->backlight.pwm = pwm_get(display->drm->dev,
> +					       "pwm_pmic_backlight");
>  		desc = "PMIC";
>  	} else {
> -		panel->backlight.pwm = pwm_get(i915->drm.dev,
> "pwm_soc_backlight");
> +		panel->backlight.pwm = pwm_get(display->drm->dev,
> +					       "pwm_soc_backlight");
>  		desc = "SoC";
>  	}
> 
>  	if (IS_ERR(panel->backlight.pwm)) {
> -		drm_err(&i915->drm, "[CONNECTOR:%d:%s] Failed to get the
> %s PWM chip\n",
> +		drm_err(display->drm,
> +			"[CONNECTOR:%d:%s] Failed to get the %s PWM
> chip\n",
>  			connector->base.base.id, connector->base.name,
> desc);
>  		panel->backlight.pwm = NULL;
>  		return -ENODEV;
> @@ -1556,7 +1580,8 @@ static int ext_pwm_setup_backlight(struct
> intel_connector *connector,
>  		level = intel_backlight_invert_pwm_level(connector, level);
>  		panel->backlight.pwm_enabled = true;
> 
> -		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] PWM
> already enabled at freq %ld, VBT freq %d, level %d\n",
> +		drm_dbg_kms(display->drm,
> +			    "[CONNECTOR:%d:%s] PWM already enabled at
> freq %ld, VBT freq %d, level %d\n",
>  			    connector->base.base.id, connector->base.name,
>  			    NSEC_PER_SEC / (unsigned long)panel-
> >backlight.pwm_state.period,
>  			    get_vbt_pwm_freq(connector), level);
> @@ -1566,7 +1591,7 @@ static int ext_pwm_setup_backlight(struct
> intel_connector *connector,
>  			NSEC_PER_SEC / get_vbt_pwm_freq(connector);
>  	}
> 
> -	drm_dbg_kms(&i915->drm,
> +	drm_dbg_kms(display->drm,
>  		    "[CONNECTOR:%d:%s] Using %s PWM for backlight
> control\n",
>  		    connector->base.base.id, connector->base.name, desc);
> 
> @@ -1632,17 +1657,17 @@ void intel_backlight_update(struct
> intel_atomic_state *state,
>  			    const struct drm_connector_state *conn_state)
>  {
>  	struct intel_connector *connector = to_intel_connector(conn_state-
> >connector);
> -	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct intel_panel *panel = &connector->panel;
> 
>  	if (!panel->backlight.present)
>  		return;
> 
> -	mutex_lock(&i915->display.backlight.lock);
> +	mutex_lock(&display->backlight.lock);
>  	if (!panel->backlight.enabled)
>  		__intel_backlight_enable(crtc_state, conn_state);
> 
> -	mutex_unlock(&i915->display.backlight.lock);
> +	mutex_unlock(&display->backlight.lock);
>  }
> 
>  int intel_backlight_setup(struct intel_connector *connector, enum pipe pipe)
> @@ -1793,13 +1818,14 @@ void intel_backlight_init_funcs(struct intel_panel
> *panel)
>  {
>  	struct intel_connector *connector =
>  		container_of(panel, struct intel_connector, panel);
> +	struct intel_display *display = to_intel_display(connector);
>  	struct drm_i915_private *i915 = to_i915(connector->base.dev);
> 
>  	if (connector->base.connector_type ==
> DRM_MODE_CONNECTOR_DSI &&
>  	    intel_dsi_dcs_init_backlight_funcs(connector) == 0)
>  		return;
> 
> -	if (IS_GEMINILAKE(i915) || IS_BROXTON(i915)) {
> +	if (display->platform.geminilake || display->platform.broxton) {
>  		panel->backlight.pwm_funcs = &bxt_pwm_funcs;
>  	} else if (INTEL_PCH_TYPE(i915) >= PCH_CNP) {
>  		panel->backlight.pwm_funcs = &cnp_pwm_funcs;
> @@ -1810,13 +1836,13 @@ void intel_backlight_init_funcs(struct intel_panel
> *panel)
>  			panel->backlight.pwm_funcs = &spt_pwm_funcs;
>  	} else if (HAS_PCH_SPLIT(i915)) {
>  		panel->backlight.pwm_funcs = &pch_pwm_funcs;
> -	} else if (IS_VALLEYVIEW(i915) || IS_CHERRYVIEW(i915)) {
> +	} else if (display->platform.valleyview || display-
> >platform.cherryview) {
>  		if (connector->base.connector_type ==
> DRM_MODE_CONNECTOR_DSI) {
>  			panel->backlight.pwm_funcs = &ext_pwm_funcs;
>  		} else {
>  			panel->backlight.pwm_funcs = &vlv_pwm_funcs;
>  		}
> -	} else if (DISPLAY_VER(i915) == 4) {
> +	} else if (DISPLAY_VER(display) == 4) {
>  		panel->backlight.pwm_funcs = &i965_pwm_funcs;
>  	} else {
>  		panel->backlight.pwm_funcs = &i9xx_pwm_funcs;
> @@ -1826,7 +1852,7 @@ void intel_backlight_init_funcs(struct intel_panel
> *panel)
>  		if (intel_dp_aux_init_backlight_funcs(connector) == 0)
>  			return;
> 
> -		if (!intel_has_quirk(&i915->display,
> QUIRK_NO_PPS_BACKLIGHT_POWER_HOOK))
> +		if (!intel_has_quirk(display,
> QUIRK_NO_PPS_BACKLIGHT_POWER_HOOK))
>  			connector->panel.backlight.power =
> intel_pps_backlight_power;
>  	}
> 
> --
> 2.39.5
Jani Nikula Feb. 5, 2025, 9:33 a.m. UTC | #2
On Tue, 04 Feb 2025, Patchwork <patchwork@emeril.freedesktop.org> wrote:
> == Series Details ==
>
> Series: drm/i915/backlight: convert to use struct intel_display
> URL   : https://patchwork.freedesktop.org/series/144312/
> State : failure
>
> == Summary ==
>
> CI Bug Log - changes from CI_DRM_16063 -> Patchwork_144312v1
> ====================================================
>
> Summary
> -------
>
>   **FAILURE**
>
>   Serious unknown changes coming with Patchwork_144312v1 absolutely need to be
>   verified manually.
>   
>   If you think the reported changes have nothing to do with the changes
>   introduced in Patchwork_144312v1, please notify your bug team (I915-ci-infra@lists.freedesktop.org) to allow them
>   to document this new failure mode, which will reduce false positives in CI.
>
>   External URL: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_144312v1/index.html
>
> Participating hosts (43 -> 42)
> ------------------------------
>
>   Missing    (1): fi-snb-2520m 
>
> Possible new issues
> -------------------
>
>   Here are the unknown changes that may have been introduced in Patchwork_144312v1:
>
> ### IGT changes ###
>
> #### Possible regressions ####
>
>   * igt@i915_pm_rpm@module-reload:
>     - bat-rpls-4:         [PASS][1] -> [FAIL][2]
>    [1]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_16063/bat-rpls-4/igt@i915_pm_rpm@module-reload.html
>    [2]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_144312v1/bat-rpls-4/igt@i915_pm_rpm@module-reload.html
>     - fi-tgl-1115g4:      [PASS][3] -> [FAIL][4]
>    [3]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_16063/fi-tgl-1115g4/igt@i915_pm_rpm@module-reload.html
>    [4]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_144312v1/fi-tgl-1115g4/igt@i915_pm_rpm@module-reload.html

Please re-report


>
>   
> Known issues
> ------------
>
>   Here are the changes found in Patchwork_144312v1 that come from known issues:
>
> ### IGT changes ###
>
> #### Issues hit ####
>
>   * igt@i915_selftest@live:
>     - bat-twl-1:          NOTRUN -> [ABORT][5] ([i915#12919] / [i915#13503])
>    [5]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_144312v1/bat-twl-1/igt@i915_selftest@live.html
>
>   * igt@i915_selftest@live@gt_heartbeat:
>     - bat-twl-1:          [PASS][6] -> [ABORT][7] ([i915#12919])
>    [6]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_16063/bat-twl-1/igt@i915_selftest@live@gt_heartbeat.html
>    [7]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_144312v1/bat-twl-1/igt@i915_selftest@live@gt_heartbeat.html
>
>   * igt@i915_selftest@live@workarounds:
>     - bat-mtlp-6:         [PASS][8] -> [DMESG-FAIL][9] ([i915#12061]) +1 other test dmesg-fail
>    [8]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_16063/bat-mtlp-6/igt@i915_selftest@live@workarounds.html
>    [9]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_144312v1/bat-mtlp-6/igt@i915_selftest@live@workarounds.html
>
>   * igt@kms_pipe_crc_basic@nonblocking-crc-frame-sequence:
>     - bat-dg2-11:         [PASS][10] -> [SKIP][11] ([i915#9197]) +3 other tests skip
>    [10]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_16063/bat-dg2-11/igt@kms_pipe_crc_basic@nonblocking-crc-frame-sequence.html
>    [11]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_144312v1/bat-dg2-11/igt@kms_pipe_crc_basic@nonblocking-crc-frame-sequence.html
>
>   
> #### Possible fixes ####
>
>   * igt@i915_selftest@live@workarounds:
>     - bat-arls-5:         [DMESG-FAIL][12] ([i915#12061]) -> [PASS][13] +1 other test pass
>    [12]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_16063/bat-arls-5/igt@i915_selftest@live@workarounds.html
>    [13]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_144312v1/bat-arls-5/igt@i915_selftest@live@workarounds.html
>     - {bat-mtlp-9}:       [DMESG-FAIL][14] ([i915#12061]) -> [PASS][15] +1 other test pass
>    [14]: https://intel-gfx-ci.01.org/tree/drm-tip/CI_DRM_16063/bat-mtlp-9/igt@i915_selftest@live@workarounds.html
>    [15]: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_144312v1/bat-mtlp-9/igt@i915_selftest@live@workarounds.html
>
>   
>   {name}: This element is suppressed. This means it is ignored when computing
>           the status of the difference (SUCCESS, WARNING, or FAILURE).
>
>   [i915#12061]: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/12061
>   [i915#12919]: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/12919
>   [i915#13503]: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/13503
>   [i915#9197]: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/9197
>
>
> Build changes
> -------------
>
>   * Linux: CI_DRM_16063 -> Patchwork_144312v1
>
>   CI-20190529: 20190529
>   CI_DRM_16063: 34f113e9fef546134e402e7657fc47e92fba59dc @ git://anongit.freedesktop.org/gfx-ci/linux
>   IGT_8223: ccfe042787b082c06402ff9af257f8338b8edd5e @ https://gitlab.freedesktop.org/drm/igt-gpu-tools.git
>   Patchwork_144312v1: 34f113e9fef546134e402e7657fc47e92fba59dc @ git://anongit.freedesktop.org/gfx-ci/linux
>
> == Logs ==
>
> For more details see: https://intel-gfx-ci.01.org/tree/drm-tip/Patchwork_144312v1/index.html
diff mbox series

Patch

diff --git a/drivers/gpu/drm/i915/display/intel_backlight.c b/drivers/gpu/drm/i915/display/intel_backlight.c
index 7e6ce905bdaf..477b21af71a4 100644
--- a/drivers/gpu/drm/i915/display/intel_backlight.c
+++ b/drivers/gpu/drm/i915/display/intel_backlight.c
@@ -104,20 +104,20 @@  u32 intel_backlight_invert_pwm_level(struct intel_connector *connector, u32 val)
 void intel_backlight_set_pwm_level(const struct drm_connector_state *conn_state, u32 val)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 
-	drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] set backlight PWM = %d\n",
+	drm_dbg_kms(display->drm, "[CONNECTOR:%d:%s] set backlight PWM = %d\n",
 		    connector->base.base.id, connector->base.name, val);
 	panel->backlight.pwm_funcs->set(conn_state, val);
 }
 
 u32 intel_backlight_level_to_pwm(struct intel_connector *connector, u32 val)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 
-	drm_WARN_ON_ONCE(&i915->drm,
+	drm_WARN_ON_ONCE(display->drm,
 			 panel->backlight.max == 0 || panel->backlight.pwm_level_max == 0);
 
 	val = scale(val, panel->backlight.min, panel->backlight.max,
@@ -145,32 +145,33 @@  u32 intel_backlight_level_from_pwm(struct intel_connector *connector, u32 val)
 
 static u32 lpt_get_backlight(struct intel_connector *connector, enum pipe unused)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 
-	return intel_de_read(i915, BLC_PWM_PCH_CTL2) & BACKLIGHT_DUTY_CYCLE_MASK;
+	return intel_de_read(display, BLC_PWM_PCH_CTL2) & BACKLIGHT_DUTY_CYCLE_MASK;
 }
 
 static u32 pch_get_backlight(struct intel_connector *connector, enum pipe unused)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 
-	return intel_de_read(i915, BLC_PWM_CPU_CTL) & BACKLIGHT_DUTY_CYCLE_MASK;
+	return intel_de_read(display, BLC_PWM_CPU_CTL) & BACKLIGHT_DUTY_CYCLE_MASK;
 }
 
 static u32 i9xx_get_backlight(struct intel_connector *connector, enum pipe unused)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	u32 val;
 
-	val = intel_de_read(i915, BLC_PWM_CTL) & BACKLIGHT_DUTY_CYCLE_MASK;
-	if (DISPLAY_VER(i915) < 4)
+	val = intel_de_read(display, BLC_PWM_CTL) & BACKLIGHT_DUTY_CYCLE_MASK;
+	if (DISPLAY_VER(display) < 4)
 		val >>= 1;
 
 	if (panel->backlight.combination_mode) {
+		struct pci_dev *pdev = to_pci_dev(display->drm->dev);
 		u8 lbpc;
 
-		pci_read_config_byte(to_pci_dev(i915->drm.dev), LBPC, &lbpc);
+		pci_read_config_byte(pdev, LBPC, &lbpc);
 		val *= lbpc;
 	}
 
@@ -179,20 +180,20 @@  static u32 i9xx_get_backlight(struct intel_connector *connector, enum pipe unuse
 
 static u32 vlv_get_backlight(struct intel_connector *connector, enum pipe pipe)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 
-	if (drm_WARN_ON(&i915->drm, pipe != PIPE_A && pipe != PIPE_B))
+	if (drm_WARN_ON(display->drm, pipe != PIPE_A && pipe != PIPE_B))
 		return 0;
 
-	return intel_de_read(i915, VLV_BLC_PWM_CTL(pipe)) & BACKLIGHT_DUTY_CYCLE_MASK;
+	return intel_de_read(display, VLV_BLC_PWM_CTL(pipe)) & BACKLIGHT_DUTY_CYCLE_MASK;
 }
 
 static u32 bxt_get_backlight(struct intel_connector *connector, enum pipe unused)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 
-	return intel_de_read(i915, BXT_BLC_PWM_DUTY(panel->backlight.controller));
+	return intel_de_read(display, BXT_BLC_PWM_DUTY(panel->backlight.controller));
 }
 
 static u32 ext_pwm_get_backlight(struct intel_connector *connector, enum pipe unused)
@@ -207,69 +208,70 @@  static u32 ext_pwm_get_backlight(struct intel_connector *connector, enum pipe un
 static void lpt_set_backlight(const struct drm_connector_state *conn_state, u32 level)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	u32 val;
 
-	val = intel_de_read(i915, BLC_PWM_PCH_CTL2) & ~BACKLIGHT_DUTY_CYCLE_MASK;
-	intel_de_write(i915, BLC_PWM_PCH_CTL2, val | level);
+	val = intel_de_read(display, BLC_PWM_PCH_CTL2) & ~BACKLIGHT_DUTY_CYCLE_MASK;
+	intel_de_write(display, BLC_PWM_PCH_CTL2, val | level);
 }
 
 static void pch_set_backlight(const struct drm_connector_state *conn_state, u32 level)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	u32 tmp;
 
-	tmp = intel_de_read(i915, BLC_PWM_CPU_CTL) & ~BACKLIGHT_DUTY_CYCLE_MASK;
-	intel_de_write(i915, BLC_PWM_CPU_CTL, tmp | level);
+	tmp = intel_de_read(display, BLC_PWM_CPU_CTL) & ~BACKLIGHT_DUTY_CYCLE_MASK;
+	intel_de_write(display, BLC_PWM_CPU_CTL, tmp | level);
 }
 
 static void i9xx_set_backlight(const struct drm_connector_state *conn_state, u32 level)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	u32 tmp, mask;
 
-	drm_WARN_ON(&i915->drm, panel->backlight.pwm_level_max == 0);
+	drm_WARN_ON(display->drm, panel->backlight.pwm_level_max == 0);
 
 	if (panel->backlight.combination_mode) {
+		struct pci_dev *pdev = to_pci_dev(display->drm->dev);
 		u8 lbpc;
 
 		lbpc = level * 0xfe / panel->backlight.pwm_level_max + 1;
 		level /= lbpc;
-		pci_write_config_byte(to_pci_dev(i915->drm.dev), LBPC, lbpc);
+		pci_write_config_byte(pdev, LBPC, lbpc);
 	}
 
-	if (DISPLAY_VER(i915) == 4) {
+	if (DISPLAY_VER(display) == 4) {
 		mask = BACKLIGHT_DUTY_CYCLE_MASK;
 	} else {
 		level <<= 1;
 		mask = BACKLIGHT_DUTY_CYCLE_MASK_PNV;
 	}
 
-	tmp = intel_de_read(i915, BLC_PWM_CTL) & ~mask;
-	intel_de_write(i915, BLC_PWM_CTL, tmp | level);
+	tmp = intel_de_read(display, BLC_PWM_CTL) & ~mask;
+	intel_de_write(display, BLC_PWM_CTL, tmp | level);
 }
 
 static void vlv_set_backlight(const struct drm_connector_state *conn_state, u32 level)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	enum pipe pipe = to_intel_crtc(conn_state->crtc)->pipe;
 	u32 tmp;
 
-	tmp = intel_de_read(i915, VLV_BLC_PWM_CTL(pipe)) & ~BACKLIGHT_DUTY_CYCLE_MASK;
-	intel_de_write(i915, VLV_BLC_PWM_CTL(pipe), tmp | level);
+	tmp = intel_de_read(display, VLV_BLC_PWM_CTL(pipe)) & ~BACKLIGHT_DUTY_CYCLE_MASK;
+	intel_de_write(display, VLV_BLC_PWM_CTL(pipe), tmp | level);
 }
 
 static void bxt_set_backlight(const struct drm_connector_state *conn_state, u32 level)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 
-	intel_de_write(i915, BXT_BLC_PWM_DUTY(panel->backlight.controller), level);
+	intel_de_write(display, BXT_BLC_PWM_DUTY(panel->backlight.controller), level);
 }
 
 static void ext_pwm_set_backlight(const struct drm_connector_state *conn_state, u32 level)
@@ -284,10 +286,10 @@  static void
 intel_panel_actually_set_backlight(const struct drm_connector_state *conn_state, u32 level)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 
-	drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] set backlight level = %d\n",
+	drm_dbg_kms(display->drm, "[CONNECTOR:%d:%s] set backlight level = %d\n",
 		    connector->base.base.id, connector->base.name, level);
 
 	panel->backlight.funcs->set(conn_state, level);
@@ -300,7 +302,7 @@  void intel_backlight_set_acpi(const struct drm_connector_state *conn_state,
 			      u32 user_level, u32 user_max)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	u32 hw_level;
 
@@ -313,9 +315,9 @@  void intel_backlight_set_acpi(const struct drm_connector_state *conn_state,
 	if (!panel->backlight.present || !conn_state->crtc)
 		return;
 
-	mutex_lock(&i915->display.backlight.lock);
+	mutex_lock(&display->backlight.lock);
 
-	drm_WARN_ON(&i915->drm, panel->backlight.max == 0);
+	drm_WARN_ON(display->drm, panel->backlight.max == 0);
 
 	hw_level = clamp_user_to_hw(connector, user_level, user_max);
 	panel->backlight.level = hw_level;
@@ -329,13 +331,13 @@  void intel_backlight_set_acpi(const struct drm_connector_state *conn_state,
 	if (panel->backlight.enabled)
 		intel_panel_actually_set_backlight(conn_state, hw_level);
 
-	mutex_unlock(&i915->display.backlight.lock);
+	mutex_unlock(&display->backlight.lock);
 }
 
 static void lpt_disable_backlight(const struct drm_connector_state *old_conn_state, u32 level)
 {
 	struct intel_connector *connector = to_intel_connector(old_conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	u32 tmp;
 
 	intel_backlight_set_pwm_level(old_conn_state, level);
@@ -348,26 +350,26 @@  static void lpt_disable_backlight(const struct drm_connector_state *old_conn_sta
 	 * This needs rework if we need to add support for CPU PWM on PCH split
 	 * platforms.
 	 */
-	tmp = intel_de_read(i915, BLC_PWM_CPU_CTL2);
+	tmp = intel_de_read(display, BLC_PWM_CPU_CTL2);
 	if (tmp & BLM_PWM_ENABLE) {
-		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] CPU backlight was enabled, disabling\n",
+		drm_dbg_kms(display->drm, "[CONNECTOR:%d:%s] CPU backlight was enabled, disabling\n",
 			    connector->base.base.id, connector->base.name);
-		intel_de_write(i915, BLC_PWM_CPU_CTL2, tmp & ~BLM_PWM_ENABLE);
+		intel_de_write(display, BLC_PWM_CPU_CTL2, tmp & ~BLM_PWM_ENABLE);
 	}
 
-	intel_de_rmw(i915, BLC_PWM_PCH_CTL1, BLM_PCH_PWM_ENABLE, 0);
+	intel_de_rmw(display, BLC_PWM_PCH_CTL1, BLM_PCH_PWM_ENABLE, 0);
 }
 
 static void pch_disable_backlight(const struct drm_connector_state *old_conn_state, u32 val)
 {
 	struct intel_connector *connector = to_intel_connector(old_conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 
 	intel_backlight_set_pwm_level(old_conn_state, val);
 
-	intel_de_rmw(i915, BLC_PWM_CPU_CTL2, BLM_PWM_ENABLE, 0);
+	intel_de_rmw(display, BLC_PWM_CPU_CTL2, BLM_PWM_ENABLE, 0);
 
-	intel_de_rmw(i915, BLC_PWM_PCH_CTL1, BLM_PCH_PWM_ENABLE, 0);
+	intel_de_rmw(display, BLC_PWM_PCH_CTL1, BLM_PCH_PWM_ENABLE, 0);
 }
 
 static void i9xx_disable_backlight(const struct drm_connector_state *old_conn_state, u32 val)
@@ -377,48 +379,49 @@  static void i9xx_disable_backlight(const struct drm_connector_state *old_conn_st
 
 static void i965_disable_backlight(const struct drm_connector_state *old_conn_state, u32 val)
 {
-	struct drm_i915_private *i915 = to_i915(old_conn_state->connector->dev);
+	struct intel_connector *connector = to_intel_connector(old_conn_state->connector);
+	struct intel_display *display = to_intel_display(connector);
 
 	intel_backlight_set_pwm_level(old_conn_state, val);
 
-	intel_de_rmw(i915, BLC_PWM_CTL2, BLM_PWM_ENABLE, 0);
+	intel_de_rmw(display, BLC_PWM_CTL2, BLM_PWM_ENABLE, 0);
 }
 
 static void vlv_disable_backlight(const struct drm_connector_state *old_conn_state, u32 val)
 {
 	struct intel_connector *connector = to_intel_connector(old_conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	enum pipe pipe = to_intel_crtc(old_conn_state->crtc)->pipe;
 
 	intel_backlight_set_pwm_level(old_conn_state, val);
 
-	intel_de_rmw(i915, VLV_BLC_PWM_CTL2(pipe), BLM_PWM_ENABLE, 0);
+	intel_de_rmw(display, VLV_BLC_PWM_CTL2(pipe), BLM_PWM_ENABLE, 0);
 }
 
 static void bxt_disable_backlight(const struct drm_connector_state *old_conn_state, u32 val)
 {
 	struct intel_connector *connector = to_intel_connector(old_conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 
 	intel_backlight_set_pwm_level(old_conn_state, val);
 
-	intel_de_rmw(i915, BXT_BLC_PWM_CTL(panel->backlight.controller),
+	intel_de_rmw(display, BXT_BLC_PWM_CTL(panel->backlight.controller),
 		     BXT_BLC_PWM_ENABLE, 0);
 
 	if (panel->backlight.controller == 1)
-		intel_de_rmw(i915, UTIL_PIN_CTL, UTIL_PIN_ENABLE, 0);
+		intel_de_rmw(display, UTIL_PIN_CTL, UTIL_PIN_ENABLE, 0);
 }
 
 static void cnp_disable_backlight(const struct drm_connector_state *old_conn_state, u32 val)
 {
 	struct intel_connector *connector = to_intel_connector(old_conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 
 	intel_backlight_set_pwm_level(old_conn_state, val);
 
-	intel_de_rmw(i915, BXT_BLC_PWM_CTL(panel->backlight.controller),
+	intel_de_rmw(display, BXT_BLC_PWM_CTL(panel->backlight.controller),
 		     BXT_BLC_PWM_ENABLE, 0);
 }
 
@@ -436,7 +439,7 @@  static void ext_pwm_disable_backlight(const struct drm_connector_state *old_conn
 void intel_backlight_disable(const struct drm_connector_state *old_conn_state)
 {
 	struct intel_connector *connector = to_intel_connector(old_conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 
 	if (!panel->backlight.present)
@@ -448,49 +451,51 @@  void intel_backlight_disable(const struct drm_connector_state *old_conn_state)
 	 * backlight. This will leave the backlight on unnecessarily when
 	 * another client is not activated.
 	 */
-	if (i915->drm.switch_power_state == DRM_SWITCH_POWER_CHANGING) {
-		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] Skipping backlight disable on vga switch\n",
+	if (display->drm->switch_power_state == DRM_SWITCH_POWER_CHANGING) {
+		drm_dbg_kms(display->drm, "[CONNECTOR:%d:%s] Skipping backlight disable on vga switch\n",
 			    connector->base.base.id, connector->base.name);
 		return;
 	}
 
-	mutex_lock(&i915->display.backlight.lock);
+	mutex_lock(&display->backlight.lock);
 
 	if (panel->backlight.device)
 		panel->backlight.device->props.power = BACKLIGHT_POWER_OFF;
 	panel->backlight.enabled = false;
 	panel->backlight.funcs->disable(old_conn_state, 0);
 
-	mutex_unlock(&i915->display.backlight.lock);
+	mutex_unlock(&display->backlight.lock);
 }
 
 static void lpt_enable_backlight(const struct intel_crtc_state *crtc_state,
 				 const struct drm_connector_state *conn_state, u32 level)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
+	struct intel_display *display = to_intel_display(connector);
 	struct drm_i915_private *i915 = to_i915(connector->base.dev);
 	struct intel_panel *panel = &connector->panel;
 	u32 pch_ctl1, pch_ctl2;
 
-	pch_ctl1 = intel_de_read(i915, BLC_PWM_PCH_CTL1);
+	pch_ctl1 = intel_de_read(display, BLC_PWM_PCH_CTL1);
 	if (pch_ctl1 & BLM_PCH_PWM_ENABLE) {
-		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] PCH backlight already enabled\n",
+		drm_dbg_kms(display->drm,
+			    "[CONNECTOR:%d:%s] PCH backlight already enabled\n",
 			    connector->base.base.id, connector->base.name);
 		pch_ctl1 &= ~BLM_PCH_PWM_ENABLE;
-		intel_de_write(i915, BLC_PWM_PCH_CTL1, pch_ctl1);
+		intel_de_write(display, BLC_PWM_PCH_CTL1, pch_ctl1);
 	}
 
 	if (HAS_PCH_LPT(i915))
-		intel_de_rmw(i915, SOUTH_CHICKEN2, LPT_PWM_GRANULARITY,
+		intel_de_rmw(display, SOUTH_CHICKEN2, LPT_PWM_GRANULARITY,
 			     panel->backlight.alternate_pwm_increment ?
 			     LPT_PWM_GRANULARITY : 0);
 	else
-		intel_de_rmw(i915, SOUTH_CHICKEN1, SPT_PWM_GRANULARITY,
+		intel_de_rmw(display, SOUTH_CHICKEN1, SPT_PWM_GRANULARITY,
 			     panel->backlight.alternate_pwm_increment ?
 			     SPT_PWM_GRANULARITY : 0);
 
 	pch_ctl2 = panel->backlight.pwm_level_max << 16;
-	intel_de_write(i915, BLC_PWM_PCH_CTL2, pch_ctl2);
+	intel_de_write(display, BLC_PWM_PCH_CTL2, pch_ctl2);
 
 	pch_ctl1 = 0;
 	if (panel->backlight.active_low_pwm)
@@ -500,9 +505,9 @@  static void lpt_enable_backlight(const struct intel_crtc_state *crtc_state,
 	if (HAS_PCH_LPT(i915))
 		pch_ctl1 |= BLM_PCH_OVERRIDE_ENABLE;
 
-	intel_de_write(i915, BLC_PWM_PCH_CTL1, pch_ctl1);
-	intel_de_posting_read(i915, BLC_PWM_PCH_CTL1);
-	intel_de_write(i915, BLC_PWM_PCH_CTL1, pch_ctl1 | BLM_PCH_PWM_ENABLE);
+	intel_de_write(display, BLC_PWM_PCH_CTL1, pch_ctl1);
+	intel_de_posting_read(display, BLC_PWM_PCH_CTL1);
+	intel_de_write(display, BLC_PWM_PCH_CTL1, pch_ctl1 | BLM_PCH_PWM_ENABLE);
 
 	/* This won't stick until the above enable. */
 	intel_backlight_set_pwm_level(conn_state, level);
@@ -512,63 +517,66 @@  static void pch_enable_backlight(const struct intel_crtc_state *crtc_state,
 				 const struct drm_connector_state *conn_state, u32 level)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	enum transcoder cpu_transcoder = crtc_state->cpu_transcoder;
 	u32 cpu_ctl2, pch_ctl1, pch_ctl2;
 
-	cpu_ctl2 = intel_de_read(i915, BLC_PWM_CPU_CTL2);
+	cpu_ctl2 = intel_de_read(display, BLC_PWM_CPU_CTL2);
 	if (cpu_ctl2 & BLM_PWM_ENABLE) {
-		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] CPU backlight already enabled\n",
+		drm_dbg_kms(display->drm,
+			    "[CONNECTOR:%d:%s] CPU backlight already enabled\n",
 			    connector->base.base.id, connector->base.name);
 		cpu_ctl2 &= ~BLM_PWM_ENABLE;
-		intel_de_write(i915, BLC_PWM_CPU_CTL2, cpu_ctl2);
+		intel_de_write(display, BLC_PWM_CPU_CTL2, cpu_ctl2);
 	}
 
-	pch_ctl1 = intel_de_read(i915, BLC_PWM_PCH_CTL1);
+	pch_ctl1 = intel_de_read(display, BLC_PWM_PCH_CTL1);
 	if (pch_ctl1 & BLM_PCH_PWM_ENABLE) {
-		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] PCH backlight already enabled\n",
+		drm_dbg_kms(display->drm,
+			    "[CONNECTOR:%d:%s] PCH backlight already enabled\n",
 			    connector->base.base.id, connector->base.name);
 		pch_ctl1 &= ~BLM_PCH_PWM_ENABLE;
-		intel_de_write(i915, BLC_PWM_PCH_CTL1, pch_ctl1);
+		intel_de_write(display, BLC_PWM_PCH_CTL1, pch_ctl1);
 	}
 
 	if (cpu_transcoder == TRANSCODER_EDP)
 		cpu_ctl2 = BLM_TRANSCODER_EDP;
 	else
 		cpu_ctl2 = BLM_PIPE(cpu_transcoder);
-	intel_de_write(i915, BLC_PWM_CPU_CTL2, cpu_ctl2);
-	intel_de_posting_read(i915, BLC_PWM_CPU_CTL2);
-	intel_de_write(i915, BLC_PWM_CPU_CTL2, cpu_ctl2 | BLM_PWM_ENABLE);
+	intel_de_write(display, BLC_PWM_CPU_CTL2, cpu_ctl2);
+	intel_de_posting_read(display, BLC_PWM_CPU_CTL2);
+	intel_de_write(display, BLC_PWM_CPU_CTL2, cpu_ctl2 | BLM_PWM_ENABLE);
 
 	/* This won't stick until the above enable. */
 	intel_backlight_set_pwm_level(conn_state, level);
 
 	pch_ctl2 = panel->backlight.pwm_level_max << 16;
-	intel_de_write(i915, BLC_PWM_PCH_CTL2, pch_ctl2);
+	intel_de_write(display, BLC_PWM_PCH_CTL2, pch_ctl2);
 
 	pch_ctl1 = 0;
 	if (panel->backlight.active_low_pwm)
 		pch_ctl1 |= BLM_PCH_POLARITY;
 
-	intel_de_write(i915, BLC_PWM_PCH_CTL1, pch_ctl1);
-	intel_de_posting_read(i915, BLC_PWM_PCH_CTL1);
-	intel_de_write(i915, BLC_PWM_PCH_CTL1, pch_ctl1 | BLM_PCH_PWM_ENABLE);
+	intel_de_write(display, BLC_PWM_PCH_CTL1, pch_ctl1);
+	intel_de_posting_read(display, BLC_PWM_PCH_CTL1);
+	intel_de_write(display, BLC_PWM_PCH_CTL1, pch_ctl1 | BLM_PCH_PWM_ENABLE);
 }
 
 static void i9xx_enable_backlight(const struct intel_crtc_state *crtc_state,
 				  const struct drm_connector_state *conn_state, u32 level)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	u32 ctl, freq;
 
-	ctl = intel_de_read(i915, BLC_PWM_CTL);
+	ctl = intel_de_read(display, BLC_PWM_CTL);
 	if (ctl & BACKLIGHT_DUTY_CYCLE_MASK_PNV) {
-		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] backlight already enabled\n",
+		drm_dbg_kms(display->drm,
+			    "[CONNECTOR:%d:%s] backlight already enabled\n",
 			    connector->base.base.id, connector->base.name);
-		intel_de_write(i915, BLC_PWM_CTL, 0);
+		intel_de_write(display, BLC_PWM_CTL, 0);
 	}
 
 	freq = panel->backlight.pwm_level_max;
@@ -578,11 +586,11 @@  static void i9xx_enable_backlight(const struct intel_crtc_state *crtc_state,
 	ctl = freq << 17;
 	if (panel->backlight.combination_mode)
 		ctl |= BLM_LEGACY_MODE;
-	if (IS_PINEVIEW(i915) && panel->backlight.active_low_pwm)
+	if (display->platform.pineview && panel->backlight.active_low_pwm)
 		ctl |= BLM_POLARITY_PNV;
 
-	intel_de_write(i915, BLC_PWM_CTL, ctl);
-	intel_de_posting_read(i915, BLC_PWM_CTL);
+	intel_de_write(display, BLC_PWM_CTL, ctl);
+	intel_de_posting_read(display, BLC_PWM_CTL);
 
 	/* XXX: combine this into above write? */
 	intel_backlight_set_pwm_level(conn_state, level);
@@ -592,25 +600,26 @@  static void i9xx_enable_backlight(const struct intel_crtc_state *crtc_state,
 	 * 855gm only, but checking for gen2 is safe, as 855gm is the only gen2
 	 * that has backlight.
 	 */
-	if (DISPLAY_VER(i915) == 2)
-		intel_de_write(i915, BLC_HIST_CTL, BLM_HISTOGRAM_ENABLE);
+	if (DISPLAY_VER(display) == 2)
+		intel_de_write(display, BLC_HIST_CTL, BLM_HISTOGRAM_ENABLE);
 }
 
 static void i965_enable_backlight(const struct intel_crtc_state *crtc_state,
 				  const struct drm_connector_state *conn_state, u32 level)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	enum pipe pipe = to_intel_crtc(conn_state->crtc)->pipe;
 	u32 ctl, ctl2, freq;
 
-	ctl2 = intel_de_read(i915, BLC_PWM_CTL2);
+	ctl2 = intel_de_read(display, BLC_PWM_CTL2);
 	if (ctl2 & BLM_PWM_ENABLE) {
-		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] backlight already enabled\n",
+		drm_dbg_kms(display->drm,
+			    "[CONNECTOR:%d:%s] backlight already enabled\n",
 			    connector->base.base.id, connector->base.name);
 		ctl2 &= ~BLM_PWM_ENABLE;
-		intel_de_write(i915, BLC_PWM_CTL2, ctl2);
+		intel_de_write(display, BLC_PWM_CTL2, ctl2);
 	}
 
 	freq = panel->backlight.pwm_level_max;
@@ -618,16 +627,16 @@  static void i965_enable_backlight(const struct intel_crtc_state *crtc_state,
 		freq /= 0xff;
 
 	ctl = freq << 16;
-	intel_de_write(i915, BLC_PWM_CTL, ctl);
+	intel_de_write(display, BLC_PWM_CTL, ctl);
 
 	ctl2 = BLM_PIPE(pipe);
 	if (panel->backlight.combination_mode)
 		ctl2 |= BLM_COMBINATION_MODE;
 	if (panel->backlight.active_low_pwm)
 		ctl2 |= BLM_POLARITY_I965;
-	intel_de_write(i915, BLC_PWM_CTL2, ctl2);
-	intel_de_posting_read(i915, BLC_PWM_CTL2);
-	intel_de_write(i915, BLC_PWM_CTL2, ctl2 | BLM_PWM_ENABLE);
+	intel_de_write(display, BLC_PWM_CTL2, ctl2);
+	intel_de_posting_read(display, BLC_PWM_CTL2);
+	intel_de_write(display, BLC_PWM_CTL2, ctl2 | BLM_PWM_ENABLE);
 
 	intel_backlight_set_pwm_level(conn_state, level);
 }
@@ -636,21 +645,22 @@  static void vlv_enable_backlight(const struct intel_crtc_state *crtc_state,
 				 const struct drm_connector_state *conn_state, u32 level)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	enum pipe pipe = to_intel_crtc(crtc_state->uapi.crtc)->pipe;
 	u32 ctl, ctl2;
 
-	ctl2 = intel_de_read(i915, VLV_BLC_PWM_CTL2(pipe));
+	ctl2 = intel_de_read(display, VLV_BLC_PWM_CTL2(pipe));
 	if (ctl2 & BLM_PWM_ENABLE) {
-		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] backlight already enabled\n",
+		drm_dbg_kms(display->drm,
+			    "[CONNECTOR:%d:%s] backlight already enabled\n",
 			    connector->base.base.id, connector->base.name);
 		ctl2 &= ~BLM_PWM_ENABLE;
-		intel_de_write(i915, VLV_BLC_PWM_CTL2(pipe), ctl2);
+		intel_de_write(display, VLV_BLC_PWM_CTL2(pipe), ctl2);
 	}
 
 	ctl = panel->backlight.pwm_level_max << 16;
-	intel_de_write(i915, VLV_BLC_PWM_CTL(pipe), ctl);
+	intel_de_write(display, VLV_BLC_PWM_CTL(pipe), ctl);
 
 	/* XXX: combine this into above write? */
 	intel_backlight_set_pwm_level(conn_state, level);
@@ -658,47 +668,49 @@  static void vlv_enable_backlight(const struct intel_crtc_state *crtc_state,
 	ctl2 = 0;
 	if (panel->backlight.active_low_pwm)
 		ctl2 |= BLM_POLARITY_I965;
-	intel_de_write(i915, VLV_BLC_PWM_CTL2(pipe), ctl2);
-	intel_de_posting_read(i915, VLV_BLC_PWM_CTL2(pipe));
-	intel_de_write(i915, VLV_BLC_PWM_CTL2(pipe), ctl2 | BLM_PWM_ENABLE);
+	intel_de_write(display, VLV_BLC_PWM_CTL2(pipe), ctl2);
+	intel_de_posting_read(display, VLV_BLC_PWM_CTL2(pipe));
+	intel_de_write(display, VLV_BLC_PWM_CTL2(pipe), ctl2 | BLM_PWM_ENABLE);
 }
 
 static void bxt_enable_backlight(const struct intel_crtc_state *crtc_state,
 				 const struct drm_connector_state *conn_state, u32 level)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	enum pipe pipe = to_intel_crtc(crtc_state->uapi.crtc)->pipe;
 	u32 pwm_ctl, val;
 
 	/* Controller 1 uses the utility pin. */
 	if (panel->backlight.controller == 1) {
-		val = intel_de_read(i915, UTIL_PIN_CTL);
+		val = intel_de_read(display, UTIL_PIN_CTL);
 		if (val & UTIL_PIN_ENABLE) {
-			drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] utility pin already enabled\n",
+			drm_dbg_kms(display->drm,
+				    "[CONNECTOR:%d:%s] utility pin already enabled\n",
 				    connector->base.base.id, connector->base.name);
 			val &= ~UTIL_PIN_ENABLE;
-			intel_de_write(i915, UTIL_PIN_CTL, val);
+			intel_de_write(display, UTIL_PIN_CTL, val);
 		}
 
 		val = 0;
 		if (panel->backlight.util_pin_active_low)
 			val |= UTIL_PIN_POLARITY;
-		intel_de_write(i915, UTIL_PIN_CTL,
+		intel_de_write(display, UTIL_PIN_CTL,
 			       val | UTIL_PIN_PIPE(pipe) | UTIL_PIN_MODE_PWM | UTIL_PIN_ENABLE);
 	}
 
-	pwm_ctl = intel_de_read(i915, BXT_BLC_PWM_CTL(panel->backlight.controller));
+	pwm_ctl = intel_de_read(display, BXT_BLC_PWM_CTL(panel->backlight.controller));
 	if (pwm_ctl & BXT_BLC_PWM_ENABLE) {
-		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] backlight already enabled\n",
+		drm_dbg_kms(display->drm,
+			    "[CONNECTOR:%d:%s] backlight already enabled\n",
 			    connector->base.base.id, connector->base.name);
 		pwm_ctl &= ~BXT_BLC_PWM_ENABLE;
-		intel_de_write(i915, BXT_BLC_PWM_CTL(panel->backlight.controller),
+		intel_de_write(display, BXT_BLC_PWM_CTL(panel->backlight.controller),
 			       pwm_ctl);
 	}
 
-	intel_de_write(i915, BXT_BLC_PWM_FREQ(panel->backlight.controller),
+	intel_de_write(display, BXT_BLC_PWM_FREQ(panel->backlight.controller),
 		       panel->backlight.pwm_level_max);
 
 	intel_backlight_set_pwm_level(conn_state, level);
@@ -707,9 +719,9 @@  static void bxt_enable_backlight(const struct intel_crtc_state *crtc_state,
 	if (panel->backlight.active_low_pwm)
 		pwm_ctl |= BXT_BLC_PWM_POLARITY;
 
-	intel_de_write(i915, BXT_BLC_PWM_CTL(panel->backlight.controller), pwm_ctl);
-	intel_de_posting_read(i915, BXT_BLC_PWM_CTL(panel->backlight.controller));
-	intel_de_write(i915, BXT_BLC_PWM_CTL(panel->backlight.controller),
+	intel_de_write(display, BXT_BLC_PWM_CTL(panel->backlight.controller), pwm_ctl);
+	intel_de_posting_read(display, BXT_BLC_PWM_CTL(panel->backlight.controller));
+	intel_de_write(display, BXT_BLC_PWM_CTL(panel->backlight.controller),
 		       pwm_ctl | BXT_BLC_PWM_ENABLE);
 }
 
@@ -717,19 +729,19 @@  static void cnp_enable_backlight(const struct intel_crtc_state *crtc_state,
 				 const struct drm_connector_state *conn_state, u32 level)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	u32 pwm_ctl;
 
-	pwm_ctl = intel_de_read(i915, BXT_BLC_PWM_CTL(panel->backlight.controller));
+	pwm_ctl = intel_de_read(display, BXT_BLC_PWM_CTL(panel->backlight.controller));
 	if (pwm_ctl & BXT_BLC_PWM_ENABLE) {
-		drm_dbg_kms(&i915->drm, "backlight already enabled\n");
+		drm_dbg_kms(display->drm, "backlight already enabled\n");
 		pwm_ctl &= ~BXT_BLC_PWM_ENABLE;
-		intel_de_write(i915, BXT_BLC_PWM_CTL(panel->backlight.controller),
+		intel_de_write(display, BXT_BLC_PWM_CTL(panel->backlight.controller),
 			       pwm_ctl);
 	}
 
-	intel_de_write(i915, BXT_BLC_PWM_FREQ(panel->backlight.controller),
+	intel_de_write(display, BXT_BLC_PWM_FREQ(panel->backlight.controller),
 		       panel->backlight.pwm_level_max);
 
 	intel_backlight_set_pwm_level(conn_state, level);
@@ -738,9 +750,9 @@  static void cnp_enable_backlight(const struct intel_crtc_state *crtc_state,
 	if (panel->backlight.active_low_pwm)
 		pwm_ctl |= BXT_BLC_PWM_POLARITY;
 
-	intel_de_write(i915, BXT_BLC_PWM_CTL(panel->backlight.controller), pwm_ctl);
-	intel_de_posting_read(i915, BXT_BLC_PWM_CTL(panel->backlight.controller));
-	intel_de_write(i915, BXT_BLC_PWM_CTL(panel->backlight.controller),
+	intel_de_write(display, BXT_BLC_PWM_CTL(panel->backlight.controller), pwm_ctl);
+	intel_de_posting_read(display, BXT_BLC_PWM_CTL(panel->backlight.controller));
+	intel_de_write(display, BXT_BLC_PWM_CTL(panel->backlight.controller),
 		       pwm_ctl | BXT_BLC_PWM_ENABLE);
 }
 
@@ -782,37 +794,37 @@  void intel_backlight_enable(const struct intel_crtc_state *crtc_state,
 			    const struct drm_connector_state *conn_state)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	enum pipe pipe = to_intel_crtc(crtc_state->uapi.crtc)->pipe;
 
 	if (!panel->backlight.present)
 		return;
 
-	drm_dbg_kms(&i915->drm, "pipe %c\n", pipe_name(pipe));
+	drm_dbg_kms(display->drm, "pipe %c\n", pipe_name(pipe));
 
-	mutex_lock(&i915->display.backlight.lock);
+	mutex_lock(&display->backlight.lock);
 
 	__intel_backlight_enable(crtc_state, conn_state);
 
-	mutex_unlock(&i915->display.backlight.lock);
+	mutex_unlock(&display->backlight.lock);
 }
 
 #if IS_ENABLED(CONFIG_BACKLIGHT_CLASS_DEVICE)
 static u32 intel_panel_get_backlight(struct intel_connector *connector)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	u32 val = 0;
 
-	mutex_lock(&i915->display.backlight.lock);
+	mutex_lock(&display->backlight.lock);
 
 	if (panel->backlight.enabled)
 		val = panel->backlight.funcs->get(connector, intel_connector_get_pipe(connector));
 
-	mutex_unlock(&i915->display.backlight.lock);
+	mutex_unlock(&display->backlight.lock);
 
-	drm_dbg_kms(&i915->drm, "get backlight PWM = %d\n", val);
+	drm_dbg_kms(display->drm, "get backlight PWM = %d\n", val);
 	return val;
 }
 
@@ -831,16 +843,16 @@  static void intel_panel_set_backlight(const struct drm_connector_state *conn_sta
 				      u32 user_level, u32 user_max)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	u32 hw_level;
 
 	if (!panel->backlight.present)
 		return;
 
-	mutex_lock(&i915->display.backlight.lock);
+	mutex_lock(&display->backlight.lock);
 
-	drm_WARN_ON(&i915->drm, panel->backlight.max == 0);
+	drm_WARN_ON(display->drm, panel->backlight.max == 0);
 
 	hw_level = scale_user_to_hw(connector, user_level, user_max);
 	panel->backlight.level = hw_level;
@@ -848,18 +860,18 @@  static void intel_panel_set_backlight(const struct drm_connector_state *conn_sta
 	if (panel->backlight.enabled)
 		intel_panel_actually_set_backlight(conn_state, hw_level);
 
-	mutex_unlock(&i915->display.backlight.lock);
+	mutex_unlock(&display->backlight.lock);
 }
 
 static int intel_backlight_device_update_status(struct backlight_device *bd)
 {
 	struct intel_connector *connector = bl_get_data(bd);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 
-	drm_modeset_lock(&i915->drm.mode_config.connection_mutex, NULL);
+	drm_modeset_lock(&display->drm->mode_config.connection_mutex, NULL);
 
-	drm_dbg_kms(&i915->drm, "updating intel_backlight, brightness=%d/%d\n",
+	drm_dbg_kms(display->drm, "updating intel_backlight, brightness=%d/%d\n",
 		    bd->props.brightness, bd->props.max_brightness);
 	intel_panel_set_backlight(connector->base.state, bd->props.brightness,
 				  bd->props.max_brightness);
@@ -880,7 +892,7 @@  static int intel_backlight_device_update_status(struct backlight_device *bd)
 		bd->props.power = BACKLIGHT_POWER_OFF;
 	}
 
-	drm_modeset_unlock(&i915->drm.mode_config.connection_mutex);
+	drm_modeset_unlock(&display->drm->mode_config.connection_mutex);
 
 	return 0;
 }
@@ -888,6 +900,7 @@  static int intel_backlight_device_update_status(struct backlight_device *bd)
 static int intel_backlight_device_get_brightness(struct backlight_device *bd)
 {
 	struct intel_connector *connector = bl_get_data(bd);
+	struct intel_display *display = to_intel_display(connector);
 	struct drm_i915_private *i915 = to_i915(connector->base.dev);
 	intel_wakeref_t wakeref;
 	int ret = 0;
@@ -895,13 +908,13 @@  static int intel_backlight_device_get_brightness(struct backlight_device *bd)
 	with_intel_runtime_pm(&i915->runtime_pm, wakeref) {
 		u32 hw_level;
 
-		drm_modeset_lock(&i915->drm.mode_config.connection_mutex, NULL);
+		drm_modeset_lock(&display->drm->mode_config.connection_mutex, NULL);
 
 		hw_level = intel_panel_get_backlight(connector);
 		ret = scale_hw_to_user(connector,
 				       hw_level, bd->props.max_brightness);
 
-		drm_modeset_unlock(&i915->drm.mode_config.connection_mutex);
+		drm_modeset_unlock(&display->drm->mode_config.connection_mutex);
 	}
 
 	return ret;
@@ -914,7 +927,7 @@  static const struct backlight_ops intel_backlight_device_ops = {
 
 int intel_backlight_device_register(struct intel_connector *connector)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	struct backlight_properties props;
 	struct backlight_device *bd;
@@ -930,7 +943,8 @@  int intel_backlight_device_register(struct intel_connector *connector)
 	WARN_ON(panel->backlight.max == 0);
 
 	if (!acpi_video_backlight_use_native()) {
-		drm_info(&i915->drm, "Skipping intel_backlight registration\n");
+		drm_info(display->drm,
+			 "Skipping intel_backlight registration\n");
 		return 0;
 	}
 
@@ -967,7 +981,8 @@  int intel_backlight_device_register(struct intel_connector *connector)
 		 */
 		kfree(name);
 		name = kasprintf(GFP_KERNEL, "card%d-%s-backlight",
-				 i915->drm.primary->index, connector->base.name);
+				 display->drm->primary->index,
+				 connector->base.name);
 		if (!name)
 			return -ENOMEM;
 	}
@@ -975,7 +990,7 @@  int intel_backlight_device_register(struct intel_connector *connector)
 				       &intel_backlight_device_ops, &props);
 
 	if (IS_ERR(bd)) {
-		drm_err(&i915->drm,
+		drm_err(display->drm,
 			"[CONNECTOR:%d:%s] backlight device %s register failed: %ld\n",
 			connector->base.base.id, connector->base.name, name, PTR_ERR(bd));
 		ret = PTR_ERR(bd);
@@ -984,7 +999,7 @@  int intel_backlight_device_register(struct intel_connector *connector)
 
 	panel->backlight.device = bd;
 
-	drm_dbg_kms(&i915->drm,
+	drm_dbg_kms(display->drm,
 		    "[CONNECTOR:%d:%s] backlight device %s registered\n",
 		    connector->base.base.id, connector->base.name, name);
 
@@ -1011,9 +1026,9 @@  void intel_backlight_device_unregister(struct intel_connector *connector)
  */
 static u32 cnp_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 
-	return DIV_ROUND_CLOSEST(KHz(DISPLAY_RUNTIME_INFO(i915)->rawclk_freq),
+	return DIV_ROUND_CLOSEST(KHz(DISPLAY_RUNTIME_INFO(display)->rawclk_freq),
 				 pwm_freq_hz);
 }
 
@@ -1073,9 +1088,9 @@  static u32 lpt_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)
  */
 static u32 pch_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 
-	return DIV_ROUND_CLOSEST(KHz(DISPLAY_RUNTIME_INFO(i915)->rawclk_freq),
+	return DIV_ROUND_CLOSEST(KHz(DISPLAY_RUNTIME_INFO(display)->rawclk_freq),
 				 pwm_freq_hz * 128);
 }
 
@@ -1089,13 +1104,13 @@  static u32 pch_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)
  */
 static u32 i9xx_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	int clock;
 
-	if (IS_PINEVIEW(i915))
-		clock = KHz(DISPLAY_RUNTIME_INFO(i915)->rawclk_freq);
+	if (display->platform.pineview)
+		clock = KHz(DISPLAY_RUNTIME_INFO(display)->rawclk_freq);
 	else
-		clock = KHz(i915->display.cdclk.hw.cdclk);
+		clock = KHz(display->cdclk.hw.cdclk);
 
 	return DIV_ROUND_CLOSEST(clock, pwm_freq_hz * 32);
 }
@@ -1107,13 +1122,13 @@  static u32 i9xx_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)
  */
 static u32 i965_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	int clock;
 
-	if (IS_G4X(i915))
-		clock = KHz(DISPLAY_RUNTIME_INFO(i915)->rawclk_freq);
+	if (display->platform.g4x)
+		clock = KHz(DISPLAY_RUNTIME_INFO(display)->rawclk_freq);
 	else
-		clock = KHz(i915->display.cdclk.hw.cdclk);
+		clock = KHz(display->cdclk.hw.cdclk);
 
 	return DIV_ROUND_CLOSEST(clock, pwm_freq_hz * 128);
 }
@@ -1125,17 +1140,17 @@  static u32 i965_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)
  */
 static u32 vlv_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	int mul, clock;
 
-	if ((intel_de_read(i915, CBR1_VLV) & CBR_PWM_CLOCK_MUX_SELECT) == 0) {
-		if (IS_CHERRYVIEW(i915))
+	if ((intel_de_read(display, CBR1_VLV) & CBR_PWM_CLOCK_MUX_SELECT) == 0) {
+		if (display->platform.cherryview)
 			clock = KHz(19200);
 		else
 			clock = MHz(25);
 		mul = 16;
 	} else {
-		clock = KHz(DISPLAY_RUNTIME_INFO(i915)->rawclk_freq);
+		clock = KHz(DISPLAY_RUNTIME_INFO(display)->rawclk_freq);
 		mul = 128;
 	}
 
@@ -1144,16 +1159,16 @@  static u32 vlv_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)
 
 static u16 get_vbt_pwm_freq(struct intel_connector *connector)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	u16 pwm_freq_hz = connector->panel.vbt.backlight.pwm_freq_hz;
 
 	if (pwm_freq_hz) {
-		drm_dbg_kms(&i915->drm,
+		drm_dbg_kms(display->drm,
 			    "VBT defined backlight frequency %u Hz\n",
 			    pwm_freq_hz);
 	} else {
 		pwm_freq_hz = 200;
-		drm_dbg_kms(&i915->drm,
+		drm_dbg_kms(display->drm,
 			    "default backlight frequency %u Hz\n",
 			    pwm_freq_hz);
 	}
@@ -1163,20 +1178,20 @@  static u16 get_vbt_pwm_freq(struct intel_connector *connector)
 
 static u32 get_backlight_max_vbt(struct intel_connector *connector)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	u16 pwm_freq_hz = get_vbt_pwm_freq(connector);
 	u32 pwm;
 
 	if (!panel->backlight.pwm_funcs->hz_to_pwm) {
-		drm_dbg_kms(&i915->drm,
+		drm_dbg_kms(display->drm,
 			    "backlight frequency conversion not supported\n");
 		return 0;
 	}
 
 	pwm = panel->backlight.pwm_funcs->hz_to_pwm(connector, pwm_freq_hz);
 	if (!pwm) {
-		drm_dbg_kms(&i915->drm,
+		drm_dbg_kms(display->drm,
 			    "backlight frequency conversion failed\n");
 		return 0;
 	}
@@ -1189,11 +1204,11 @@  static u32 get_backlight_max_vbt(struct intel_connector *connector)
  */
 static u32 get_backlight_min_vbt(struct intel_connector *connector)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	int min;
 
-	drm_WARN_ON(&i915->drm, panel->backlight.pwm_level_max == 0);
+	drm_WARN_ON(display->drm, panel->backlight.pwm_level_max == 0);
 
 	/*
 	 * XXX: If the vbt value is 255, it makes min equal to max, which leads
@@ -1204,7 +1219,7 @@  static u32 get_backlight_min_vbt(struct intel_connector *connector)
 	 */
 	min = clamp_t(int, connector->panel.vbt.backlight.min_brightness, 0, 64);
 	if (min != connector->panel.vbt.backlight.min_brightness) {
-		drm_dbg_kms(&i915->drm,
+		drm_dbg_kms(display->drm,
 			    "clamping VBT min backlight %d/255 to %d/255\n",
 			    connector->panel.vbt.backlight.min_brightness, min);
 	}
@@ -1215,24 +1230,25 @@  static u32 get_backlight_min_vbt(struct intel_connector *connector)
 
 static int lpt_setup_backlight(struct intel_connector *connector, enum pipe unused)
 {
+	struct intel_display *display = to_intel_display(connector);
 	struct drm_i915_private *i915 = to_i915(connector->base.dev);
 	struct intel_panel *panel = &connector->panel;
 	u32 cpu_ctl2, pch_ctl1, pch_ctl2, val;
 	bool alt, cpu_mode;
 
 	if (HAS_PCH_LPT(i915))
-		alt = intel_de_read(i915, SOUTH_CHICKEN2) & LPT_PWM_GRANULARITY;
+		alt = intel_de_read(display, SOUTH_CHICKEN2) & LPT_PWM_GRANULARITY;
 	else
-		alt = intel_de_read(i915, SOUTH_CHICKEN1) & SPT_PWM_GRANULARITY;
+		alt = intel_de_read(display, SOUTH_CHICKEN1) & SPT_PWM_GRANULARITY;
 	panel->backlight.alternate_pwm_increment = alt;
 
-	pch_ctl1 = intel_de_read(i915, BLC_PWM_PCH_CTL1);
+	pch_ctl1 = intel_de_read(display, BLC_PWM_PCH_CTL1);
 	panel->backlight.active_low_pwm = pch_ctl1 & BLM_PCH_POLARITY;
 
-	pch_ctl2 = intel_de_read(i915, BLC_PWM_PCH_CTL2);
+	pch_ctl2 = intel_de_read(display, BLC_PWM_PCH_CTL2);
 	panel->backlight.pwm_level_max = pch_ctl2 >> 16;
 
-	cpu_ctl2 = intel_de_read(i915, BLC_PWM_CPU_CTL2);
+	cpu_ctl2 = intel_de_read(display, BLC_PWM_CPU_CTL2);
 
 	if (!panel->backlight.pwm_level_max)
 		panel->backlight.pwm_level_max = get_backlight_max_vbt(connector);
@@ -1251,19 +1267,19 @@  static int lpt_setup_backlight(struct intel_connector *connector, enum pipe unus
 	if (cpu_mode) {
 		val = pch_get_backlight(connector, unused);
 
-		drm_dbg_kms(&i915->drm,
+		drm_dbg_kms(display->drm,
 			    "CPU backlight register was enabled, switching to PCH override\n");
 
 		/* Write converted CPU PWM value to PCH override register */
 		lpt_set_backlight(connector->base.state, val);
-		intel_de_write(i915, BLC_PWM_PCH_CTL1,
+		intel_de_write(display, BLC_PWM_PCH_CTL1,
 			       pch_ctl1 | BLM_PCH_OVERRIDE_ENABLE);
 
-		intel_de_write(i915, BLC_PWM_CPU_CTL2,
+		intel_de_write(display, BLC_PWM_CPU_CTL2,
 			       cpu_ctl2 & ~BLM_PWM_ENABLE);
 	}
 
-	drm_dbg_kms(&i915->drm,
+	drm_dbg_kms(display->drm,
 		    "[CONNECTOR:%d:%s] Using native PCH PWM for backlight control\n",
 		    connector->base.base.id, connector->base.name);
 
@@ -1272,14 +1288,14 @@  static int lpt_setup_backlight(struct intel_connector *connector, enum pipe unus
 
 static int pch_setup_backlight(struct intel_connector *connector, enum pipe unused)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	u32 cpu_ctl2, pch_ctl1, pch_ctl2;
 
-	pch_ctl1 = intel_de_read(i915, BLC_PWM_PCH_CTL1);
+	pch_ctl1 = intel_de_read(display, BLC_PWM_PCH_CTL1);
 	panel->backlight.active_low_pwm = pch_ctl1 & BLM_PCH_POLARITY;
 
-	pch_ctl2 = intel_de_read(i915, BLC_PWM_PCH_CTL2);
+	pch_ctl2 = intel_de_read(display, BLC_PWM_PCH_CTL2);
 	panel->backlight.pwm_level_max = pch_ctl2 >> 16;
 
 	if (!panel->backlight.pwm_level_max)
@@ -1290,11 +1306,11 @@  static int pch_setup_backlight(struct intel_connector *connector, enum pipe unus
 
 	panel->backlight.pwm_level_min = get_backlight_min_vbt(connector);
 
-	cpu_ctl2 = intel_de_read(i915, BLC_PWM_CPU_CTL2);
+	cpu_ctl2 = intel_de_read(display, BLC_PWM_CPU_CTL2);
 	panel->backlight.pwm_enabled = (cpu_ctl2 & BLM_PWM_ENABLE) &&
 		(pch_ctl1 & BLM_PCH_PWM_ENABLE);
 
-	drm_dbg_kms(&i915->drm,
+	drm_dbg_kms(display->drm,
 		    "[CONNECTOR:%d:%s] Using native PCH PWM for backlight control\n",
 		    connector->base.base.id, connector->base.name);
 
@@ -1303,16 +1319,16 @@  static int pch_setup_backlight(struct intel_connector *connector, enum pipe unus
 
 static int i9xx_setup_backlight(struct intel_connector *connector, enum pipe unused)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	u32 ctl, val;
 
-	ctl = intel_de_read(i915, BLC_PWM_CTL);
+	ctl = intel_de_read(display, BLC_PWM_CTL);
 
-	if (DISPLAY_VER(i915) == 2 || IS_I915GM(i915) || IS_I945GM(i915))
+	if (DISPLAY_VER(display) == 2 || display->platform.i915gm || display->platform.i945gm)
 		panel->backlight.combination_mode = ctl & BLM_LEGACY_MODE;
 
-	if (IS_PINEVIEW(i915))
+	if (display->platform.pineview)
 		panel->backlight.active_low_pwm = ctl & BLM_POLARITY_PNV;
 
 	panel->backlight.pwm_level_max = ctl >> 17;
@@ -1336,7 +1352,7 @@  static int i9xx_setup_backlight(struct intel_connector *connector, enum pipe unu
 
 	panel->backlight.pwm_enabled = val != 0;
 
-	drm_dbg_kms(&i915->drm,
+	drm_dbg_kms(display->drm,
 		    "[CONNECTOR:%d:%s] Using native PWM for backlight control\n",
 		    connector->base.base.id, connector->base.name);
 
@@ -1345,15 +1361,15 @@  static int i9xx_setup_backlight(struct intel_connector *connector, enum pipe unu
 
 static int i965_setup_backlight(struct intel_connector *connector, enum pipe unused)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	u32 ctl, ctl2;
 
-	ctl2 = intel_de_read(i915, BLC_PWM_CTL2);
+	ctl2 = intel_de_read(display, BLC_PWM_CTL2);
 	panel->backlight.combination_mode = ctl2 & BLM_COMBINATION_MODE;
 	panel->backlight.active_low_pwm = ctl2 & BLM_POLARITY_I965;
 
-	ctl = intel_de_read(i915, BLC_PWM_CTL);
+	ctl = intel_de_read(display, BLC_PWM_CTL);
 	panel->backlight.pwm_level_max = ctl >> 16;
 
 	if (!panel->backlight.pwm_level_max)
@@ -1369,7 +1385,7 @@  static int i965_setup_backlight(struct intel_connector *connector, enum pipe unu
 
 	panel->backlight.pwm_enabled = ctl2 & BLM_PWM_ENABLE;
 
-	drm_dbg_kms(&i915->drm,
+	drm_dbg_kms(display->drm,
 		    "[CONNECTOR:%d:%s] Using native PWM for backlight control\n",
 		    connector->base.base.id, connector->base.name);
 
@@ -1378,17 +1394,17 @@  static int i965_setup_backlight(struct intel_connector *connector, enum pipe unu
 
 static int vlv_setup_backlight(struct intel_connector *connector, enum pipe pipe)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	u32 ctl, ctl2;
 
-	if (drm_WARN_ON(&i915->drm, pipe != PIPE_A && pipe != PIPE_B))
+	if (drm_WARN_ON(display->drm, pipe != PIPE_A && pipe != PIPE_B))
 		return -ENODEV;
 
-	ctl2 = intel_de_read(i915, VLV_BLC_PWM_CTL2(pipe));
+	ctl2 = intel_de_read(display, VLV_BLC_PWM_CTL2(pipe));
 	panel->backlight.active_low_pwm = ctl2 & BLM_POLARITY_I965;
 
-	ctl = intel_de_read(i915, VLV_BLC_PWM_CTL(pipe));
+	ctl = intel_de_read(display, VLV_BLC_PWM_CTL(pipe));
 	panel->backlight.pwm_level_max = ctl >> 16;
 
 	if (!panel->backlight.pwm_level_max)
@@ -1401,7 +1417,7 @@  static int vlv_setup_backlight(struct intel_connector *connector, enum pipe pipe
 
 	panel->backlight.pwm_enabled = ctl2 & BLM_PWM_ENABLE;
 
-	drm_dbg_kms(&i915->drm,
+	drm_dbg_kms(display->drm,
 		    "[CONNECTOR:%d:%s] Using native PWM for backlight control (on pipe %c)\n",
 		    connector->base.base.id, connector->base.name, pipe_name(pipe));
 
@@ -1411,25 +1427,25 @@  static int vlv_setup_backlight(struct intel_connector *connector, enum pipe pipe
 static int
 bxt_setup_backlight(struct intel_connector *connector, enum pipe unused)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	u32 pwm_ctl, val;
 
 	panel->backlight.controller = connector->panel.vbt.backlight.controller;
 
-	pwm_ctl = intel_de_read(i915,
+	pwm_ctl = intel_de_read(display,
 				BXT_BLC_PWM_CTL(panel->backlight.controller));
 
 	/* Controller 1 uses the utility pin. */
 	if (panel->backlight.controller == 1) {
-		val = intel_de_read(i915, UTIL_PIN_CTL);
+		val = intel_de_read(display, UTIL_PIN_CTL);
 		panel->backlight.util_pin_active_low =
 					val & UTIL_PIN_POLARITY;
 	}
 
 	panel->backlight.active_low_pwm = pwm_ctl & BXT_BLC_PWM_POLARITY;
 	panel->backlight.pwm_level_max =
-		intel_de_read(i915, BXT_BLC_PWM_FREQ(panel->backlight.controller));
+		intel_de_read(display, BXT_BLC_PWM_FREQ(panel->backlight.controller));
 
 	if (!panel->backlight.pwm_level_max)
 		panel->backlight.pwm_level_max = get_backlight_max_vbt(connector);
@@ -1441,7 +1457,7 @@  bxt_setup_backlight(struct intel_connector *connector, enum pipe unused)
 
 	panel->backlight.pwm_enabled = pwm_ctl & BXT_BLC_PWM_ENABLE;
 
-	drm_dbg_kms(&i915->drm,
+	drm_dbg_kms(display->drm,
 		    "[CONNECTOR:%d:%s] Using native PWM for backlight control (controller=%d)\n",
 		    connector->base.base.id, connector->base.name,
 		    panel->backlight.controller);
@@ -1449,8 +1465,10 @@  bxt_setup_backlight(struct intel_connector *connector, enum pipe unused)
 	return 0;
 }
 
-static int cnp_num_backlight_controllers(struct drm_i915_private *i915)
+static int cnp_num_backlight_controllers(struct intel_display *display)
 {
+	struct drm_i915_private *i915 = to_i915(display->drm);
+
 	if (INTEL_PCH_TYPE(i915) >= PCH_MTL)
 		return 2;
 
@@ -1463,15 +1481,17 @@  static int cnp_num_backlight_controllers(struct drm_i915_private *i915)
 	return 1;
 }
 
-static bool cnp_backlight_controller_is_valid(struct drm_i915_private *i915, int controller)
+static bool cnp_backlight_controller_is_valid(struct intel_display *display, int controller)
 {
-	if (controller < 0 || controller >= cnp_num_backlight_controllers(i915))
+	struct drm_i915_private *i915 = to_i915(display->drm);
+
+	if (controller < 0 || controller >= cnp_num_backlight_controllers(display))
 		return false;
 
 	if (controller == 1 &&
 	    INTEL_PCH_TYPE(i915) >= PCH_ICP &&
 	    INTEL_PCH_TYPE(i915) <= PCH_ADP)
-		return intel_de_read(i915, SOUTH_CHICKEN1) & ICP_SECOND_PPS_IO_SELECT;
+		return intel_de_read(display, SOUTH_CHICKEN1) & ICP_SECOND_PPS_IO_SELECT;
 
 	return true;
 }
@@ -1479,7 +1499,7 @@  static bool cnp_backlight_controller_is_valid(struct drm_i915_private *i915, int
 static int
 cnp_setup_backlight(struct intel_connector *connector, enum pipe unused)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	u32 pwm_ctl;
 
@@ -1488,19 +1508,20 @@  cnp_setup_backlight(struct intel_connector *connector, enum pipe unused)
 	 * controller. ICP+ can have two controllers, depending on pin muxing.
 	 */
 	panel->backlight.controller = connector->panel.vbt.backlight.controller;
-	if (!cnp_backlight_controller_is_valid(i915, panel->backlight.controller)) {
-		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] Invalid backlight controller %d, assuming 0\n",
+	if (!cnp_backlight_controller_is_valid(display, panel->backlight.controller)) {
+		drm_dbg_kms(display->drm,
+			    "[CONNECTOR:%d:%s] Invalid backlight controller %d, assuming 0\n",
 			    connector->base.base.id, connector->base.name,
 			    panel->backlight.controller);
 		panel->backlight.controller = 0;
 	}
 
-	pwm_ctl = intel_de_read(i915,
+	pwm_ctl = intel_de_read(display,
 				BXT_BLC_PWM_CTL(panel->backlight.controller));
 
 	panel->backlight.active_low_pwm = pwm_ctl & BXT_BLC_PWM_POLARITY;
 	panel->backlight.pwm_level_max =
-		intel_de_read(i915, BXT_BLC_PWM_FREQ(panel->backlight.controller));
+		intel_de_read(display, BXT_BLC_PWM_FREQ(panel->backlight.controller));
 
 	if (!panel->backlight.pwm_level_max)
 		panel->backlight.pwm_level_max = get_backlight_max_vbt(connector);
@@ -1512,7 +1533,7 @@  cnp_setup_backlight(struct intel_connector *connector, enum pipe unused)
 
 	panel->backlight.pwm_enabled = pwm_ctl & BXT_BLC_PWM_ENABLE;
 
-	drm_dbg_kms(&i915->drm,
+	drm_dbg_kms(display->drm,
 		    "[CONNECTOR:%d:%s] Using native PCH PWM for backlight control (controller=%d)\n",
 		    connector->base.base.id, connector->base.name,
 		    panel->backlight.controller);
@@ -1523,22 +1544,25 @@  cnp_setup_backlight(struct intel_connector *connector, enum pipe unused)
 static int ext_pwm_setup_backlight(struct intel_connector *connector,
 				   enum pipe pipe)
 {
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 	const char *desc;
 	u32 level;
 
 	/* Get the right PWM chip for DSI backlight according to VBT */
 	if (connector->panel.vbt.dsi.config->pwm_blc == PPS_BLC_PMIC) {
-		panel->backlight.pwm = pwm_get(i915->drm.dev, "pwm_pmic_backlight");
+		panel->backlight.pwm = pwm_get(display->drm->dev,
+					       "pwm_pmic_backlight");
 		desc = "PMIC";
 	} else {
-		panel->backlight.pwm = pwm_get(i915->drm.dev, "pwm_soc_backlight");
+		panel->backlight.pwm = pwm_get(display->drm->dev,
+					       "pwm_soc_backlight");
 		desc = "SoC";
 	}
 
 	if (IS_ERR(panel->backlight.pwm)) {
-		drm_err(&i915->drm, "[CONNECTOR:%d:%s] Failed to get the %s PWM chip\n",
+		drm_err(display->drm,
+			"[CONNECTOR:%d:%s] Failed to get the %s PWM chip\n",
 			connector->base.base.id, connector->base.name, desc);
 		panel->backlight.pwm = NULL;
 		return -ENODEV;
@@ -1556,7 +1580,8 @@  static int ext_pwm_setup_backlight(struct intel_connector *connector,
 		level = intel_backlight_invert_pwm_level(connector, level);
 		panel->backlight.pwm_enabled = true;
 
-		drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] PWM already enabled at freq %ld, VBT freq %d, level %d\n",
+		drm_dbg_kms(display->drm,
+			    "[CONNECTOR:%d:%s] PWM already enabled at freq %ld, VBT freq %d, level %d\n",
 			    connector->base.base.id, connector->base.name,
 			    NSEC_PER_SEC / (unsigned long)panel->backlight.pwm_state.period,
 			    get_vbt_pwm_freq(connector), level);
@@ -1566,7 +1591,7 @@  static int ext_pwm_setup_backlight(struct intel_connector *connector,
 			NSEC_PER_SEC / get_vbt_pwm_freq(connector);
 	}
 
-	drm_dbg_kms(&i915->drm,
+	drm_dbg_kms(display->drm,
 		    "[CONNECTOR:%d:%s] Using %s PWM for backlight control\n",
 		    connector->base.base.id, connector->base.name, desc);
 
@@ -1632,17 +1657,17 @@  void intel_backlight_update(struct intel_atomic_state *state,
 			    const struct drm_connector_state *conn_state)
 {
 	struct intel_connector *connector = to_intel_connector(conn_state->connector);
-	struct drm_i915_private *i915 = to_i915(connector->base.dev);
+	struct intel_display *display = to_intel_display(connector);
 	struct intel_panel *panel = &connector->panel;
 
 	if (!panel->backlight.present)
 		return;
 
-	mutex_lock(&i915->display.backlight.lock);
+	mutex_lock(&display->backlight.lock);
 	if (!panel->backlight.enabled)
 		__intel_backlight_enable(crtc_state, conn_state);
 
-	mutex_unlock(&i915->display.backlight.lock);
+	mutex_unlock(&display->backlight.lock);
 }
 
 int intel_backlight_setup(struct intel_connector *connector, enum pipe pipe)
@@ -1793,13 +1818,14 @@  void intel_backlight_init_funcs(struct intel_panel *panel)
 {
 	struct intel_connector *connector =
 		container_of(panel, struct intel_connector, panel);
+	struct intel_display *display = to_intel_display(connector);
 	struct drm_i915_private *i915 = to_i915(connector->base.dev);
 
 	if (connector->base.connector_type == DRM_MODE_CONNECTOR_DSI &&
 	    intel_dsi_dcs_init_backlight_funcs(connector) == 0)
 		return;
 
-	if (IS_GEMINILAKE(i915) || IS_BROXTON(i915)) {
+	if (display->platform.geminilake || display->platform.broxton) {
 		panel->backlight.pwm_funcs = &bxt_pwm_funcs;
 	} else if (INTEL_PCH_TYPE(i915) >= PCH_CNP) {
 		panel->backlight.pwm_funcs = &cnp_pwm_funcs;
@@ -1810,13 +1836,13 @@  void intel_backlight_init_funcs(struct intel_panel *panel)
 			panel->backlight.pwm_funcs = &spt_pwm_funcs;
 	} else if (HAS_PCH_SPLIT(i915)) {
 		panel->backlight.pwm_funcs = &pch_pwm_funcs;
-	} else if (IS_VALLEYVIEW(i915) || IS_CHERRYVIEW(i915)) {
+	} else if (display->platform.valleyview || display->platform.cherryview) {
 		if (connector->base.connector_type == DRM_MODE_CONNECTOR_DSI) {
 			panel->backlight.pwm_funcs = &ext_pwm_funcs;
 		} else {
 			panel->backlight.pwm_funcs = &vlv_pwm_funcs;
 		}
-	} else if (DISPLAY_VER(i915) == 4) {
+	} else if (DISPLAY_VER(display) == 4) {
 		panel->backlight.pwm_funcs = &i965_pwm_funcs;
 	} else {
 		panel->backlight.pwm_funcs = &i9xx_pwm_funcs;
@@ -1826,7 +1852,7 @@  void intel_backlight_init_funcs(struct intel_panel *panel)
 		if (intel_dp_aux_init_backlight_funcs(connector) == 0)
 			return;
 
-		if (!intel_has_quirk(&i915->display, QUIRK_NO_PPS_BACKLIGHT_POWER_HOOK))
+		if (!intel_has_quirk(display, QUIRK_NO_PPS_BACKLIGHT_POWER_HOOK))
 			connector->panel.backlight.power = intel_pps_backlight_power;
 	}