|
@@ -676,7 +676,7 @@ intel_dp_i2c_aux_ch(struct i2c_adapter *adapter, int mode,
|
|
|
int reply_bytes;
|
|
|
int ret;
|
|
|
|
|
|
- edp_panel_vdd_on(intel_dp);
|
|
|
+ intel_edp_panel_vdd_on(intel_dp);
|
|
|
intel_dp_check_edp(intel_dp);
|
|
|
/* Set up the command byte */
|
|
|
if (mode & MODE_I2C_READ)
|
|
@@ -1161,7 +1161,7 @@ static u32 ironlake_get_pp_control(struct intel_dp *intel_dp)
|
|
|
return control;
|
|
|
}
|
|
|
|
|
|
-void edp_panel_vdd_on(struct intel_dp *intel_dp)
|
|
|
+void intel_edp_panel_vdd_on(struct intel_dp *intel_dp)
|
|
|
{
|
|
|
struct drm_device *dev = intel_dp_to_dev(intel_dp);
|
|
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
|
@@ -1329,6 +1329,8 @@ void intel_edp_panel_off(struct intel_dp *intel_dp)
|
|
|
|
|
|
edp_wait_backlight_off(intel_dp);
|
|
|
|
|
|
+ WARN(!intel_dp->want_panel_vdd, "Need VDD to turn off panel\n");
|
|
|
+
|
|
|
pp = ironlake_get_pp_control(intel_dp);
|
|
|
/* We need to switch off panel power _and_ force vdd, for otherwise some
|
|
|
* panels get very unhappy and cease to work. */
|
|
@@ -1880,7 +1882,7 @@ static void intel_disable_dp(struct intel_encoder *encoder)
|
|
|
|
|
|
/* Make sure the panel is off before trying to change the mode. But also
|
|
|
* ensure that we have vdd while we switch off the panel. */
|
|
|
- edp_panel_vdd_on(intel_dp);
|
|
|
+ intel_edp_panel_vdd_on(intel_dp);
|
|
|
intel_edp_backlight_off(intel_dp);
|
|
|
intel_dp_sink_dpms(intel_dp, DRM_MODE_DPMS_OFF);
|
|
|
intel_edp_panel_off(intel_dp);
|
|
@@ -1913,7 +1915,7 @@ static void intel_enable_dp(struct intel_encoder *encoder)
|
|
|
if (WARN_ON(dp_reg & DP_PORT_EN))
|
|
|
return;
|
|
|
|
|
|
- edp_panel_vdd_on(intel_dp);
|
|
|
+ intel_edp_panel_vdd_on(intel_dp);
|
|
|
intel_dp_sink_dpms(intel_dp, DRM_MODE_DPMS_ON);
|
|
|
intel_dp_start_link_train(intel_dp);
|
|
|
intel_edp_panel_on(intel_dp);
|
|
@@ -2951,7 +2953,7 @@ intel_dp_probe_oui(struct intel_dp *intel_dp)
|
|
|
if (!(intel_dp->dpcd[DP_DOWN_STREAM_PORT_COUNT] & DP_OUI_SUPPORT))
|
|
|
return;
|
|
|
|
|
|
- edp_panel_vdd_on(intel_dp);
|
|
|
+ intel_edp_panel_vdd_on(intel_dp);
|
|
|
|
|
|
if (intel_dp_aux_native_read_retry(intel_dp, DP_SINK_OUI, buf, 3))
|
|
|
DRM_DEBUG_KMS("Sink OUI: %02hx%02hx%02hx\n",
|
|
@@ -3748,7 +3750,7 @@ static bool intel_edp_init_connector(struct intel_dp *intel_dp,
|
|
|
return true;
|
|
|
|
|
|
/* Cache DPCD and EDID for edp. */
|
|
|
- edp_panel_vdd_on(intel_dp);
|
|
|
+ intel_edp_panel_vdd_on(intel_dp);
|
|
|
has_dpcd = intel_dp_get_dpcd(intel_dp);
|
|
|
edp_panel_vdd_off(intel_dp, false);
|
|
|
|