aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/radeon/radeon_display.c
diff options
context:
space:
mode:
authorRafał Miłecki <zajec5@gmail.com>2013-08-01 11:29:16 -0400
committerAlex Deucher <alexander.deucher@amd.com>2013-08-30 16:30:44 -0400
commita4d39e68949f5b4f7b426be63782b421018f741a (patch)
tree9cb9815717773cc8de4fde17a9a32bd3635d5d95 /drivers/gpu/drm/radeon/radeon_display.c
parentd105f4768a959f22078820625ccec9b693f164c8 (diff)
drm/radeon: use loop for initializing AFMT blocks
Signed-off-by: Rafał Miłecki <zajec5@gmail.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu/drm/radeon/radeon_display.c')
-rw-r--r--drivers/gpu/drm/radeon/radeon_display.c53
1 files changed, 23 insertions, 30 deletions
diff --git a/drivers/gpu/drm/radeon/radeon_display.c b/drivers/gpu/drm/radeon/radeon_display.c
index c2b67b4e1ac2..31d9fbe85c72 100644
--- a/drivers/gpu/drm/radeon/radeon_display.c
+++ b/drivers/gpu/drm/radeon/radeon_display.c
@@ -1257,38 +1257,31 @@ static void radeon_afmt_init(struct radeon_device *rdev)
1257 if (ASIC_IS_DCE6(rdev)) { 1257 if (ASIC_IS_DCE6(rdev)) {
1258 /* todo */ 1258 /* todo */
1259 } else if (ASIC_IS_DCE4(rdev)) { 1259 } else if (ASIC_IS_DCE4(rdev)) {
1260 static uint32_t eg_offsets[] = {
1261 EVERGREEN_CRTC0_REGISTER_OFFSET,
1262 EVERGREEN_CRTC1_REGISTER_OFFSET,
1263 EVERGREEN_CRTC2_REGISTER_OFFSET,
1264 EVERGREEN_CRTC3_REGISTER_OFFSET,
1265 EVERGREEN_CRTC4_REGISTER_OFFSET,
1266 EVERGREEN_CRTC5_REGISTER_OFFSET,
1267 };
1268 int num_afmt;
1269
1260 /* DCE4/5 has 6 audio blocks tied to DIG encoders */ 1270 /* DCE4/5 has 6 audio blocks tied to DIG encoders */
1261 /* DCE4.1 has 2 audio blocks tied to DIG encoders */ 1271 /* DCE4.1 has 2 audio blocks tied to DIG encoders */
1262 rdev->mode_info.afmt[0] = kzalloc(sizeof(struct radeon_afmt), GFP_KERNEL); 1272 if (ASIC_IS_DCE5(rdev))
1263 if (rdev->mode_info.afmt[0]) { 1273 num_afmt = 6;
1264 rdev->mode_info.afmt[0]->offset = EVERGREEN_CRTC0_REGISTER_OFFSET; 1274 else if (ASIC_IS_DCE41(rdev))
1265 rdev->mode_info.afmt[0]->id = 0; 1275 num_afmt = 2;
1266 } 1276 else /* DCE4 */
1267 rdev->mode_info.afmt[1] = kzalloc(sizeof(struct radeon_afmt), GFP_KERNEL); 1277 num_afmt = 6;
1268 if (rdev->mode_info.afmt[1]) { 1278
1269 rdev->mode_info.afmt[1]->offset = EVERGREEN_CRTC1_REGISTER_OFFSET; 1279 BUG_ON(num_afmt > ARRAY_SIZE(eg_offsets));
1270 rdev->mode_info.afmt[1]->id = 1; 1280 for (i = 0; i < num_afmt; i++) {
1271 } 1281 rdev->mode_info.afmt[i] = kzalloc(sizeof(struct radeon_afmt), GFP_KERNEL);
1272 if (!ASIC_IS_DCE41(rdev)) { 1282 if (rdev->mode_info.afmt[i]) {
1273 rdev->mode_info.afmt[2] = kzalloc(sizeof(struct radeon_afmt), GFP_KERNEL); 1283 rdev->mode_info.afmt[i]->offset = eg_offsets[i];
1274 if (rdev->mode_info.afmt[2]) { 1284 rdev->mode_info.afmt[i]->id = i;
1275 rdev->mode_info.afmt[2]->offset = EVERGREEN_CRTC2_REGISTER_OFFSET;
1276 rdev->mode_info.afmt[2]->id = 2;
1277 }
1278 rdev->mode_info.afmt[3] = kzalloc(sizeof(struct radeon_afmt), GFP_KERNEL);
1279 if (rdev->mode_info.afmt[3]) {
1280 rdev->mode_info.afmt[3]->offset = EVERGREEN_CRTC3_REGISTER_OFFSET;
1281 rdev->mode_info.afmt[3]->id = 3;
1282 }
1283 rdev->mode_info.afmt[4] = kzalloc(sizeof(struct radeon_afmt), GFP_KERNEL);
1284 if (rdev->mode_info.afmt[4]) {
1285 rdev->mode_info.afmt[4]->offset = EVERGREEN_CRTC4_REGISTER_OFFSET;
1286 rdev->mode_info.afmt[4]->id = 4;
1287 }
1288 rdev->mode_info.afmt[5] = kzalloc(sizeof(struct radeon_afmt), GFP_KERNEL);
1289 if (rdev->mode_info.afmt[5]) {
1290 rdev->mode_info.afmt[5]->offset = EVERGREEN_CRTC5_REGISTER_OFFSET;
1291 rdev->mode_info.afmt[5]->id = 5;
1292 } 1285 }
1293 } 1286 }
1294 } else if (ASIC_IS_DCE3(rdev)) { 1287 } else if (ASIC_IS_DCE3(rdev)) {