aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWu Fengguang <fengguang.wu@intel.com>2011-12-09 07:42:20 -0500
committerKeith Packard <keithp@keithp.com>2011-12-19 22:15:48 -0500
commit2deed761188d7480eb5f7efbfe7aa77f09322ed8 (patch)
treebebf3721fc6b05b49713789298ea0593e49ebf89
parent3a9627f4fbb0ec2e8f6c8a17a589b659873ee04e (diff)
drm/i915: HDMI hot remove notification to audio driver
On HDMI monitor hot remove, clear SDVO_AUDIO_ENABLE accordingly, so that the audio driver will receive hot plug events and take action to refresh its device state and ELD contents. The cleared SDVO_AUDIO_ENABLE bit needs to be restored to prevent losing HDMI audio after DPMS on. CC: Wang Zhenyu <zhenyu.z.wang@intel.com> Signed-off-by: Wu Fengguang <fengguang.wu@intel.com> Signed-off-by: Keith Packard <keithp@keithp.com>
-rw-r--r--drivers/gpu/drm/i915/intel_hdmi.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/drivers/gpu/drm/i915/intel_hdmi.c b/drivers/gpu/drm/i915/intel_hdmi.c
index d4f5a0b2120d..64541f7ef900 100644
--- a/drivers/gpu/drm/i915/intel_hdmi.c
+++ b/drivers/gpu/drm/i915/intel_hdmi.c
@@ -269,6 +269,10 @@ static void intel_hdmi_dpms(struct drm_encoder *encoder, int mode)
269 struct drm_i915_private *dev_priv = dev->dev_private; 269 struct drm_i915_private *dev_priv = dev->dev_private;
270 struct intel_hdmi *intel_hdmi = enc_to_intel_hdmi(encoder); 270 struct intel_hdmi *intel_hdmi = enc_to_intel_hdmi(encoder);
271 u32 temp; 271 u32 temp;
272 u32 enable_bits = SDVO_ENABLE;
273
274 if (intel_hdmi->has_audio)
275 enable_bits |= SDVO_AUDIO_ENABLE;
272 276
273 temp = I915_READ(intel_hdmi->sdvox_reg); 277 temp = I915_READ(intel_hdmi->sdvox_reg);
274 278
@@ -281,9 +285,9 @@ static void intel_hdmi_dpms(struct drm_encoder *encoder, int mode)
281 } 285 }
282 286
283 if (mode != DRM_MODE_DPMS_ON) { 287 if (mode != DRM_MODE_DPMS_ON) {
284 temp &= ~SDVO_ENABLE; 288 temp &= ~enable_bits;
285 } else { 289 } else {
286 temp |= SDVO_ENABLE; 290 temp |= enable_bits;
287 } 291 }
288 292
289 I915_WRITE(intel_hdmi->sdvox_reg, temp); 293 I915_WRITE(intel_hdmi->sdvox_reg, temp);