diff options
author | Slava Grigorev <slava.grigorev@amd.com> | 2014-12-05 17:59:56 -0500 |
---|---|---|
committer | Alex Deucher <alexander.deucher@amd.com> | 2015-01-22 10:42:10 -0500 |
commit | 96ea7afbc256ce7e2b2446909f52dab357942c3c (patch) | |
tree | 5fb9182a64808b71c271d99dfec4a622a8ee2508 /drivers/gpu/drm | |
parent | a85d682a6578a3bd02c95afb4ef527fa0897bb69 (diff) |
radeon/audio: consolidate update_avi_infoframe() functions
Reviewed-by: Christian König <christian.koenig@amd.com>
Signed-off-by: Slava Grigorev <slava.grigorev@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu/drm')
-rw-r--r-- | drivers/gpu/drm/radeon/dce3_1_afmt.c | 2 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/evergreen_hdmi.c | 16 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/r600_hdmi.c | 14 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/radeon_audio.c | 20 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/radeon_audio.h | 4 |
5 files changed, 34 insertions, 22 deletions
diff --git a/drivers/gpu/drm/radeon/dce3_1_afmt.c b/drivers/gpu/drm/radeon/dce3_1_afmt.c index 6cb2f1171539..0accc5ee0e39 100644 --- a/drivers/gpu/drm/radeon/dce3_1_afmt.c +++ b/drivers/gpu/drm/radeon/dce3_1_afmt.c | |||
@@ -254,7 +254,7 @@ void dce3_1_hdmi_setmode(struct drm_encoder *encoder, struct drm_display_mode *m | |||
254 | return; | 254 | return; |
255 | } | 255 | } |
256 | 256 | ||
257 | r600_hdmi_update_avi_infoframe(encoder, buffer, sizeof(buffer)); | 257 | radeon_update_avi_infoframe(encoder, buffer, sizeof(buffer)); |
258 | r600_hdmi_update_ACR(encoder, mode->clock); | 258 | r600_hdmi_update_ACR(encoder, mode->clock); |
259 | 259 | ||
260 | /* it's unknown what these bits do excatly, but it's indeed quite useful for debugging */ | 260 | /* it's unknown what these bits do excatly, but it's indeed quite useful for debugging */ |
diff --git a/drivers/gpu/drm/radeon/evergreen_hdmi.c b/drivers/gpu/drm/radeon/evergreen_hdmi.c index 38b1c51cce4d..f2896e5ff055 100644 --- a/drivers/gpu/drm/radeon/evergreen_hdmi.c +++ b/drivers/gpu/drm/radeon/evergreen_hdmi.c | |||
@@ -195,18 +195,12 @@ void evergreen_hdmi_write_sad_regs(struct drm_encoder *encoder, | |||
195 | } | 195 | } |
196 | 196 | ||
197 | /* | 197 | /* |
198 | * build a HDMI Video Info Frame | 198 | * build a AVI Info Frame |
199 | */ | 199 | */ |
200 | static void evergreen_hdmi_update_avi_infoframe(struct drm_encoder *encoder, | 200 | void evergreen_update_avi_infoframe(struct radeon_device *rdev, u32 offset, |
201 | void *buffer, size_t size) | 201 | unsigned char *buffer, size_t size) |
202 | { | 202 | { |
203 | struct drm_device *dev = encoder->dev; | ||
204 | struct radeon_device *rdev = dev->dev_private; | ||
205 | struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder); | ||
206 | struct radeon_encoder_atom_dig *dig = radeon_encoder->enc_priv; | ||
207 | uint32_t offset = dig->afmt->offset; | ||
208 | uint8_t *frame = buffer + 3; | 203 | uint8_t *frame = buffer + 3; |
209 | uint8_t *header = buffer; | ||
210 | 204 | ||
211 | WREG32(AFMT_AVI_INFO0 + offset, | 205 | WREG32(AFMT_AVI_INFO0 + offset, |
212 | frame[0x0] | (frame[0x1] << 8) | (frame[0x2] << 16) | (frame[0x3] << 24)); | 206 | frame[0x0] | (frame[0x1] << 8) | (frame[0x2] << 16) | (frame[0x3] << 24)); |
@@ -215,7 +209,7 @@ static void evergreen_hdmi_update_avi_infoframe(struct drm_encoder *encoder, | |||
215 | WREG32(AFMT_AVI_INFO2 + offset, | 209 | WREG32(AFMT_AVI_INFO2 + offset, |
216 | frame[0x8] | (frame[0x9] << 8) | (frame[0xA] << 16) | (frame[0xB] << 24)); | 210 | frame[0x8] | (frame[0x9] << 8) | (frame[0xA] << 16) | (frame[0xB] << 24)); |
217 | WREG32(AFMT_AVI_INFO3 + offset, | 211 | WREG32(AFMT_AVI_INFO3 + offset, |
218 | frame[0xC] | (frame[0xD] << 8) | (header[1] << 24)); | 212 | frame[0xC] | (frame[0xD] << 8) | (buffer[1] << 24)); |
219 | } | 213 | } |
220 | 214 | ||
221 | void dce4_hdmi_audio_set_dto(struct radeon_device *rdev, | 215 | void dce4_hdmi_audio_set_dto(struct radeon_device *rdev, |
@@ -431,7 +425,7 @@ void evergreen_hdmi_setmode(struct drm_encoder *encoder, struct drm_display_mode | |||
431 | return; | 425 | return; |
432 | } | 426 | } |
433 | 427 | ||
434 | evergreen_hdmi_update_avi_infoframe(encoder, buffer, sizeof(buffer)); | 428 | radeon_update_avi_infoframe(encoder, buffer, sizeof(buffer)); |
435 | 429 | ||
436 | WREG32_OR(HDMI_INFOFRAME_CONTROL0 + offset, | 430 | WREG32_OR(HDMI_INFOFRAME_CONTROL0 + offset, |
437 | HDMI_AVI_INFO_SEND | /* enable AVI info frames */ | 431 | HDMI_AVI_INFO_SEND | /* enable AVI info frames */ |
diff --git a/drivers/gpu/drm/radeon/r600_hdmi.c b/drivers/gpu/drm/radeon/r600_hdmi.c index 30580d1a14f0..53ee7ad9612c 100644 --- a/drivers/gpu/drm/radeon/r600_hdmi.c +++ b/drivers/gpu/drm/radeon/r600_hdmi.c | |||
@@ -285,16 +285,10 @@ void r600_hdmi_update_ACR(struct drm_encoder *encoder, uint32_t clock) | |||
285 | /* | 285 | /* |
286 | * build a HDMI Video Info Frame | 286 | * build a HDMI Video Info Frame |
287 | */ | 287 | */ |
288 | void r600_hdmi_update_avi_infoframe(struct drm_encoder *encoder, void *buffer, | 288 | void r600_update_avi_infoframe(struct radeon_device *rdev, u32 offset, |
289 | size_t size) | 289 | unsigned char *buffer, size_t size) |
290 | { | 290 | { |
291 | struct drm_device *dev = encoder->dev; | ||
292 | struct radeon_device *rdev = dev->dev_private; | ||
293 | struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder); | ||
294 | struct radeon_encoder_atom_dig *dig = radeon_encoder->enc_priv; | ||
295 | uint32_t offset = dig->afmt->offset; | ||
296 | uint8_t *frame = buffer + 3; | 291 | uint8_t *frame = buffer + 3; |
297 | uint8_t *header = buffer; | ||
298 | 292 | ||
299 | WREG32(HDMI0_AVI_INFO0 + offset, | 293 | WREG32(HDMI0_AVI_INFO0 + offset, |
300 | frame[0x0] | (frame[0x1] << 8) | (frame[0x2] << 16) | (frame[0x3] << 24)); | 294 | frame[0x0] | (frame[0x1] << 8) | (frame[0x2] << 16) | (frame[0x3] << 24)); |
@@ -303,7 +297,7 @@ void r600_hdmi_update_avi_infoframe(struct drm_encoder *encoder, void *buffer, | |||
303 | WREG32(HDMI0_AVI_INFO2 + offset, | 297 | WREG32(HDMI0_AVI_INFO2 + offset, |
304 | frame[0x8] | (frame[0x9] << 8) | (frame[0xA] << 16) | (frame[0xB] << 24)); | 298 | frame[0x8] | (frame[0x9] << 8) | (frame[0xA] << 16) | (frame[0xB] << 24)); |
305 | WREG32(HDMI0_AVI_INFO3 + offset, | 299 | WREG32(HDMI0_AVI_INFO3 + offset, |
306 | frame[0xC] | (frame[0xD] << 8) | (header[1] << 24)); | 300 | frame[0xC] | (frame[0xD] << 8) | (buffer[1] << 24)); |
307 | } | 301 | } |
308 | 302 | ||
309 | /* | 303 | /* |
@@ -486,7 +480,7 @@ void r600_hdmi_setmode(struct drm_encoder *encoder, struct drm_display_mode *mod | |||
486 | return; | 480 | return; |
487 | } | 481 | } |
488 | 482 | ||
489 | r600_hdmi_update_avi_infoframe(encoder, buffer, sizeof(buffer)); | 483 | radeon_update_avi_infoframe(encoder, buffer, sizeof(buffer)); |
490 | 484 | ||
491 | /* fglrx duplicates INFOFRAME_CONTROL0 & INFOFRAME_CONTROL1 ops here */ | 485 | /* fglrx duplicates INFOFRAME_CONTROL0 & INFOFRAME_CONTROL1 ops here */ |
492 | 486 | ||
diff --git a/drivers/gpu/drm/radeon/radeon_audio.c b/drivers/gpu/drm/radeon/radeon_audio.c index 2a2bf5b5b805..cc58ee8c7d2f 100644 --- a/drivers/gpu/drm/radeon/radeon_audio.c +++ b/drivers/gpu/drm/radeon/radeon_audio.c | |||
@@ -74,6 +74,10 @@ void dce6_hdmi_audio_set_dto(struct radeon_device *rdev, | |||
74 | struct radeon_crtc *crtc, unsigned int clock); | 74 | struct radeon_crtc *crtc, unsigned int clock); |
75 | void dce6_dp_audio_set_dto(struct radeon_device *rdev, | 75 | void dce6_dp_audio_set_dto(struct radeon_device *rdev, |
76 | struct radeon_crtc *crtc, unsigned int clock); | 76 | struct radeon_crtc *crtc, unsigned int clock); |
77 | void r600_update_avi_infoframe(struct radeon_device *rdev, u32 offset, | ||
78 | unsigned char *buffer, size_t size); | ||
79 | void evergreen_update_avi_infoframe(struct radeon_device *rdev, u32 offset, | ||
80 | unsigned char *buffer, size_t size); | ||
77 | 81 | ||
78 | static const u32 pin_offsets[7] = | 82 | static const u32 pin_offsets[7] = |
79 | { | 83 | { |
@@ -101,24 +105,28 @@ static struct radeon_audio_basic_funcs r600_funcs = { | |||
101 | .endpoint_rreg = radeon_audio_rreg, | 105 | .endpoint_rreg = radeon_audio_rreg, |
102 | .endpoint_wreg = radeon_audio_wreg, | 106 | .endpoint_wreg = radeon_audio_wreg, |
103 | .enable = r600_audio_enable, | 107 | .enable = r600_audio_enable, |
108 | .update_avi_infoframe = r600_update_avi_infoframe, | ||
104 | }; | 109 | }; |
105 | 110 | ||
106 | static struct radeon_audio_basic_funcs dce32_funcs = { | 111 | static struct radeon_audio_basic_funcs dce32_funcs = { |
107 | .endpoint_rreg = radeon_audio_rreg, | 112 | .endpoint_rreg = radeon_audio_rreg, |
108 | .endpoint_wreg = radeon_audio_wreg, | 113 | .endpoint_wreg = radeon_audio_wreg, |
109 | .enable = r600_audio_enable, | 114 | .enable = r600_audio_enable, |
115 | .update_avi_infoframe = r600_update_avi_infoframe, | ||
110 | }; | 116 | }; |
111 | 117 | ||
112 | static struct radeon_audio_basic_funcs dce4_funcs = { | 118 | static struct radeon_audio_basic_funcs dce4_funcs = { |
113 | .endpoint_rreg = radeon_audio_rreg, | 119 | .endpoint_rreg = radeon_audio_rreg, |
114 | .endpoint_wreg = radeon_audio_wreg, | 120 | .endpoint_wreg = radeon_audio_wreg, |
115 | .enable = dce4_audio_enable, | 121 | .enable = dce4_audio_enable, |
122 | .update_avi_infoframe = evergreen_update_avi_infoframe, | ||
116 | }; | 123 | }; |
117 | 124 | ||
118 | static struct radeon_audio_basic_funcs dce6_funcs = { | 125 | static struct radeon_audio_basic_funcs dce6_funcs = { |
119 | .endpoint_rreg = dce6_endpoint_rreg, | 126 | .endpoint_rreg = dce6_endpoint_rreg, |
120 | .endpoint_wreg = dce6_endpoint_wreg, | 127 | .endpoint_wreg = dce6_endpoint_wreg, |
121 | .enable = dce6_audio_enable, | 128 | .enable = dce6_audio_enable, |
129 | .update_avi_infoframe = evergreen_update_avi_infoframe, | ||
122 | }; | 130 | }; |
123 | 131 | ||
124 | static struct radeon_audio_funcs r600_hdmi_funcs = { | 132 | static struct radeon_audio_funcs r600_hdmi_funcs = { |
@@ -436,3 +444,15 @@ void radeon_audio_set_dto(struct drm_encoder *encoder, unsigned int clock) | |||
436 | if (radeon_encoder->audio && radeon_encoder->audio->set_dto) | 444 | if (radeon_encoder->audio && radeon_encoder->audio->set_dto) |
437 | radeon_encoder->audio->set_dto(rdev, crtc, clock); | 445 | radeon_encoder->audio->set_dto(rdev, crtc, clock); |
438 | } | 446 | } |
447 | |||
448 | void radeon_update_avi_infoframe(struct drm_encoder *encoder, void *buffer, | ||
449 | size_t size) | ||
450 | { | ||
451 | struct radeon_device *rdev = encoder->dev->dev_private; | ||
452 | struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder); | ||
453 | struct radeon_encoder_atom_dig *dig = radeon_encoder->enc_priv; | ||
454 | |||
455 | if (dig && dig->afmt && rdev->audio.funcs->update_avi_infoframe) | ||
456 | rdev->audio.funcs->update_avi_infoframe(rdev, dig->afmt->offset, | ||
457 | buffer, size); | ||
458 | } | ||
diff --git a/drivers/gpu/drm/radeon/radeon_audio.h b/drivers/gpu/drm/radeon/radeon_audio.h index 06b80de7cdbe..dc85d53d1587 100644 --- a/drivers/gpu/drm/radeon/radeon_audio.h +++ b/drivers/gpu/drm/radeon/radeon_audio.h | |||
@@ -39,6 +39,8 @@ struct radeon_audio_basic_funcs | |||
39 | u32 offset, u32 reg, u32 v); | 39 | u32 offset, u32 reg, u32 v); |
40 | void (*enable)(struct radeon_device *rdev, | 40 | void (*enable)(struct radeon_device *rdev, |
41 | struct r600_audio_pin *pin, u8 enable_mask); | 41 | struct r600_audio_pin *pin, u8 enable_mask); |
42 | void (*update_avi_infoframe)(struct radeon_device *rdev, u32 offset, | ||
43 | unsigned char *buffer, size_t size); | ||
42 | }; | 44 | }; |
43 | 45 | ||
44 | struct radeon_audio_funcs | 46 | struct radeon_audio_funcs |
@@ -72,5 +74,7 @@ void radeon_audio_enable(struct radeon_device *rdev, | |||
72 | struct r600_audio_pin *pin, u8 enable_mask); | 74 | struct r600_audio_pin *pin, u8 enable_mask); |
73 | void radeon_audio_fini(struct radeon_device *rdev); | 75 | void radeon_audio_fini(struct radeon_device *rdev); |
74 | void radeon_audio_set_dto(struct drm_encoder *encoder, unsigned int clock); | 76 | void radeon_audio_set_dto(struct drm_encoder *encoder, unsigned int clock); |
77 | void radeon_update_avi_infoframe(struct drm_encoder *encoder, void *buffer, | ||
78 | size_t size); | ||
75 | 79 | ||
76 | #endif | 80 | #endif |