aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915/intel_dp.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/gpu/drm/i915/intel_dp.c')
-rw-r--r--drivers/gpu/drm/i915/intel_dp.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/drivers/gpu/drm/i915/intel_dp.c b/drivers/gpu/drm/i915/intel_dp.c
index 3fa56f38f929..a14ee4be5d69 100644
--- a/drivers/gpu/drm/i915/intel_dp.c
+++ b/drivers/gpu/drm/i915/intel_dp.c
@@ -925,7 +925,7 @@ static void ironlake_set_pll_cpu_edp(struct intel_dp *intel_dp)
925 udelay(500); 925 udelay(500);
926} 926}
927 927
928static void intel_dp_mode_set(struct intel_encoder *encoder) 928static void intel_dp_prepare(struct intel_encoder *encoder)
929{ 929{
930 struct drm_device *dev = encoder->base.dev; 930 struct drm_device *dev = encoder->base.dev;
931 struct drm_i915_private *dev_priv = dev->dev_private; 931 struct drm_i915_private *dev_priv = dev->dev_private;
@@ -1902,6 +1902,8 @@ static void g4x_pre_enable_dp(struct intel_encoder *encoder)
1902 struct intel_dp *intel_dp = enc_to_intel_dp(&encoder->base); 1902 struct intel_dp *intel_dp = enc_to_intel_dp(&encoder->base);
1903 struct intel_digital_port *dport = dp_to_dig_port(intel_dp); 1903 struct intel_digital_port *dport = dp_to_dig_port(intel_dp);
1904 1904
1905 intel_dp_prepare(encoder);
1906
1905 /* Only ilk+ has port A */ 1907 /* Only ilk+ has port A */
1906 if (dport->port == PORT_A) { 1908 if (dport->port == PORT_A) {
1907 ironlake_set_pll_cpu_edp(intel_dp); 1909 ironlake_set_pll_cpu_edp(intel_dp);
@@ -1958,6 +1960,8 @@ static void vlv_dp_pre_pll_enable(struct intel_encoder *encoder)
1958 enum dpio_channel port = vlv_dport_to_channel(dport); 1960 enum dpio_channel port = vlv_dport_to_channel(dport);
1959 int pipe = intel_crtc->pipe; 1961 int pipe = intel_crtc->pipe;
1960 1962
1963 intel_dp_prepare(encoder);
1964
1961 /* Program Tx lane resets to default */ 1965 /* Program Tx lane resets to default */
1962 mutex_lock(&dev_priv->dpio_lock); 1966 mutex_lock(&dev_priv->dpio_lock);
1963 vlv_dpio_write(dev_priv, pipe, VLV_PCS_DW0(port), 1967 vlv_dpio_write(dev_priv, pipe, VLV_PCS_DW0(port),
@@ -4224,7 +4228,6 @@ intel_dp_init(struct drm_device *dev, int output_reg, enum port port)
4224 DRM_MODE_ENCODER_TMDS); 4228 DRM_MODE_ENCODER_TMDS);
4225 4229
4226 intel_encoder->compute_config = intel_dp_compute_config; 4230 intel_encoder->compute_config = intel_dp_compute_config;
4227 intel_encoder->mode_set = intel_dp_mode_set;
4228 intel_encoder->disable = intel_disable_dp; 4231 intel_encoder->disable = intel_disable_dp;
4229 intel_encoder->get_hw_state = intel_dp_get_hw_state; 4232 intel_encoder->get_hw_state = intel_dp_get_hw_state;
4230 intel_encoder->get_config = intel_dp_get_config; 4233 intel_encoder->get_config = intel_dp_get_config;