diff options
Diffstat (limited to 'drivers/gpu/drm/i915/display/intel_panel.c')
| -rw-r--r-- | drivers/gpu/drm/i915/display/intel_panel.c | 407 | 
1 files changed, 228 insertions, 179 deletions
diff --git a/drivers/gpu/drm/i915/display/intel_panel.c b/drivers/gpu/drm/i915/display/intel_panel.c index 7b3ec6eb3382..276f43870802 100644 --- a/drivers/gpu/drm/i915/display/intel_panel.c +++ b/drivers/gpu/drm/i915/display/intel_panel.c @@ -96,8 +96,9 @@ intel_panel_edid_downclock_mode(struct intel_connector *connector,  	if (!downclock_mode)  		return NULL; -	DRM_DEBUG_KMS("[CONNECTOR:%d:%s] using downclock mode from EDID: ", -		      connector->base.base.id, connector->base.name); +	drm_dbg_kms(&dev_priv->drm, +		    "[CONNECTOR:%d:%s] using downclock mode from EDID: ", +		    connector->base.base.id, connector->base.name);  	drm_mode_debug_printmodeline(downclock_mode);  	return downclock_mode; @@ -122,8 +123,9 @@ intel_panel_edid_fixed_mode(struct intel_connector *connector)  		if (!fixed_mode)  			return NULL; -		DRM_DEBUG_KMS("[CONNECTOR:%d:%s] using preferred mode from EDID: ", -			      connector->base.base.id, connector->base.name); +		drm_dbg_kms(&dev_priv->drm, +			    "[CONNECTOR:%d:%s] using preferred mode from EDID: ", +			    connector->base.base.id, connector->base.name);  		drm_mode_debug_printmodeline(fixed_mode);  		return fixed_mode; @@ -138,8 +140,9 @@ intel_panel_edid_fixed_mode(struct intel_connector *connector)  	fixed_mode->type |= DRM_MODE_TYPE_PREFERRED; -	DRM_DEBUG_KMS("[CONNECTOR:%d:%s] using first mode from EDID: ", -		      connector->base.base.id, connector->base.name); +	drm_dbg_kms(&dev_priv->drm, +		    "[CONNECTOR:%d:%s] using first mode from EDID: ", +		    connector->base.base.id, connector->base.name);  	drm_mode_debug_printmodeline(fixed_mode);  	return fixed_mode; @@ -162,8 +165,8 @@ intel_panel_vbt_fixed_mode(struct intel_connector *connector)  	fixed_mode->type |= DRM_MODE_TYPE_PREFERRED; -	DRM_DEBUG_KMS("[CONNECTOR:%d:%s] using mode from VBT: ", -		      connector->base.base.id, connector->base.name); +	drm_dbg_kms(&dev_priv->drm, "[CONNECTOR:%d:%s] using mode from VBT: ", +		    connector->base.base.id, connector->base.name);  	drm_mode_debug_printmodeline(fixed_mode);  	info->width_mm = fixed_mode->width_mm; @@ -423,15 +426,15 @@ void intel_gmch_panel_fitting(struct intel_crtc *intel_crtc,  		}  		break;  	default: -		WARN(1, "bad panel fit mode: %d\n", fitting_mode); +		drm_WARN(&dev_priv->drm, 1, "bad panel fit mode: %d\n", +			 fitting_mode);  		return;  	}  	/* 965+ wants fuzzy fitting */  	/* FIXME: handle multiple panels by failing gracefully */  	if (INTEL_GEN(dev_priv) >= 4) -		pfit_control |= ((intel_crtc->pipe << PFIT_PIPE_SHIFT) | -				 PFIT_FILTER_FUZZY); +		pfit_control |= PFIT_PIPE(intel_crtc->pipe) | PFIT_FILTER_FUZZY;  out:  	if ((pfit_control & PFIT_ENABLE) == 0) { @@ -520,7 +523,7 @@ static u32 intel_panel_compute_brightness(struct intel_connector *connector,  	struct drm_i915_private *dev_priv = to_i915(connector->base.dev);  	struct intel_panel *panel = &connector->panel; -	WARN_ON(panel->backlight.max == 0); +	drm_WARN_ON(&dev_priv->drm, panel->backlight.max == 0);  	if (i915_modparams.invert_brightness < 0)  		return val; @@ -537,14 +540,14 @@ static u32 lpt_get_backlight(struct intel_connector *connector)  {  	struct drm_i915_private *dev_priv = to_i915(connector->base.dev); -	return I915_READ(BLC_PWM_PCH_CTL2) & BACKLIGHT_DUTY_CYCLE_MASK; +	return intel_de_read(dev_priv, BLC_PWM_PCH_CTL2) & BACKLIGHT_DUTY_CYCLE_MASK;  }  static u32 pch_get_backlight(struct intel_connector *connector)  {  	struct drm_i915_private *dev_priv = to_i915(connector->base.dev); -	return I915_READ(BLC_PWM_CPU_CTL) & BACKLIGHT_DUTY_CYCLE_MASK; +	return intel_de_read(dev_priv, BLC_PWM_CPU_CTL) & BACKLIGHT_DUTY_CYCLE_MASK;  }  static u32 i9xx_get_backlight(struct intel_connector *connector) @@ -553,7 +556,7 @@ static u32 i9xx_get_backlight(struct intel_connector *connector)  	struct intel_panel *panel = &connector->panel;  	u32 val; -	val = I915_READ(BLC_PWM_CTL) & BACKLIGHT_DUTY_CYCLE_MASK; +	val = intel_de_read(dev_priv, BLC_PWM_CTL) & BACKLIGHT_DUTY_CYCLE_MASK;  	if (INTEL_GEN(dev_priv) < 4)  		val >>= 1; @@ -569,10 +572,10 @@ static u32 i9xx_get_backlight(struct intel_connector *connector)  static u32 _vlv_get_backlight(struct drm_i915_private *dev_priv, enum pipe pipe)  { -	if (WARN_ON(pipe != PIPE_A && pipe != PIPE_B)) +	if (drm_WARN_ON(&dev_priv->drm, pipe != PIPE_A && pipe != PIPE_B))  		return 0; -	return I915_READ(VLV_BLC_PWM_CTL(pipe)) & BACKLIGHT_DUTY_CYCLE_MASK; +	return intel_de_read(dev_priv, VLV_BLC_PWM_CTL(pipe)) & BACKLIGHT_DUTY_CYCLE_MASK;  }  static u32 vlv_get_backlight(struct intel_connector *connector) @@ -588,7 +591,8 @@ static u32 bxt_get_backlight(struct intel_connector *connector)  	struct drm_i915_private *dev_priv = to_i915(connector->base.dev);  	struct intel_panel *panel = &connector->panel; -	return I915_READ(BXT_BLC_PWM_DUTY(panel->backlight.controller)); +	return intel_de_read(dev_priv, +			     BXT_BLC_PWM_DUTY(panel->backlight.controller));  }  static u32 pwm_get_backlight(struct intel_connector *connector) @@ -605,8 +609,8 @@ static void lpt_set_backlight(const struct drm_connector_state *conn_state, u32  	struct intel_connector *connector = to_intel_connector(conn_state->connector);  	struct drm_i915_private *dev_priv = to_i915(connector->base.dev); -	u32 val = I915_READ(BLC_PWM_PCH_CTL2) & ~BACKLIGHT_DUTY_CYCLE_MASK; -	I915_WRITE(BLC_PWM_PCH_CTL2, val | level); +	u32 val = intel_de_read(dev_priv, BLC_PWM_PCH_CTL2) & ~BACKLIGHT_DUTY_CYCLE_MASK; +	intel_de_write(dev_priv, BLC_PWM_PCH_CTL2, val | level);  }  static void pch_set_backlight(const struct drm_connector_state *conn_state, u32 level) @@ -615,8 +619,8 @@ static void pch_set_backlight(const struct drm_connector_state *conn_state, u32  	struct drm_i915_private *dev_priv = to_i915(connector->base.dev);  	u32 tmp; -	tmp = I915_READ(BLC_PWM_CPU_CTL) & ~BACKLIGHT_DUTY_CYCLE_MASK; -	I915_WRITE(BLC_PWM_CPU_CTL, tmp | level); +	tmp = intel_de_read(dev_priv, BLC_PWM_CPU_CTL) & ~BACKLIGHT_DUTY_CYCLE_MASK; +	intel_de_write(dev_priv, BLC_PWM_CPU_CTL, tmp | level);  }  static void i9xx_set_backlight(const struct drm_connector_state *conn_state, u32 level) @@ -626,7 +630,7 @@ static void i9xx_set_backlight(const struct drm_connector_state *conn_state, u32  	struct intel_panel *panel = &connector->panel;  	u32 tmp, mask; -	WARN_ON(panel->backlight.max == 0); +	drm_WARN_ON(&dev_priv->drm, panel->backlight.max == 0);  	if (panel->backlight.combination_mode) {  		u8 lbpc; @@ -643,8 +647,8 @@ static void i9xx_set_backlight(const struct drm_connector_state *conn_state, u32  		mask = BACKLIGHT_DUTY_CYCLE_MASK_PNV;  	} -	tmp = I915_READ(BLC_PWM_CTL) & ~mask; -	I915_WRITE(BLC_PWM_CTL, tmp | level); +	tmp = intel_de_read(dev_priv, BLC_PWM_CTL) & ~mask; +	intel_de_write(dev_priv, BLC_PWM_CTL, tmp | level);  }  static void vlv_set_backlight(const struct drm_connector_state *conn_state, u32 level) @@ -654,8 +658,8 @@ static void vlv_set_backlight(const struct drm_connector_state *conn_state, u32  	enum pipe pipe = to_intel_crtc(conn_state->crtc)->pipe;  	u32 tmp; -	tmp = I915_READ(VLV_BLC_PWM_CTL(pipe)) & ~BACKLIGHT_DUTY_CYCLE_MASK; -	I915_WRITE(VLV_BLC_PWM_CTL(pipe), tmp | level); +	tmp = intel_de_read(dev_priv, VLV_BLC_PWM_CTL(pipe)) & ~BACKLIGHT_DUTY_CYCLE_MASK; +	intel_de_write(dev_priv, VLV_BLC_PWM_CTL(pipe), tmp | level);  }  static void bxt_set_backlight(const struct drm_connector_state *conn_state, u32 level) @@ -664,7 +668,8 @@ static void bxt_set_backlight(const struct drm_connector_state *conn_state, u32  	struct drm_i915_private *dev_priv = to_i915(connector->base.dev);  	struct intel_panel *panel = &connector->panel; -	I915_WRITE(BXT_BLC_PWM_DUTY(panel->backlight.controller), level); +	intel_de_write(dev_priv, +		       BXT_BLC_PWM_DUTY(panel->backlight.controller), level);  }  static void pwm_set_backlight(const struct drm_connector_state *conn_state, u32 level) @@ -709,7 +714,7 @@ void intel_panel_set_backlight_acpi(const struct drm_connector_state *conn_state  	mutex_lock(&dev_priv->backlight_lock); -	WARN_ON(panel->backlight.max == 0); +	drm_WARN_ON(&dev_priv->drm, panel->backlight.max == 0);  	hw_level = clamp_user_to_hw(connector, user_level, user_max);  	panel->backlight.level = hw_level; @@ -742,14 +747,16 @@ 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 = I915_READ(BLC_PWM_CPU_CTL2); +	tmp = intel_de_read(dev_priv, BLC_PWM_CPU_CTL2);  	if (tmp & BLM_PWM_ENABLE) { -		DRM_DEBUG_KMS("cpu backlight was enabled, disabling\n"); -		I915_WRITE(BLC_PWM_CPU_CTL2, tmp & ~BLM_PWM_ENABLE); +		drm_dbg_kms(&dev_priv->drm, +			    "cpu backlight was enabled, disabling\n"); +		intel_de_write(dev_priv, BLC_PWM_CPU_CTL2, +			       tmp & ~BLM_PWM_ENABLE);  	} -	tmp = I915_READ(BLC_PWM_PCH_CTL1); -	I915_WRITE(BLC_PWM_PCH_CTL1, tmp & ~BLM_PCH_PWM_ENABLE); +	tmp = intel_de_read(dev_priv, BLC_PWM_PCH_CTL1); +	intel_de_write(dev_priv, BLC_PWM_PCH_CTL1, tmp & ~BLM_PCH_PWM_ENABLE);  }  static void pch_disable_backlight(const struct drm_connector_state *old_conn_state) @@ -760,11 +767,11 @@ static void pch_disable_backlight(const struct drm_connector_state *old_conn_sta  	intel_panel_actually_set_backlight(old_conn_state, 0); -	tmp = I915_READ(BLC_PWM_CPU_CTL2); -	I915_WRITE(BLC_PWM_CPU_CTL2, tmp & ~BLM_PWM_ENABLE); +	tmp = intel_de_read(dev_priv, BLC_PWM_CPU_CTL2); +	intel_de_write(dev_priv, BLC_PWM_CPU_CTL2, tmp & ~BLM_PWM_ENABLE); -	tmp = I915_READ(BLC_PWM_PCH_CTL1); -	I915_WRITE(BLC_PWM_PCH_CTL1, tmp & ~BLM_PCH_PWM_ENABLE); +	tmp = intel_de_read(dev_priv, BLC_PWM_PCH_CTL1); +	intel_de_write(dev_priv, BLC_PWM_PCH_CTL1, tmp & ~BLM_PCH_PWM_ENABLE);  }  static void i9xx_disable_backlight(const struct drm_connector_state *old_conn_state) @@ -779,8 +786,8 @@ static void i965_disable_backlight(const struct drm_connector_state *old_conn_st  	intel_panel_actually_set_backlight(old_conn_state, 0); -	tmp = I915_READ(BLC_PWM_CTL2); -	I915_WRITE(BLC_PWM_CTL2, tmp & ~BLM_PWM_ENABLE); +	tmp = intel_de_read(dev_priv, BLC_PWM_CTL2); +	intel_de_write(dev_priv, BLC_PWM_CTL2, tmp & ~BLM_PWM_ENABLE);  }  static void vlv_disable_backlight(const struct drm_connector_state *old_conn_state) @@ -792,8 +799,9 @@ static void vlv_disable_backlight(const struct drm_connector_state *old_conn_sta  	intel_panel_actually_set_backlight(old_conn_state, 0); -	tmp = I915_READ(VLV_BLC_PWM_CTL2(pipe)); -	I915_WRITE(VLV_BLC_PWM_CTL2(pipe), tmp & ~BLM_PWM_ENABLE); +	tmp = intel_de_read(dev_priv, VLV_BLC_PWM_CTL2(pipe)); +	intel_de_write(dev_priv, VLV_BLC_PWM_CTL2(pipe), +		       tmp & ~BLM_PWM_ENABLE);  }  static void bxt_disable_backlight(const struct drm_connector_state *old_conn_state) @@ -805,14 +813,15 @@ static void bxt_disable_backlight(const struct drm_connector_state *old_conn_sta  	intel_panel_actually_set_backlight(old_conn_state, 0); -	tmp = I915_READ(BXT_BLC_PWM_CTL(panel->backlight.controller)); -	I915_WRITE(BXT_BLC_PWM_CTL(panel->backlight.controller), -			tmp & ~BXT_BLC_PWM_ENABLE); +	tmp = intel_de_read(dev_priv, +			    BXT_BLC_PWM_CTL(panel->backlight.controller)); +	intel_de_write(dev_priv, BXT_BLC_PWM_CTL(panel->backlight.controller), +		       tmp & ~BXT_BLC_PWM_ENABLE);  	if (panel->backlight.controller == 1) { -		val = I915_READ(UTIL_PIN_CTL); +		val = intel_de_read(dev_priv, UTIL_PIN_CTL);  		val &= ~UTIL_PIN_ENABLE; -		I915_WRITE(UTIL_PIN_CTL, val); +		intel_de_write(dev_priv, UTIL_PIN_CTL, val);  	}  } @@ -825,9 +834,10 @@ static void cnp_disable_backlight(const struct drm_connector_state *old_conn_sta  	intel_panel_actually_set_backlight(old_conn_state, 0); -	tmp = I915_READ(BXT_BLC_PWM_CTL(panel->backlight.controller)); -	I915_WRITE(BXT_BLC_PWM_CTL(panel->backlight.controller), -		   tmp & ~BXT_BLC_PWM_ENABLE); +	tmp = intel_de_read(dev_priv, +			    BXT_BLC_PWM_CTL(panel->backlight.controller)); +	intel_de_write(dev_priv, BXT_BLC_PWM_CTL(panel->backlight.controller), +		       tmp & ~BXT_BLC_PWM_ENABLE);  }  static void pwm_disable_backlight(const struct drm_connector_state *old_conn_state) @@ -857,7 +867,8 @@ void intel_panel_disable_backlight(const struct drm_connector_state *old_conn_st  	 * another client is not activated.  	 */  	if (dev_priv->drm.switch_power_state == DRM_SWITCH_POWER_CHANGING) { -		DRM_DEBUG_DRIVER("Skipping backlight disable on vga switch\n"); +		drm_dbg(&dev_priv->drm, +			"Skipping backlight disable on vga switch\n");  		return;  	} @@ -879,31 +890,31 @@ static void lpt_enable_backlight(const struct intel_crtc_state *crtc_state,  	struct intel_panel *panel = &connector->panel;  	u32 pch_ctl1, pch_ctl2, schicken; -	pch_ctl1 = I915_READ(BLC_PWM_PCH_CTL1); +	pch_ctl1 = intel_de_read(dev_priv, BLC_PWM_PCH_CTL1);  	if (pch_ctl1 & BLM_PCH_PWM_ENABLE) { -		DRM_DEBUG_KMS("pch backlight already enabled\n"); +		drm_dbg_kms(&dev_priv->drm, "pch backlight already enabled\n");  		pch_ctl1 &= ~BLM_PCH_PWM_ENABLE; -		I915_WRITE(BLC_PWM_PCH_CTL1, pch_ctl1); +		intel_de_write(dev_priv, BLC_PWM_PCH_CTL1, pch_ctl1);  	}  	if (HAS_PCH_LPT(dev_priv)) { -		schicken = I915_READ(SOUTH_CHICKEN2); +		schicken = intel_de_read(dev_priv, SOUTH_CHICKEN2);  		if (panel->backlight.alternate_pwm_increment)  			schicken |= LPT_PWM_GRANULARITY;  		else  			schicken &= ~LPT_PWM_GRANULARITY; -		I915_WRITE(SOUTH_CHICKEN2, schicken); +		intel_de_write(dev_priv, SOUTH_CHICKEN2, schicken);  	} else { -		schicken = I915_READ(SOUTH_CHICKEN1); +		schicken = intel_de_read(dev_priv, SOUTH_CHICKEN1);  		if (panel->backlight.alternate_pwm_increment)  			schicken |= SPT_PWM_GRANULARITY;  		else  			schicken &= ~SPT_PWM_GRANULARITY; -		I915_WRITE(SOUTH_CHICKEN1, schicken); +		intel_de_write(dev_priv, SOUTH_CHICKEN1, schicken);  	}  	pch_ctl2 = panel->backlight.max << 16; -	I915_WRITE(BLC_PWM_PCH_CTL2, pch_ctl2); +	intel_de_write(dev_priv, BLC_PWM_PCH_CTL2, pch_ctl2);  	pch_ctl1 = 0;  	if (panel->backlight.active_low_pwm) @@ -913,9 +924,10 @@ static void lpt_enable_backlight(const struct intel_crtc_state *crtc_state,  	if (HAS_PCH_LPT(dev_priv))  		pch_ctl1 |= BLM_PCH_OVERRIDE_ENABLE; -	I915_WRITE(BLC_PWM_PCH_CTL1, pch_ctl1); -	POSTING_READ(BLC_PWM_PCH_CTL1); -	I915_WRITE(BLC_PWM_PCH_CTL1, pch_ctl1 | BLM_PCH_PWM_ENABLE); +	intel_de_write(dev_priv, BLC_PWM_PCH_CTL1, pch_ctl1); +	intel_de_posting_read(dev_priv, BLC_PWM_PCH_CTL1); +	intel_de_write(dev_priv, BLC_PWM_PCH_CTL1, +		       pch_ctl1 | BLM_PCH_PWM_ENABLE);  	/* This won't stick until the above enable. */  	intel_panel_actually_set_backlight(conn_state, panel->backlight.level); @@ -930,41 +942,42 @@ static void pch_enable_backlight(const struct intel_crtc_state *crtc_state,  	enum transcoder cpu_transcoder = crtc_state->cpu_transcoder;  	u32 cpu_ctl2, pch_ctl1, pch_ctl2; -	cpu_ctl2 = I915_READ(BLC_PWM_CPU_CTL2); +	cpu_ctl2 = intel_de_read(dev_priv, BLC_PWM_CPU_CTL2);  	if (cpu_ctl2 & BLM_PWM_ENABLE) { -		DRM_DEBUG_KMS("cpu backlight already enabled\n"); +		drm_dbg_kms(&dev_priv->drm, "cpu backlight already enabled\n");  		cpu_ctl2 &= ~BLM_PWM_ENABLE; -		I915_WRITE(BLC_PWM_CPU_CTL2, cpu_ctl2); +		intel_de_write(dev_priv, BLC_PWM_CPU_CTL2, cpu_ctl2);  	} -	pch_ctl1 = I915_READ(BLC_PWM_PCH_CTL1); +	pch_ctl1 = intel_de_read(dev_priv, BLC_PWM_PCH_CTL1);  	if (pch_ctl1 & BLM_PCH_PWM_ENABLE) { -		DRM_DEBUG_KMS("pch backlight already enabled\n"); +		drm_dbg_kms(&dev_priv->drm, "pch backlight already enabled\n");  		pch_ctl1 &= ~BLM_PCH_PWM_ENABLE; -		I915_WRITE(BLC_PWM_PCH_CTL1, pch_ctl1); +		intel_de_write(dev_priv, BLC_PWM_PCH_CTL1, pch_ctl1);  	}  	if (cpu_transcoder == TRANSCODER_EDP)  		cpu_ctl2 = BLM_TRANSCODER_EDP;  	else  		cpu_ctl2 = BLM_PIPE(cpu_transcoder); -	I915_WRITE(BLC_PWM_CPU_CTL2, cpu_ctl2); -	POSTING_READ(BLC_PWM_CPU_CTL2); -	I915_WRITE(BLC_PWM_CPU_CTL2, cpu_ctl2 | BLM_PWM_ENABLE); +	intel_de_write(dev_priv, BLC_PWM_CPU_CTL2, cpu_ctl2); +	intel_de_posting_read(dev_priv, BLC_PWM_CPU_CTL2); +	intel_de_write(dev_priv, BLC_PWM_CPU_CTL2, cpu_ctl2 | BLM_PWM_ENABLE);  	/* This won't stick until the above enable. */  	intel_panel_actually_set_backlight(conn_state, panel->backlight.level);  	pch_ctl2 = panel->backlight.max << 16; -	I915_WRITE(BLC_PWM_PCH_CTL2, pch_ctl2); +	intel_de_write(dev_priv, BLC_PWM_PCH_CTL2, pch_ctl2);  	pch_ctl1 = 0;  	if (panel->backlight.active_low_pwm)  		pch_ctl1 |= BLM_PCH_POLARITY; -	I915_WRITE(BLC_PWM_PCH_CTL1, pch_ctl1); -	POSTING_READ(BLC_PWM_PCH_CTL1); -	I915_WRITE(BLC_PWM_PCH_CTL1, pch_ctl1 | BLM_PCH_PWM_ENABLE); +	intel_de_write(dev_priv, BLC_PWM_PCH_CTL1, pch_ctl1); +	intel_de_posting_read(dev_priv, BLC_PWM_PCH_CTL1); +	intel_de_write(dev_priv, BLC_PWM_PCH_CTL1, +		       pch_ctl1 | BLM_PCH_PWM_ENABLE);  }  static void i9xx_enable_backlight(const struct intel_crtc_state *crtc_state, @@ -975,10 +988,10 @@ static void i9xx_enable_backlight(const struct intel_crtc_state *crtc_state,  	struct intel_panel *panel = &connector->panel;  	u32 ctl, freq; -	ctl = I915_READ(BLC_PWM_CTL); +	ctl = intel_de_read(dev_priv, BLC_PWM_CTL);  	if (ctl & BACKLIGHT_DUTY_CYCLE_MASK_PNV) { -		DRM_DEBUG_KMS("backlight already enabled\n"); -		I915_WRITE(BLC_PWM_CTL, 0); +		drm_dbg_kms(&dev_priv->drm, "backlight already enabled\n"); +		intel_de_write(dev_priv, BLC_PWM_CTL, 0);  	}  	freq = panel->backlight.max; @@ -991,8 +1004,8 @@ static void i9xx_enable_backlight(const struct intel_crtc_state *crtc_state,  	if (IS_PINEVIEW(dev_priv) && panel->backlight.active_low_pwm)  		ctl |= BLM_POLARITY_PNV; -	I915_WRITE(BLC_PWM_CTL, ctl); -	POSTING_READ(BLC_PWM_CTL); +	intel_de_write(dev_priv, BLC_PWM_CTL, ctl); +	intel_de_posting_read(dev_priv, BLC_PWM_CTL);  	/* XXX: combine this into above write? */  	intel_panel_actually_set_backlight(conn_state, panel->backlight.level); @@ -1003,7 +1016,7 @@ static void i9xx_enable_backlight(const struct intel_crtc_state *crtc_state,  	 * that has backlight.  	 */  	if (IS_GEN(dev_priv, 2)) -		I915_WRITE(BLC_HIST_CTL, BLM_HISTOGRAM_ENABLE); +		intel_de_write(dev_priv, BLC_HIST_CTL, BLM_HISTOGRAM_ENABLE);  }  static void i965_enable_backlight(const struct intel_crtc_state *crtc_state, @@ -1015,11 +1028,11 @@ static void i965_enable_backlight(const struct intel_crtc_state *crtc_state,  	enum pipe pipe = to_intel_crtc(conn_state->crtc)->pipe;  	u32 ctl, ctl2, freq; -	ctl2 = I915_READ(BLC_PWM_CTL2); +	ctl2 = intel_de_read(dev_priv, BLC_PWM_CTL2);  	if (ctl2 & BLM_PWM_ENABLE) { -		DRM_DEBUG_KMS("backlight already enabled\n"); +		drm_dbg_kms(&dev_priv->drm, "backlight already enabled\n");  		ctl2 &= ~BLM_PWM_ENABLE; -		I915_WRITE(BLC_PWM_CTL2, ctl2); +		intel_de_write(dev_priv, BLC_PWM_CTL2, ctl2);  	}  	freq = panel->backlight.max; @@ -1027,16 +1040,16 @@ static void i965_enable_backlight(const struct intel_crtc_state *crtc_state,  		freq /= 0xff;  	ctl = freq << 16; -	I915_WRITE(BLC_PWM_CTL, ctl); +	intel_de_write(dev_priv, 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; -	I915_WRITE(BLC_PWM_CTL2, ctl2); -	POSTING_READ(BLC_PWM_CTL2); -	I915_WRITE(BLC_PWM_CTL2, ctl2 | BLM_PWM_ENABLE); +	intel_de_write(dev_priv, BLC_PWM_CTL2, ctl2); +	intel_de_posting_read(dev_priv, BLC_PWM_CTL2); +	intel_de_write(dev_priv, BLC_PWM_CTL2, ctl2 | BLM_PWM_ENABLE);  	intel_panel_actually_set_backlight(conn_state, panel->backlight.level);  } @@ -1050,15 +1063,15 @@ static void vlv_enable_backlight(const struct intel_crtc_state *crtc_state,  	enum pipe pipe = to_intel_crtc(crtc_state->uapi.crtc)->pipe;  	u32 ctl, ctl2; -	ctl2 = I915_READ(VLV_BLC_PWM_CTL2(pipe)); +	ctl2 = intel_de_read(dev_priv, VLV_BLC_PWM_CTL2(pipe));  	if (ctl2 & BLM_PWM_ENABLE) { -		DRM_DEBUG_KMS("backlight already enabled\n"); +		drm_dbg_kms(&dev_priv->drm, "backlight already enabled\n");  		ctl2 &= ~BLM_PWM_ENABLE; -		I915_WRITE(VLV_BLC_PWM_CTL2(pipe), ctl2); +		intel_de_write(dev_priv, VLV_BLC_PWM_CTL2(pipe), ctl2);  	}  	ctl = panel->backlight.max << 16; -	I915_WRITE(VLV_BLC_PWM_CTL(pipe), ctl); +	intel_de_write(dev_priv, VLV_BLC_PWM_CTL(pipe), ctl);  	/* XXX: combine this into above write? */  	intel_panel_actually_set_backlight(conn_state, panel->backlight.level); @@ -1066,9 +1079,10 @@ static void vlv_enable_backlight(const struct intel_crtc_state *crtc_state,  	ctl2 = 0;  	if (panel->backlight.active_low_pwm)  		ctl2 |= BLM_POLARITY_I965; -	I915_WRITE(VLV_BLC_PWM_CTL2(pipe), ctl2); -	POSTING_READ(VLV_BLC_PWM_CTL2(pipe)); -	I915_WRITE(VLV_BLC_PWM_CTL2(pipe), ctl2 | BLM_PWM_ENABLE); +	intel_de_write(dev_priv, VLV_BLC_PWM_CTL2(pipe), ctl2); +	intel_de_posting_read(dev_priv, VLV_BLC_PWM_CTL2(pipe)); +	intel_de_write(dev_priv, VLV_BLC_PWM_CTL2(pipe), +		       ctl2 | BLM_PWM_ENABLE);  }  static void bxt_enable_backlight(const struct intel_crtc_state *crtc_state, @@ -1082,30 +1096,34 @@ static void bxt_enable_backlight(const struct intel_crtc_state *crtc_state,  	/* Controller 1 uses the utility pin. */  	if (panel->backlight.controller == 1) { -		val = I915_READ(UTIL_PIN_CTL); +		val = intel_de_read(dev_priv, UTIL_PIN_CTL);  		if (val & UTIL_PIN_ENABLE) { -			DRM_DEBUG_KMS("util pin already enabled\n"); +			drm_dbg_kms(&dev_priv->drm, +				    "util pin already enabled\n");  			val &= ~UTIL_PIN_ENABLE; -			I915_WRITE(UTIL_PIN_CTL, val); +			intel_de_write(dev_priv, UTIL_PIN_CTL, val);  		}  		val = 0;  		if (panel->backlight.util_pin_active_low)  			val |= UTIL_PIN_POLARITY; -		I915_WRITE(UTIL_PIN_CTL, val | UTIL_PIN_PIPE(pipe) | -				UTIL_PIN_MODE_PWM | UTIL_PIN_ENABLE); +		intel_de_write(dev_priv, UTIL_PIN_CTL, +			       val | UTIL_PIN_PIPE(pipe) | UTIL_PIN_MODE_PWM | UTIL_PIN_ENABLE);  	} -	pwm_ctl = I915_READ(BXT_BLC_PWM_CTL(panel->backlight.controller)); +	pwm_ctl = intel_de_read(dev_priv, +				BXT_BLC_PWM_CTL(panel->backlight.controller));  	if (pwm_ctl & BXT_BLC_PWM_ENABLE) { -		DRM_DEBUG_KMS("backlight already enabled\n"); +		drm_dbg_kms(&dev_priv->drm, "backlight already enabled\n");  		pwm_ctl &= ~BXT_BLC_PWM_ENABLE; -		I915_WRITE(BXT_BLC_PWM_CTL(panel->backlight.controller), -				pwm_ctl); +		intel_de_write(dev_priv, +			       BXT_BLC_PWM_CTL(panel->backlight.controller), +			       pwm_ctl);  	} -	I915_WRITE(BXT_BLC_PWM_FREQ(panel->backlight.controller), -			panel->backlight.max); +	intel_de_write(dev_priv, +		       BXT_BLC_PWM_FREQ(panel->backlight.controller), +		       panel->backlight.max);  	intel_panel_actually_set_backlight(conn_state, panel->backlight.level); @@ -1113,10 +1131,12 @@ static void bxt_enable_backlight(const struct intel_crtc_state *crtc_state,  	if (panel->backlight.active_low_pwm)  		pwm_ctl |= BXT_BLC_PWM_POLARITY; -	I915_WRITE(BXT_BLC_PWM_CTL(panel->backlight.controller), pwm_ctl); -	POSTING_READ(BXT_BLC_PWM_CTL(panel->backlight.controller)); -	I915_WRITE(BXT_BLC_PWM_CTL(panel->backlight.controller), -			pwm_ctl | BXT_BLC_PWM_ENABLE); +	intel_de_write(dev_priv, BXT_BLC_PWM_CTL(panel->backlight.controller), +		       pwm_ctl); +	intel_de_posting_read(dev_priv, +			      BXT_BLC_PWM_CTL(panel->backlight.controller)); +	intel_de_write(dev_priv, BXT_BLC_PWM_CTL(panel->backlight.controller), +		       pwm_ctl | BXT_BLC_PWM_ENABLE);  }  static void cnp_enable_backlight(const struct intel_crtc_state *crtc_state, @@ -1127,16 +1147,19 @@ static void cnp_enable_backlight(const struct intel_crtc_state *crtc_state,  	struct intel_panel *panel = &connector->panel;  	u32 pwm_ctl; -	pwm_ctl = I915_READ(BXT_BLC_PWM_CTL(panel->backlight.controller)); +	pwm_ctl = intel_de_read(dev_priv, +				BXT_BLC_PWM_CTL(panel->backlight.controller));  	if (pwm_ctl & BXT_BLC_PWM_ENABLE) { -		DRM_DEBUG_KMS("backlight already enabled\n"); +		drm_dbg_kms(&dev_priv->drm, "backlight already enabled\n");  		pwm_ctl &= ~BXT_BLC_PWM_ENABLE; -		I915_WRITE(BXT_BLC_PWM_CTL(panel->backlight.controller), -			   pwm_ctl); +		intel_de_write(dev_priv, +			       BXT_BLC_PWM_CTL(panel->backlight.controller), +			       pwm_ctl);  	} -	I915_WRITE(BXT_BLC_PWM_FREQ(panel->backlight.controller), -		   panel->backlight.max); +	intel_de_write(dev_priv, +		       BXT_BLC_PWM_FREQ(panel->backlight.controller), +		       panel->backlight.max);  	intel_panel_actually_set_backlight(conn_state, panel->backlight.level); @@ -1144,10 +1167,12 @@ static void cnp_enable_backlight(const struct intel_crtc_state *crtc_state,  	if (panel->backlight.active_low_pwm)  		pwm_ctl |= BXT_BLC_PWM_POLARITY; -	I915_WRITE(BXT_BLC_PWM_CTL(panel->backlight.controller), pwm_ctl); -	POSTING_READ(BXT_BLC_PWM_CTL(panel->backlight.controller)); -	I915_WRITE(BXT_BLC_PWM_CTL(panel->backlight.controller), -		   pwm_ctl | BXT_BLC_PWM_ENABLE); +	intel_de_write(dev_priv, BXT_BLC_PWM_CTL(panel->backlight.controller), +		       pwm_ctl); +	intel_de_posting_read(dev_priv, +			      BXT_BLC_PWM_CTL(panel->backlight.controller)); +	intel_de_write(dev_priv, BXT_BLC_PWM_CTL(panel->backlight.controller), +		       pwm_ctl | BXT_BLC_PWM_ENABLE);  }  static void pwm_enable_backlight(const struct intel_crtc_state *crtc_state, @@ -1194,7 +1219,7 @@ void intel_panel_enable_backlight(const struct intel_crtc_state *crtc_state,  	if (!panel->backlight.present)  		return; -	DRM_DEBUG_KMS("pipe %c\n", pipe_name(pipe)); +	drm_dbg_kms(&dev_priv->drm, "pipe %c\n", pipe_name(pipe));  	mutex_lock(&dev_priv->backlight_lock); @@ -1219,7 +1244,7 @@ static u32 intel_panel_get_backlight(struct intel_connector *connector)  	mutex_unlock(&dev_priv->backlight_lock); -	DRM_DEBUG_DRIVER("get backlight PWM = %d\n", val); +	drm_dbg(&dev_priv->drm, "get backlight PWM = %d\n", val);  	return val;  } @@ -1237,7 +1262,7 @@ static void intel_panel_set_backlight(const struct drm_connector_state *conn_sta  	mutex_lock(&dev_priv->backlight_lock); -	WARN_ON(panel->backlight.max == 0); +	drm_WARN_ON(&dev_priv->drm, panel->backlight.max == 0);  	hw_level = scale_user_to_hw(connector, user_level, user_max);  	panel->backlight.level = hw_level; @@ -1380,7 +1405,8 @@ static u32 cnp_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)  {  	struct drm_i915_private *dev_priv = to_i915(connector->base.dev); -	return DIV_ROUND_CLOSEST(KHz(dev_priv->rawclk_freq), pwm_freq_hz); +	return DIV_ROUND_CLOSEST(KHz(RUNTIME_INFO(dev_priv)->rawclk_freq), +				 pwm_freq_hz);  }  /* @@ -1441,7 +1467,8 @@ static u32 pch_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)  {  	struct drm_i915_private *dev_priv = to_i915(connector->base.dev); -	return DIV_ROUND_CLOSEST(KHz(dev_priv->rawclk_freq), pwm_freq_hz * 128); +	return DIV_ROUND_CLOSEST(KHz(RUNTIME_INFO(dev_priv)->rawclk_freq), +				 pwm_freq_hz * 128);  }  /* @@ -1458,7 +1485,7 @@ static u32 i9xx_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)  	int clock;  	if (IS_PINEVIEW(dev_priv)) -		clock = KHz(dev_priv->rawclk_freq); +		clock = KHz(RUNTIME_INFO(dev_priv)->rawclk_freq);  	else  		clock = KHz(dev_priv->cdclk.hw.cdclk); @@ -1476,7 +1503,7 @@ static u32 i965_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)  	int clock;  	if (IS_G4X(dev_priv)) -		clock = KHz(dev_priv->rawclk_freq); +		clock = KHz(RUNTIME_INFO(dev_priv)->rawclk_freq);  	else  		clock = KHz(dev_priv->cdclk.hw.cdclk); @@ -1493,14 +1520,14 @@ static u32 vlv_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)  	struct drm_i915_private *dev_priv = to_i915(connector->base.dev);  	int mul, clock; -	if ((I915_READ(CBR1_VLV) & CBR_PWM_CLOCK_MUX_SELECT) == 0) { +	if ((intel_de_read(dev_priv, CBR1_VLV) & CBR_PWM_CLOCK_MUX_SELECT) == 0) {  		if (IS_CHERRYVIEW(dev_priv))  			clock = KHz(19200);  		else  			clock = MHz(25);  		mul = 16;  	} else { -		clock = KHz(dev_priv->rawclk_freq); +		clock = KHz(RUNTIME_INFO(dev_priv)->rawclk_freq);  		mul = 128;  	} @@ -1515,22 +1542,26 @@ static u32 get_backlight_max_vbt(struct intel_connector *connector)  	u32 pwm;  	if (!panel->backlight.hz_to_pwm) { -		DRM_DEBUG_KMS("backlight frequency conversion not supported\n"); +		drm_dbg_kms(&dev_priv->drm, +			    "backlight frequency conversion not supported\n");  		return 0;  	}  	if (pwm_freq_hz) { -		DRM_DEBUG_KMS("VBT defined backlight frequency %u Hz\n", -			      pwm_freq_hz); +		drm_dbg_kms(&dev_priv->drm, +			    "VBT defined backlight frequency %u Hz\n", +			    pwm_freq_hz);  	} else {  		pwm_freq_hz = 200; -		DRM_DEBUG_KMS("default backlight frequency %u Hz\n", -			      pwm_freq_hz); +		drm_dbg_kms(&dev_priv->drm, +			    "default backlight frequency %u Hz\n", +			    pwm_freq_hz);  	}  	pwm = panel->backlight.hz_to_pwm(connector, pwm_freq_hz);  	if (!pwm) { -		DRM_DEBUG_KMS("backlight frequency conversion failed\n"); +		drm_dbg_kms(&dev_priv->drm, +			    "backlight frequency conversion failed\n");  		return 0;  	} @@ -1546,7 +1577,7 @@ static u32 get_backlight_min_vbt(struct intel_connector *connector)  	struct intel_panel *panel = &connector->panel;  	int min; -	WARN_ON(panel->backlight.max == 0); +	drm_WARN_ON(&dev_priv->drm, panel->backlight.max == 0);  	/*  	 * XXX: If the vbt value is 255, it makes min equal to max, which leads @@ -1557,8 +1588,9 @@ static u32 get_backlight_min_vbt(struct intel_connector *connector)  	 */  	min = clamp_t(int, dev_priv->vbt.backlight.min_brightness, 0, 64);  	if (min != dev_priv->vbt.backlight.min_brightness) { -		DRM_DEBUG_KMS("clamping VBT min backlight %d/255 to %d/255\n", -			      dev_priv->vbt.backlight.min_brightness, min); +		drm_dbg_kms(&dev_priv->drm, +			    "clamping VBT min backlight %d/255 to %d/255\n", +			    dev_priv->vbt.backlight.min_brightness, min);  	}  	/* vbt value is a coefficient in range [0..255] */ @@ -1573,18 +1605,18 @@ static int lpt_setup_backlight(struct intel_connector *connector, enum pipe unus  	bool alt, cpu_mode;  	if (HAS_PCH_LPT(dev_priv)) -		alt = I915_READ(SOUTH_CHICKEN2) & LPT_PWM_GRANULARITY; +		alt = intel_de_read(dev_priv, SOUTH_CHICKEN2) & LPT_PWM_GRANULARITY;  	else -		alt = I915_READ(SOUTH_CHICKEN1) & SPT_PWM_GRANULARITY; +		alt = intel_de_read(dev_priv, SOUTH_CHICKEN1) & SPT_PWM_GRANULARITY;  	panel->backlight.alternate_pwm_increment = alt; -	pch_ctl1 = I915_READ(BLC_PWM_PCH_CTL1); +	pch_ctl1 = intel_de_read(dev_priv, BLC_PWM_PCH_CTL1);  	panel->backlight.active_low_pwm = pch_ctl1 & BLM_PCH_POLARITY; -	pch_ctl2 = I915_READ(BLC_PWM_PCH_CTL2); +	pch_ctl2 = intel_de_read(dev_priv, BLC_PWM_PCH_CTL2);  	panel->backlight.max = pch_ctl2 >> 16; -	cpu_ctl2 = I915_READ(BLC_PWM_CPU_CTL2); +	cpu_ctl2 = intel_de_read(dev_priv, BLC_PWM_CPU_CTL2);  	if (!panel->backlight.max)  		panel->backlight.max = get_backlight_max_vbt(connector); @@ -1608,13 +1640,16 @@ static int lpt_setup_backlight(struct intel_connector *connector, enum pipe unus  				       panel->backlight.max);  	if (cpu_mode) { -		DRM_DEBUG_KMS("CPU backlight register was enabled, switching to PCH override\n"); +		drm_dbg_kms(&dev_priv->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, panel->backlight.level); -		I915_WRITE(BLC_PWM_PCH_CTL1, pch_ctl1 | BLM_PCH_OVERRIDE_ENABLE); +		intel_de_write(dev_priv, BLC_PWM_PCH_CTL1, +			       pch_ctl1 | BLM_PCH_OVERRIDE_ENABLE); -		I915_WRITE(BLC_PWM_CPU_CTL2, cpu_ctl2 & ~BLM_PWM_ENABLE); +		intel_de_write(dev_priv, BLC_PWM_CPU_CTL2, +			       cpu_ctl2 & ~BLM_PWM_ENABLE);  	}  	return 0; @@ -1626,10 +1661,10 @@ static int pch_setup_backlight(struct intel_connector *connector, enum pipe unus  	struct intel_panel *panel = &connector->panel;  	u32 cpu_ctl2, pch_ctl1, pch_ctl2, val; -	pch_ctl1 = I915_READ(BLC_PWM_PCH_CTL1); +	pch_ctl1 = intel_de_read(dev_priv, BLC_PWM_PCH_CTL1);  	panel->backlight.active_low_pwm = pch_ctl1 & BLM_PCH_POLARITY; -	pch_ctl2 = I915_READ(BLC_PWM_PCH_CTL2); +	pch_ctl2 = intel_de_read(dev_priv, BLC_PWM_PCH_CTL2);  	panel->backlight.max = pch_ctl2 >> 16;  	if (!panel->backlight.max) @@ -1645,7 +1680,7 @@ static int pch_setup_backlight(struct intel_connector *connector, enum pipe unus  	panel->backlight.level = clamp(val, panel->backlight.min,  				       panel->backlight.max); -	cpu_ctl2 = I915_READ(BLC_PWM_CPU_CTL2); +	cpu_ctl2 = intel_de_read(dev_priv, BLC_PWM_CPU_CTL2);  	panel->backlight.enabled = (cpu_ctl2 & BLM_PWM_ENABLE) &&  		(pch_ctl1 & BLM_PCH_PWM_ENABLE); @@ -1658,7 +1693,7 @@ static int i9xx_setup_backlight(struct intel_connector *connector, enum pipe unu  	struct intel_panel *panel = &connector->panel;  	u32 ctl, val; -	ctl = I915_READ(BLC_PWM_CTL); +	ctl = intel_de_read(dev_priv, BLC_PWM_CTL);  	if (IS_GEN(dev_priv, 2) || IS_I915GM(dev_priv) || IS_I945GM(dev_priv))  		panel->backlight.combination_mode = ctl & BLM_LEGACY_MODE; @@ -1697,11 +1732,11 @@ static int i965_setup_backlight(struct intel_connector *connector, enum pipe unu  	struct intel_panel *panel = &connector->panel;  	u32 ctl, ctl2, val; -	ctl2 = I915_READ(BLC_PWM_CTL2); +	ctl2 = intel_de_read(dev_priv, BLC_PWM_CTL2);  	panel->backlight.combination_mode = ctl2 & BLM_COMBINATION_MODE;  	panel->backlight.active_low_pwm = ctl2 & BLM_POLARITY_I965; -	ctl = I915_READ(BLC_PWM_CTL); +	ctl = intel_de_read(dev_priv, BLC_PWM_CTL);  	panel->backlight.max = ctl >> 16;  	if (!panel->backlight.max) @@ -1731,13 +1766,13 @@ static int vlv_setup_backlight(struct intel_connector *connector, enum pipe pipe  	struct intel_panel *panel = &connector->panel;  	u32 ctl, ctl2, val; -	if (WARN_ON(pipe != PIPE_A && pipe != PIPE_B)) +	if (drm_WARN_ON(&dev_priv->drm, pipe != PIPE_A && pipe != PIPE_B))  		return -ENODEV; -	ctl2 = I915_READ(VLV_BLC_PWM_CTL2(pipe)); +	ctl2 = intel_de_read(dev_priv, VLV_BLC_PWM_CTL2(pipe));  	panel->backlight.active_low_pwm = ctl2 & BLM_POLARITY_I965; -	ctl = I915_READ(VLV_BLC_PWM_CTL(pipe)); +	ctl = intel_de_read(dev_priv, VLV_BLC_PWM_CTL(pipe));  	panel->backlight.max = ctl >> 16;  	if (!panel->backlight.max) @@ -1767,18 +1802,20 @@ bxt_setup_backlight(struct intel_connector *connector, enum pipe unused)  	panel->backlight.controller = dev_priv->vbt.backlight.controller; -	pwm_ctl = I915_READ(BXT_BLC_PWM_CTL(panel->backlight.controller)); +	pwm_ctl = intel_de_read(dev_priv, +				BXT_BLC_PWM_CTL(panel->backlight.controller));  	/* Controller 1 uses the utility pin. */  	if (panel->backlight.controller == 1) { -		val = I915_READ(UTIL_PIN_CTL); +		val = intel_de_read(dev_priv, 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.max = -		I915_READ(BXT_BLC_PWM_FREQ(panel->backlight.controller)); +		intel_de_read(dev_priv, +			      BXT_BLC_PWM_FREQ(panel->backlight.controller));  	if (!panel->backlight.max)  		panel->backlight.max = get_backlight_max_vbt(connector); @@ -1812,11 +1849,13 @@ cnp_setup_backlight(struct intel_connector *connector, enum pipe unused)  	 */  	panel->backlight.controller = 0; -	pwm_ctl = I915_READ(BXT_BLC_PWM_CTL(panel->backlight.controller)); +	pwm_ctl = intel_de_read(dev_priv, +				BXT_BLC_PWM_CTL(panel->backlight.controller));  	panel->backlight.active_low_pwm = pwm_ctl & BXT_BLC_PWM_POLARITY;  	panel->backlight.max = -		I915_READ(BXT_BLC_PWM_FREQ(panel->backlight.controller)); +		intel_de_read(dev_priv, +			      BXT_BLC_PWM_FREQ(panel->backlight.controller));  	if (!panel->backlight.max)  		panel->backlight.max = get_backlight_max_vbt(connector); @@ -1843,6 +1882,7 @@ static int pwm_setup_backlight(struct intel_connector *connector,  	struct drm_i915_private *dev_priv = to_i915(dev);  	struct intel_panel *panel = &connector->panel;  	const char *desc; +	u32 level, ns;  	int retval;  	/* Get the right PWM chip for DSI backlight according to VBT */ @@ -1855,7 +1895,8 @@ static int pwm_setup_backlight(struct intel_connector *connector,  	}  	if (IS_ERR(panel->backlight.pwm)) { -		DRM_ERROR("Failed to get the %s PWM chip\n", desc); +		drm_err(&dev_priv->drm, "Failed to get the %s PWM chip\n", +			desc);  		panel->backlight.pwm = NULL;  		return -ENODEV;  	} @@ -1866,23 +1907,27 @@ static int pwm_setup_backlight(struct intel_connector *connector,  	 */  	pwm_apply_args(panel->backlight.pwm); -	retval = pwm_config(panel->backlight.pwm, CRC_PMIC_PWM_PERIOD_NS, -			    CRC_PMIC_PWM_PERIOD_NS); +	panel->backlight.min = 0; /* 0% */ +	panel->backlight.max = 100; /* 100% */ +	level = intel_panel_compute_brightness(connector, 100); +	ns = DIV_ROUND_UP(level * CRC_PMIC_PWM_PERIOD_NS, 100); + +	retval = pwm_config(panel->backlight.pwm, ns, CRC_PMIC_PWM_PERIOD_NS);  	if (retval < 0) { -		DRM_ERROR("Failed to configure the pwm chip\n"); +		drm_err(&dev_priv->drm, "Failed to configure the pwm chip\n");  		pwm_put(panel->backlight.pwm);  		panel->backlight.pwm = NULL;  		return retval;  	} -	panel->backlight.min = 0; /* 0% */ -	panel->backlight.max = 100; /* 100% */ -	panel->backlight.level = DIV_ROUND_UP( -				 pwm_get_duty_cycle(panel->backlight.pwm) * 100, -				 CRC_PMIC_PWM_PERIOD_NS); +	level = DIV_ROUND_UP(pwm_get_duty_cycle(panel->backlight.pwm) * 100, +			     CRC_PMIC_PWM_PERIOD_NS); +	panel->backlight.level = +		intel_panel_compute_brightness(connector, level);  	panel->backlight.enabled = panel->backlight.level != 0; -	DRM_INFO("Using %s PWM for LCD backlight control\n", desc); +	drm_info(&dev_priv->drm, "Using %s PWM for LCD backlight control\n", +		 desc);  	return 0;  } @@ -1913,15 +1958,17 @@ int intel_panel_setup_backlight(struct drm_connector *connector, enum pipe pipe)  	if (!dev_priv->vbt.backlight.present) {  		if (dev_priv->quirks & QUIRK_BACKLIGHT_PRESENT) { -			DRM_DEBUG_KMS("no backlight present per VBT, but present per quirk\n"); +			drm_dbg_kms(&dev_priv->drm, +				    "no backlight present per VBT, but present per quirk\n");  		} else { -			DRM_DEBUG_KMS("no backlight present per VBT\n"); +			drm_dbg_kms(&dev_priv->drm, +				    "no backlight present per VBT\n");  			return 0;  		}  	}  	/* ensure intel_panel has been initialized first */ -	if (WARN_ON(!panel->backlight.setup)) +	if (drm_WARN_ON(&dev_priv->drm, !panel->backlight.setup))  		return -ENODEV;  	/* set level and max in panel struct */ @@ -1930,17 +1977,19 @@ int intel_panel_setup_backlight(struct drm_connector *connector, enum pipe pipe)  	mutex_unlock(&dev_priv->backlight_lock);  	if (ret) { -		DRM_DEBUG_KMS("failed to setup backlight for connector %s\n", -			      connector->name); +		drm_dbg_kms(&dev_priv->drm, +			    "failed to setup backlight for connector %s\n", +			    connector->name);  		return ret;  	}  	panel->backlight.present = true; -	DRM_DEBUG_KMS("Connector %s backlight initialized, %s, brightness %u/%u\n", -		      connector->name, -		      enableddisabled(panel->backlight.enabled), -		      panel->backlight.level, panel->backlight.max); +	drm_dbg_kms(&dev_priv->drm, +		    "Connector %s backlight initialized, %s, brightness %u/%u\n", +		    connector->name, +		    enableddisabled(panel->backlight.enabled), +		    panel->backlight.level, panel->backlight.max);  	return 0;  }  |