diff options
author | Dave Airlie <airlied@redhat.com> | 2014-05-01 23:36:43 -0400 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2014-07-21 02:48:53 -0400 |
commit | 44905a27dd01f2bddd96664d0ab7da43a07f4d5a (patch) | |
tree | 2c2df67cfd75b4273115bb49d32bd070de04a367 | |
parent | 01b887c36e12845bb9162e65504de623f1a17f10 (diff) |
i915: split some DP modesetting code into a separate function
this is just prep work for mst support.
Reviewed-by: Todd Previte <tprevite@gmail.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
-rw-r--r-- | drivers/gpu/drm/i915/intel_ddi.c | 18 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/intel_drv.h | 1 |
2 files changed, 14 insertions, 5 deletions
diff --git a/drivers/gpu/drm/i915/intel_ddi.c b/drivers/gpu/drm/i915/intel_ddi.c index b2267249c1c0..1aec4257e296 100644 --- a/drivers/gpu/drm/i915/intel_ddi.c +++ b/drivers/gpu/drm/i915/intel_ddi.c | |||
@@ -365,6 +365,18 @@ void hsw_fdi_link_train(struct drm_crtc *crtc) | |||
365 | DRM_ERROR("FDI link training failed!\n"); | 365 | DRM_ERROR("FDI link training failed!\n"); |
366 | } | 366 | } |
367 | 367 | ||
368 | void intel_ddi_init_dp_buf_reg(struct intel_encoder *encoder) | ||
369 | { | ||
370 | struct intel_dp *intel_dp = enc_to_intel_dp(&encoder->base); | ||
371 | struct intel_digital_port *intel_dig_port = | ||
372 | enc_to_dig_port(&encoder->base); | ||
373 | |||
374 | intel_dp->DP = intel_dig_port->saved_port_bits | | ||
375 | DDI_BUF_CTL_ENABLE | DDI_BUF_EMP_400MV_0DB_HSW; | ||
376 | intel_dp->DP |= DDI_PORT_WIDTH(intel_dp->lane_count); | ||
377 | |||
378 | } | ||
379 | |||
368 | static struct intel_encoder * | 380 | static struct intel_encoder * |
369 | intel_ddi_get_crtc_encoder(struct drm_crtc *crtc) | 381 | intel_ddi_get_crtc_encoder(struct drm_crtc *crtc) |
370 | { | 382 | { |
@@ -1015,12 +1027,8 @@ static void intel_ddi_pre_enable(struct intel_encoder *intel_encoder) | |||
1015 | 1027 | ||
1016 | if (type == INTEL_OUTPUT_DISPLAYPORT || type == INTEL_OUTPUT_EDP) { | 1028 | if (type == INTEL_OUTPUT_DISPLAYPORT || type == INTEL_OUTPUT_EDP) { |
1017 | struct intel_dp *intel_dp = enc_to_intel_dp(encoder); | 1029 | struct intel_dp *intel_dp = enc_to_intel_dp(encoder); |
1018 | struct intel_digital_port *intel_dig_port = | ||
1019 | enc_to_dig_port(encoder); | ||
1020 | 1030 | ||
1021 | intel_dp->DP = intel_dig_port->saved_port_bits | | 1031 | intel_ddi_init_dp_buf_reg(intel_encoder); |
1022 | DDI_BUF_CTL_ENABLE | DDI_BUF_EMP_400MV_0DB_HSW; | ||
1023 | intel_dp->DP |= DDI_PORT_WIDTH(intel_dp->lane_count); | ||
1024 | 1032 | ||
1025 | intel_dp_sink_dpms(intel_dp, DRM_MODE_DPMS_ON); | 1033 | intel_dp_sink_dpms(intel_dp, DRM_MODE_DPMS_ON); |
1026 | intel_dp_start_link_train(intel_dp); | 1034 | intel_dp_start_link_train(intel_dp); |
diff --git a/drivers/gpu/drm/i915/intel_drv.h b/drivers/gpu/drm/i915/intel_drv.h index fa19744ed6c0..40086e1a4ee3 100644 --- a/drivers/gpu/drm/i915/intel_drv.h +++ b/drivers/gpu/drm/i915/intel_drv.h | |||
@@ -718,6 +718,7 @@ void intel_ddi_fdi_disable(struct drm_crtc *crtc); | |||
718 | void intel_ddi_get_config(struct intel_encoder *encoder, | 718 | void intel_ddi_get_config(struct intel_encoder *encoder, |
719 | struct intel_crtc_config *pipe_config); | 719 | struct intel_crtc_config *pipe_config); |
720 | 720 | ||
721 | void intel_ddi_init_dp_buf_reg(struct intel_encoder *encoder); | ||
721 | 722 | ||
722 | /* intel_display.c */ | 723 | /* intel_display.c */ |
723 | const char *intel_output_name(int output); | 724 | const char *intel_output_name(int output); |