Commit e6b72c94 authored by Maarten Lankhorst's avatar Maarten Lankhorst

drm/i915: Make intel_dp->has_audio reflect hw state only

Always detect if audio is available during edid detection.
With less magic switching it's easier to convert the dp connector
properties to atomic.
Signed-off-by: default avatarMaarten Lankhorst <maarten.lankhorst@linux.intel.com>
Reviewed-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
Link: http://patchwork.freedesktop.org/patch/msgid/20170501133804.8116-9-maarten.lankhorst@linux.intel.com
parent ca937582
...@@ -1671,7 +1671,12 @@ intel_dp_compute_config(struct intel_encoder *encoder, ...@@ -1671,7 +1671,12 @@ intel_dp_compute_config(struct intel_encoder *encoder,
pipe_config->has_pch_encoder = true; pipe_config->has_pch_encoder = true;
pipe_config->has_drrs = false; pipe_config->has_drrs = false;
pipe_config->has_audio = intel_dp->has_audio && port != PORT_A; if (port == PORT_A)
pipe_config->has_audio = false;
else if (intel_dp->force_audio == HDMI_AUDIO_AUTO)
pipe_config->has_audio = intel_dp->has_audio;
else
pipe_config->has_audio = intel_dp->force_audio == HDMI_AUDIO_ON;
if (is_edp(intel_dp) && intel_connector->panel.fixed_mode) { if (is_edp(intel_dp) && intel_connector->panel.fixed_mode) {
intel_fixed_panel_mode(intel_connector->panel.fixed_mode, intel_fixed_panel_mode(intel_connector->panel.fixed_mode,
...@@ -4602,9 +4607,6 @@ intel_dp_set_edid(struct intel_dp *intel_dp) ...@@ -4602,9 +4607,6 @@ intel_dp_set_edid(struct intel_dp *intel_dp)
edid = intel_dp_get_edid(intel_dp); edid = intel_dp_get_edid(intel_dp);
intel_connector->detect_edid = edid; intel_connector->detect_edid = edid;
if (intel_dp->force_audio != HDMI_AUDIO_AUTO)
intel_dp->has_audio = intel_dp->force_audio == HDMI_AUDIO_ON;
else
intel_dp->has_audio = drm_detect_monitor_audio(edid); intel_dp->has_audio = drm_detect_monitor_audio(edid);
} }
...@@ -4813,19 +4815,6 @@ static int intel_dp_get_modes(struct drm_connector *connector) ...@@ -4813,19 +4815,6 @@ static int intel_dp_get_modes(struct drm_connector *connector)
return 0; return 0;
} }
static bool
intel_dp_detect_audio(struct drm_connector *connector)
{
bool has_audio = false;
struct edid *edid;
edid = to_intel_connector(connector)->detect_edid;
if (edid)
has_audio = drm_detect_monitor_audio(edid);
return has_audio;
}
static int static int
intel_dp_set_property(struct drm_connector *connector, intel_dp_set_property(struct drm_connector *connector,
struct drm_property *property, struct drm_property *property,
...@@ -4842,22 +4831,27 @@ intel_dp_set_property(struct drm_connector *connector, ...@@ -4842,22 +4831,27 @@ intel_dp_set_property(struct drm_connector *connector,
if (property == dev_priv->force_audio_property) { if (property == dev_priv->force_audio_property) {
int i = val; int i = val;
bool has_audio; bool has_audio, old_has_audio;
int old_force_audio = intel_dp->force_audio;
if (i == intel_dp->force_audio) if (i == intel_dp->force_audio)
return 0; return 0;
if (old_force_audio == HDMI_AUDIO_AUTO)
old_has_audio = intel_dp->has_audio;
else
old_has_audio = old_force_audio;
intel_dp->force_audio = i; intel_dp->force_audio = i;
if (i == HDMI_AUDIO_AUTO) if (i == HDMI_AUDIO_AUTO)
has_audio = intel_dp_detect_audio(connector); has_audio = intel_dp->has_audio;
else else
has_audio = (i == HDMI_AUDIO_ON); has_audio = (i == HDMI_AUDIO_ON);
if (has_audio == intel_dp->has_audio) if (has_audio == old_has_audio)
return 0; return 0;
intel_dp->has_audio = has_audio;
goto done; goto done;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment