mirror of https://gitee.com/openkylin/linux.git
Revert "drm/i915: start adding dp mst audio"
Right now MST audio is causing too many kernel panics to really keep around in the kernel. On top of that, even after fixing said panics it's still basically non-functional (at least on all the setups I've tested it on). Revert until we have a proper solution for this. This reverts commit3d52ccf52f
. Signed-off-by: Lyude <cpaul@redhat.com> Fixes:3d52ccf52f
("drm/i915: start adding dp mst audio") Cc: stable@vger.kernel.org Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch> Link: http://patchwork.freedesktop.org/patch/msgid/1462287692-28570-1-git-send-email-cpaul@redhat.com
This commit is contained in:
parent
3543995a71
commit
5a8f97ea04
|
@ -2910,20 +2910,6 @@ static void intel_dp_info(struct seq_file *m,
|
||||||
intel_panel_info(m, &intel_connector->panel);
|
intel_panel_info(m, &intel_connector->panel);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void intel_dp_mst_info(struct seq_file *m,
|
|
||||||
struct intel_connector *intel_connector)
|
|
||||||
{
|
|
||||||
struct intel_encoder *intel_encoder = intel_connector->encoder;
|
|
||||||
struct intel_dp_mst_encoder *intel_mst =
|
|
||||||
enc_to_mst(&intel_encoder->base);
|
|
||||||
struct intel_digital_port *intel_dig_port = intel_mst->primary;
|
|
||||||
struct intel_dp *intel_dp = &intel_dig_port->dp;
|
|
||||||
bool has_audio = drm_dp_mst_port_has_audio(&intel_dp->mst_mgr,
|
|
||||||
intel_connector->port);
|
|
||||||
|
|
||||||
seq_printf(m, "\taudio support: %s\n", yesno(has_audio));
|
|
||||||
}
|
|
||||||
|
|
||||||
static void intel_hdmi_info(struct seq_file *m,
|
static void intel_hdmi_info(struct seq_file *m,
|
||||||
struct intel_connector *intel_connector)
|
struct intel_connector *intel_connector)
|
||||||
{
|
{
|
||||||
|
@ -2967,8 +2953,6 @@ static void intel_connector_info(struct seq_file *m,
|
||||||
intel_hdmi_info(m, intel_connector);
|
intel_hdmi_info(m, intel_connector);
|
||||||
else if (intel_encoder->type == INTEL_OUTPUT_LVDS)
|
else if (intel_encoder->type == INTEL_OUTPUT_LVDS)
|
||||||
intel_lvds_info(m, intel_connector);
|
intel_lvds_info(m, intel_connector);
|
||||||
else if (intel_encoder->type == INTEL_OUTPUT_DP_MST)
|
|
||||||
intel_dp_mst_info(m, intel_connector);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
seq_printf(m, "\tmodes:\n");
|
seq_printf(m, "\tmodes:\n");
|
||||||
|
|
|
@ -262,8 +262,7 @@ static void hsw_audio_codec_disable(struct intel_encoder *encoder)
|
||||||
tmp |= AUD_CONFIG_N_PROG_ENABLE;
|
tmp |= AUD_CONFIG_N_PROG_ENABLE;
|
||||||
tmp &= ~AUD_CONFIG_UPPER_N_MASK;
|
tmp &= ~AUD_CONFIG_UPPER_N_MASK;
|
||||||
tmp &= ~AUD_CONFIG_LOWER_N_MASK;
|
tmp &= ~AUD_CONFIG_LOWER_N_MASK;
|
||||||
if (intel_pipe_has_type(intel_crtc, INTEL_OUTPUT_DISPLAYPORT) ||
|
if (intel_pipe_has_type(intel_crtc, INTEL_OUTPUT_DISPLAYPORT))
|
||||||
intel_pipe_has_type(intel_crtc, INTEL_OUTPUT_DP_MST))
|
|
||||||
tmp |= AUD_CONFIG_N_VALUE_INDEX;
|
tmp |= AUD_CONFIG_N_VALUE_INDEX;
|
||||||
I915_WRITE(HSW_AUD_CFG(pipe), tmp);
|
I915_WRITE(HSW_AUD_CFG(pipe), tmp);
|
||||||
|
|
||||||
|
@ -476,8 +475,7 @@ static void ilk_audio_codec_enable(struct drm_connector *connector,
|
||||||
tmp &= ~AUD_CONFIG_N_VALUE_INDEX;
|
tmp &= ~AUD_CONFIG_N_VALUE_INDEX;
|
||||||
tmp &= ~AUD_CONFIG_N_PROG_ENABLE;
|
tmp &= ~AUD_CONFIG_N_PROG_ENABLE;
|
||||||
tmp &= ~AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK;
|
tmp &= ~AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK;
|
||||||
if (intel_pipe_has_type(intel_crtc, INTEL_OUTPUT_DISPLAYPORT) ||
|
if (intel_pipe_has_type(intel_crtc, INTEL_OUTPUT_DISPLAYPORT))
|
||||||
intel_pipe_has_type(intel_crtc, INTEL_OUTPUT_DP_MST))
|
|
||||||
tmp |= AUD_CONFIG_N_VALUE_INDEX;
|
tmp |= AUD_CONFIG_N_VALUE_INDEX;
|
||||||
else
|
else
|
||||||
tmp |= audio_config_hdmi_pixel_clock(adjusted_mode);
|
tmp |= audio_config_hdmi_pixel_clock(adjusted_mode);
|
||||||
|
@ -515,8 +513,7 @@ void intel_audio_codec_enable(struct intel_encoder *intel_encoder)
|
||||||
|
|
||||||
/* ELD Conn_Type */
|
/* ELD Conn_Type */
|
||||||
connector->eld[5] &= ~(3 << 2);
|
connector->eld[5] &= ~(3 << 2);
|
||||||
if (intel_pipe_has_type(crtc, INTEL_OUTPUT_DISPLAYPORT) ||
|
if (intel_pipe_has_type(crtc, INTEL_OUTPUT_DISPLAYPORT))
|
||||||
intel_pipe_has_type(crtc, INTEL_OUTPUT_DP_MST))
|
|
||||||
connector->eld[5] |= (1 << 2);
|
connector->eld[5] |= (1 << 2);
|
||||||
|
|
||||||
connector->eld[6] = drm_av_sync_delay(connector, adjusted_mode) / 2;
|
connector->eld[6] = drm_av_sync_delay(connector, adjusted_mode) / 2;
|
||||||
|
|
|
@ -2131,23 +2131,6 @@ void intel_ddi_fdi_disable(struct drm_crtc *crtc)
|
||||||
I915_WRITE(FDI_RX_CTL(PIPE_A), val);
|
I915_WRITE(FDI_RX_CTL(PIPE_A), val);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool intel_ddi_is_audio_enabled(struct drm_i915_private *dev_priv,
|
|
||||||
struct intel_crtc *intel_crtc)
|
|
||||||
{
|
|
||||||
u32 temp;
|
|
||||||
|
|
||||||
if (intel_display_power_get_if_enabled(dev_priv, POWER_DOMAIN_AUDIO)) {
|
|
||||||
temp = I915_READ(HSW_AUD_PIN_ELD_CP_VLD);
|
|
||||||
|
|
||||||
intel_display_power_put(dev_priv, POWER_DOMAIN_AUDIO);
|
|
||||||
|
|
||||||
if (temp & AUDIO_OUTPUT_ENABLE(intel_crtc->pipe))
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
void intel_ddi_get_config(struct intel_encoder *encoder,
|
void intel_ddi_get_config(struct intel_encoder *encoder,
|
||||||
struct intel_crtc_state *pipe_config)
|
struct intel_crtc_state *pipe_config)
|
||||||
{
|
{
|
||||||
|
@ -2214,8 +2197,11 @@ void intel_ddi_get_config(struct intel_encoder *encoder,
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
pipe_config->has_audio =
|
if (intel_display_power_is_enabled(dev_priv, POWER_DOMAIN_AUDIO)) {
|
||||||
intel_ddi_is_audio_enabled(dev_priv, intel_crtc);
|
temp = I915_READ(HSW_AUD_PIN_ELD_CP_VLD);
|
||||||
|
if (temp & AUDIO_OUTPUT_ENABLE(intel_crtc->pipe))
|
||||||
|
pipe_config->has_audio = true;
|
||||||
|
}
|
||||||
|
|
||||||
if (encoder->type == INTEL_OUTPUT_EDP && dev_priv->vbt.edp.bpp &&
|
if (encoder->type == INTEL_OUTPUT_EDP && dev_priv->vbt.edp.bpp &&
|
||||||
pipe_config->pipe_bpp > dev_priv->vbt.edp.bpp) {
|
pipe_config->pipe_bpp > dev_priv->vbt.edp.bpp) {
|
||||||
|
|
|
@ -77,8 +77,6 @@ static bool intel_dp_mst_compute_config(struct intel_encoder *encoder,
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (drm_dp_mst_port_has_audio(&intel_dp->mst_mgr, found->port))
|
|
||||||
pipe_config->has_audio = true;
|
|
||||||
mst_pbn = drm_dp_calc_pbn_mode(adjusted_mode->crtc_clock, bpp);
|
mst_pbn = drm_dp_calc_pbn_mode(adjusted_mode->crtc_clock, bpp);
|
||||||
|
|
||||||
pipe_config->pbn = mst_pbn;
|
pipe_config->pbn = mst_pbn;
|
||||||
|
@ -100,11 +98,6 @@ static void intel_mst_disable_dp(struct intel_encoder *encoder)
|
||||||
struct intel_dp_mst_encoder *intel_mst = enc_to_mst(&encoder->base);
|
struct intel_dp_mst_encoder *intel_mst = enc_to_mst(&encoder->base);
|
||||||
struct intel_digital_port *intel_dig_port = intel_mst->primary;
|
struct intel_digital_port *intel_dig_port = intel_mst->primary;
|
||||||
struct intel_dp *intel_dp = &intel_dig_port->dp;
|
struct intel_dp *intel_dp = &intel_dig_port->dp;
|
||||||
struct drm_device *dev = encoder->base.dev;
|
|
||||||
struct drm_i915_private *dev_priv = dev->dev_private;
|
|
||||||
struct drm_crtc *crtc = encoder->base.crtc;
|
|
||||||
struct intel_crtc *intel_crtc = to_intel_crtc(crtc);
|
|
||||||
|
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
DRM_DEBUG_KMS("%d\n", intel_dp->active_mst_links);
|
DRM_DEBUG_KMS("%d\n", intel_dp->active_mst_links);
|
||||||
|
@ -115,10 +108,6 @@ static void intel_mst_disable_dp(struct intel_encoder *encoder)
|
||||||
if (ret) {
|
if (ret) {
|
||||||
DRM_ERROR("failed to update payload %d\n", ret);
|
DRM_ERROR("failed to update payload %d\n", ret);
|
||||||
}
|
}
|
||||||
if (intel_crtc->config->has_audio) {
|
|
||||||
intel_audio_codec_disable(encoder);
|
|
||||||
intel_display_power_put(dev_priv, POWER_DOMAIN_AUDIO);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void intel_mst_post_disable_dp(struct intel_encoder *encoder)
|
static void intel_mst_post_disable_dp(struct intel_encoder *encoder)
|
||||||
|
@ -217,7 +206,6 @@ static void intel_mst_enable_dp(struct intel_encoder *encoder)
|
||||||
struct intel_dp *intel_dp = &intel_dig_port->dp;
|
struct intel_dp *intel_dp = &intel_dig_port->dp;
|
||||||
struct drm_device *dev = intel_dig_port->base.base.dev;
|
struct drm_device *dev = intel_dig_port->base.base.dev;
|
||||||
struct drm_i915_private *dev_priv = dev->dev_private;
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
||||||
struct intel_crtc *crtc = to_intel_crtc(encoder->base.crtc);
|
|
||||||
enum port port = intel_dig_port->port;
|
enum port port = intel_dig_port->port;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
@ -230,13 +218,6 @@ static void intel_mst_enable_dp(struct intel_encoder *encoder)
|
||||||
ret = drm_dp_check_act_status(&intel_dp->mst_mgr);
|
ret = drm_dp_check_act_status(&intel_dp->mst_mgr);
|
||||||
|
|
||||||
ret = drm_dp_update_payload_part2(&intel_dp->mst_mgr);
|
ret = drm_dp_update_payload_part2(&intel_dp->mst_mgr);
|
||||||
|
|
||||||
if (crtc->config->has_audio) {
|
|
||||||
DRM_DEBUG_DRIVER("Enabling DP audio on pipe %c\n",
|
|
||||||
pipe_name(crtc->pipe));
|
|
||||||
intel_display_power_get(dev_priv, POWER_DOMAIN_AUDIO);
|
|
||||||
intel_audio_codec_enable(encoder);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool intel_dp_mst_enc_get_hw_state(struct intel_encoder *encoder,
|
static bool intel_dp_mst_enc_get_hw_state(struct intel_encoder *encoder,
|
||||||
|
@ -262,9 +243,6 @@ static void intel_dp_mst_enc_get_config(struct intel_encoder *encoder,
|
||||||
|
|
||||||
pipe_config->has_dp_encoder = true;
|
pipe_config->has_dp_encoder = true;
|
||||||
|
|
||||||
pipe_config->has_audio =
|
|
||||||
intel_ddi_is_audio_enabled(dev_priv, crtc);
|
|
||||||
|
|
||||||
temp = I915_READ(TRANS_DDI_FUNC_CTL(cpu_transcoder));
|
temp = I915_READ(TRANS_DDI_FUNC_CTL(cpu_transcoder));
|
||||||
if (temp & TRANS_DDI_PHSYNC)
|
if (temp & TRANS_DDI_PHSYNC)
|
||||||
flags |= DRM_MODE_FLAG_PHSYNC;
|
flags |= DRM_MODE_FLAG_PHSYNC;
|
||||||
|
|
|
@ -1071,8 +1071,6 @@ void intel_ddi_set_pipe_settings(struct drm_crtc *crtc);
|
||||||
void intel_ddi_prepare_link_retrain(struct intel_dp *intel_dp);
|
void intel_ddi_prepare_link_retrain(struct intel_dp *intel_dp);
|
||||||
bool intel_ddi_connector_get_hw_state(struct intel_connector *intel_connector);
|
bool intel_ddi_connector_get_hw_state(struct intel_connector *intel_connector);
|
||||||
void intel_ddi_fdi_disable(struct drm_crtc *crtc);
|
void intel_ddi_fdi_disable(struct drm_crtc *crtc);
|
||||||
bool intel_ddi_is_audio_enabled(struct drm_i915_private *dev_priv,
|
|
||||||
struct intel_crtc *intel_crtc);
|
|
||||||
void intel_ddi_get_config(struct intel_encoder *encoder,
|
void intel_ddi_get_config(struct intel_encoder *encoder,
|
||||||
struct intel_crtc_state *pipe_config);
|
struct intel_crtc_state *pipe_config);
|
||||||
struct intel_encoder *
|
struct intel_encoder *
|
||||||
|
|
Loading…
Reference in New Issue