diff options
author | Rafał Miłecki <zajec5@gmail.com> | 2013-08-01 11:29:16 -0400 |
---|---|---|
committer | Alex Deucher <alexander.deucher@amd.com> | 2013-08-30 16:30:44 -0400 |
commit | a4d39e68949f5b4f7b426be63782b421018f741a (patch) | |
tree | 9cb9815717773cc8de4fde17a9a32bd3635d5d95 /drivers | |
parent | d105f4768a959f22078820625ccec9b693f164c8 (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')
-rw-r--r-- | drivers/gpu/drm/radeon/radeon_display.c | 53 |
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)) { |