diff options
author | Libin Yang <libin.yang@linux.intel.com> | 2015-12-02 01:09:44 -0500 |
---|---|---|
committer | Daniel Vetter <daniel.vetter@ffwll.ch> | 2015-12-10 04:00:46 -0500 |
commit | 3d52ccf52f2c51f613e42e65be0f06e4e6788093 (patch) | |
tree | f76a7bd592fe4acd4a2cfdd5f5d0ec9cfd1acc2b /drivers/gpu/drm/i915/intel_dp_mst.c | |
parent | ef8f9bea1368b89d0d6d1819025586ae0bea0612 (diff) |
drm/i915: start adding dp mst audio
This patch adds support for DP MST audio in i915.
Enable audio codec when DP MST is enabled if has_audio flag is set.
Disable audio codec when DP MST is disabled if has_audio flag is set.
Another separated patches to support DP MST audio will be implemented
in audio driver.
Reviewed-by: Ander Conselvan de Oliveira <conselvan2@gmail.com>
Signed-off-by: Libin Yang <libin.yang@linux.intel.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Link: http://patchwork.freedesktop.org/patch/msgid/1449036584-105393-2-git-send-email-libin.yang@linux.intel.com
Diffstat (limited to 'drivers/gpu/drm/i915/intel_dp_mst.c')
-rw-r--r-- | drivers/gpu/drm/i915/intel_dp_mst.c | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/drivers/gpu/drm/i915/intel_dp_mst.c b/drivers/gpu/drm/i915/intel_dp_mst.c index 8c4e7dfe304c..8b608c2cd070 100644 --- a/drivers/gpu/drm/i915/intel_dp_mst.c +++ b/drivers/gpu/drm/i915/intel_dp_mst.c | |||
@@ -78,6 +78,8 @@ static bool intel_dp_mst_compute_config(struct intel_encoder *encoder, | |||
78 | return false; | 78 | return false; |
79 | } | 79 | } |
80 | 80 | ||
81 | if (drm_dp_mst_port_has_audio(&intel_dp->mst_mgr, found->port)) | ||
82 | pipe_config->has_audio = true; | ||
81 | mst_pbn = drm_dp_calc_pbn_mode(adjusted_mode->crtc_clock, bpp); | 83 | mst_pbn = drm_dp_calc_pbn_mode(adjusted_mode->crtc_clock, bpp); |
82 | 84 | ||
83 | pipe_config->pbn = mst_pbn; | 85 | pipe_config->pbn = mst_pbn; |
@@ -102,6 +104,11 @@ static void intel_mst_disable_dp(struct intel_encoder *encoder) | |||
102 | struct intel_dp_mst_encoder *intel_mst = enc_to_mst(&encoder->base); | 104 | struct intel_dp_mst_encoder *intel_mst = enc_to_mst(&encoder->base); |
103 | struct intel_digital_port *intel_dig_port = intel_mst->primary; | 105 | struct intel_digital_port *intel_dig_port = intel_mst->primary; |
104 | struct intel_dp *intel_dp = &intel_dig_port->dp; | 106 | struct intel_dp *intel_dp = &intel_dig_port->dp; |
107 | struct drm_device *dev = encoder->base.dev; | ||
108 | struct drm_i915_private *dev_priv = dev->dev_private; | ||
109 | struct drm_crtc *crtc = encoder->base.crtc; | ||
110 | struct intel_crtc *intel_crtc = to_intel_crtc(crtc); | ||
111 | |||
105 | int ret; | 112 | int ret; |
106 | 113 | ||
107 | DRM_DEBUG_KMS("%d\n", intel_dp->active_mst_links); | 114 | DRM_DEBUG_KMS("%d\n", intel_dp->active_mst_links); |
@@ -112,6 +119,10 @@ static void intel_mst_disable_dp(struct intel_encoder *encoder) | |||
112 | if (ret) { | 119 | if (ret) { |
113 | DRM_ERROR("failed to update payload %d\n", ret); | 120 | DRM_ERROR("failed to update payload %d\n", ret); |
114 | } | 121 | } |
122 | if (intel_crtc->config->has_audio) { | ||
123 | intel_audio_codec_disable(encoder); | ||
124 | intel_display_power_put(dev_priv, POWER_DOMAIN_AUDIO); | ||
125 | } | ||
115 | } | 126 | } |
116 | 127 | ||
117 | static void intel_mst_post_disable_dp(struct intel_encoder *encoder) | 128 | static void intel_mst_post_disable_dp(struct intel_encoder *encoder) |
@@ -208,6 +219,7 @@ static void intel_mst_enable_dp(struct intel_encoder *encoder) | |||
208 | struct intel_dp *intel_dp = &intel_dig_port->dp; | 219 | struct intel_dp *intel_dp = &intel_dig_port->dp; |
209 | struct drm_device *dev = intel_dig_port->base.base.dev; | 220 | struct drm_device *dev = intel_dig_port->base.base.dev; |
210 | struct drm_i915_private *dev_priv = dev->dev_private; | 221 | struct drm_i915_private *dev_priv = dev->dev_private; |
222 | struct intel_crtc *crtc = to_intel_crtc(encoder->base.crtc); | ||
211 | enum port port = intel_dig_port->port; | 223 | enum port port = intel_dig_port->port; |
212 | int ret; | 224 | int ret; |
213 | 225 | ||
@@ -220,6 +232,13 @@ static void intel_mst_enable_dp(struct intel_encoder *encoder) | |||
220 | ret = drm_dp_check_act_status(&intel_dp->mst_mgr); | 232 | ret = drm_dp_check_act_status(&intel_dp->mst_mgr); |
221 | 233 | ||
222 | ret = drm_dp_update_payload_part2(&intel_dp->mst_mgr); | 234 | ret = drm_dp_update_payload_part2(&intel_dp->mst_mgr); |
235 | |||
236 | if (crtc->config->has_audio) { | ||
237 | DRM_DEBUG_DRIVER("Enabling DP audio on pipe %c\n", | ||
238 | pipe_name(crtc->pipe)); | ||
239 | intel_display_power_get(dev_priv, POWER_DOMAIN_AUDIO); | ||
240 | intel_audio_codec_enable(encoder); | ||
241 | } | ||
223 | } | 242 | } |
224 | 243 | ||
225 | static bool intel_dp_mst_enc_get_hw_state(struct intel_encoder *encoder, | 244 | static bool intel_dp_mst_enc_get_hw_state(struct intel_encoder *encoder, |
@@ -245,6 +264,9 @@ static void intel_dp_mst_enc_get_config(struct intel_encoder *encoder, | |||
245 | 264 | ||
246 | pipe_config->has_dp_encoder = true; | 265 | pipe_config->has_dp_encoder = true; |
247 | 266 | ||
267 | pipe_config->has_audio = | ||
268 | intel_ddi_is_audio_enabled(dev_priv, crtc); | ||
269 | |||
248 | temp = I915_READ(TRANS_DDI_FUNC_CTL(cpu_transcoder)); | 270 | temp = I915_READ(TRANS_DDI_FUNC_CTL(cpu_transcoder)); |
249 | if (temp & TRANS_DDI_PHSYNC) | 271 | if (temp & TRANS_DDI_PHSYNC) |
250 | flags |= DRM_MODE_FLAG_PHSYNC; | 272 | flags |= DRM_MODE_FLAG_PHSYNC; |