diff options
author | Rafał Miłecki <zajec5@gmail.com> | 2012-04-30 09:44:52 -0400 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2012-05-13 09:18:58 -0400 |
commit | a273a903bf3d480270803350d01b51b18bbbeb9d (patch) | |
tree | bc15308e30ef3e24ccd0eb3b941f18ae628317fe /drivers/gpu/drm/radeon/r600_hdmi.c | |
parent | 218c872bf8285af7aaa50f1f83312020e05451bf (diff) |
drm/radeon/kms/hdmi: enable audio packets at one place
Signed-off-by: Rafał Miłecki <zajec5@gmail.com>
Reviewed-by: Alex Deucher <alexdeucher@gmail.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers/gpu/drm/radeon/r600_hdmi.c')
-rw-r--r-- | drivers/gpu/drm/radeon/r600_hdmi.c | 26 |
1 files changed, 16 insertions, 10 deletions
diff --git a/drivers/gpu/drm/radeon/r600_hdmi.c b/drivers/gpu/drm/radeon/r600_hdmi.c index c6de0022c070..69839df1c479 100644 --- a/drivers/gpu/drm/radeon/r600_hdmi.c +++ b/drivers/gpu/drm/radeon/r600_hdmi.c | |||
@@ -303,11 +303,13 @@ void r600_hdmi_audio_workaround(struct drm_encoder *encoder) | |||
303 | r600_hdmi_is_audio_buffer_filled(encoder)) { | 303 | r600_hdmi_is_audio_buffer_filled(encoder)) { |
304 | 304 | ||
305 | /* disable audio workaround */ | 305 | /* disable audio workaround */ |
306 | WREG32_P(HDMI0_AUDIO_PACKET_CONTROL + offset, 0x0001, ~0x1001); | 306 | WREG32_P(HDMI0_AUDIO_PACKET_CONTROL + offset, |
307 | 0, ~HDMI0_AUDIO_TEST_EN); | ||
307 | 308 | ||
308 | } else { | 309 | } else { |
309 | /* enable audio workaround */ | 310 | /* enable audio workaround */ |
310 | WREG32_P(HDMI0_AUDIO_PACKET_CONTROL + offset, 0x1001, ~0x1001); | 311 | WREG32_P(HDMI0_AUDIO_PACKET_CONTROL + offset, |
312 | HDMI0_AUDIO_TEST_EN, ~HDMI0_AUDIO_TEST_EN); | ||
311 | } | 313 | } |
312 | } | 314 | } |
313 | 315 | ||
@@ -331,6 +333,18 @@ void r600_hdmi_setmode(struct drm_encoder *encoder, struct drm_display_mode *mod | |||
331 | 333 | ||
332 | WREG32(HDMI0_AUDIO_CRC_CONTROL + offset, 0x1000); | 334 | WREG32(HDMI0_AUDIO_CRC_CONTROL + offset, 0x1000); |
333 | WREG32(HDMI0_GC + offset, 0x0); | 335 | WREG32(HDMI0_GC + offset, 0x0); |
336 | |||
337 | /* Send audio packets */ | ||
338 | if (ASIC_IS_DCE4(rdev)) | ||
339 | WREG32_P(0x74fc + offset, | ||
340 | AFMT_AUDIO_SAMPLE_SEND, ~AFMT_AUDIO_SAMPLE_SEND); | ||
341 | else if (ASIC_IS_DCE32(rdev)) | ||
342 | WREG32_P(AFMT_AUDIO_PACKET_CONTROL + offset, | ||
343 | AFMT_AUDIO_SAMPLE_SEND, ~AFMT_AUDIO_SAMPLE_SEND); | ||
344 | else | ||
345 | WREG32_P(HDMI0_AUDIO_PACKET_CONTROL + offset, | ||
346 | HDMI0_AUDIO_SAMPLE_SEND, ~HDMI0_AUDIO_SAMPLE_SEND); | ||
347 | |||
334 | WREG32(HDMI0_ACR_PACKET_CONTROL + offset, 0x1000); | 348 | WREG32(HDMI0_ACR_PACKET_CONTROL + offset, 0x1000); |
335 | 349 | ||
336 | r600_hdmi_update_ACR(encoder, mode->clock); | 350 | r600_hdmi_update_ACR(encoder, mode->clock); |
@@ -495,10 +509,6 @@ void r600_hdmi_enable(struct drm_encoder *encoder) | |||
495 | offset = radeon_encoder->hdmi_offset; | 509 | offset = radeon_encoder->hdmi_offset; |
496 | if (ASIC_IS_DCE5(rdev)) { | 510 | if (ASIC_IS_DCE5(rdev)) { |
497 | /* TODO */ | 511 | /* TODO */ |
498 | } else if (ASIC_IS_DCE4(rdev)) { | ||
499 | WREG32_P(0x74fc + radeon_encoder->hdmi_offset, 0x1, ~0x1); | ||
500 | } else if (ASIC_IS_DCE32(rdev)) { | ||
501 | WREG32_P(AFMT_AUDIO_PACKET_CONTROL + radeon_encoder->hdmi_offset, 0x1, ~0x1); | ||
502 | } else if (ASIC_IS_DCE3(rdev)) { | 512 | } else if (ASIC_IS_DCE3(rdev)) { |
503 | /* TODO */ | 513 | /* TODO */ |
504 | } else if (rdev->family >= CHIP_R600) { | 514 | } else if (rdev->family >= CHIP_R600) { |
@@ -558,10 +568,6 @@ void r600_hdmi_disable(struct drm_encoder *encoder) | |||
558 | 568 | ||
559 | if (ASIC_IS_DCE5(rdev)) { | 569 | if (ASIC_IS_DCE5(rdev)) { |
560 | /* TODO */ | 570 | /* TODO */ |
561 | } else if (ASIC_IS_DCE4(rdev)) { | ||
562 | WREG32_P(0x74fc + radeon_encoder->hdmi_offset, 0, ~0x1); | ||
563 | } else if (ASIC_IS_DCE32(rdev)) { | ||
564 | WREG32_P(AFMT_AUDIO_PACKET_CONTROL + radeon_encoder->hdmi_offset, 0, ~0x1); | ||
565 | } else if (rdev->family >= CHIP_R600 && !ASIC_IS_DCE3(rdev)) { | 571 | } else if (rdev->family >= CHIP_R600 && !ASIC_IS_DCE3(rdev)) { |
566 | switch (radeon_encoder->encoder_id) { | 572 | switch (radeon_encoder->encoder_id) { |
567 | case ENCODER_OBJECT_ID_INTERNAL_KLDSCP_TMDS1: | 573 | case ENCODER_OBJECT_ID_INTERNAL_KLDSCP_TMDS1: |