]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
drm/radeon: clean up evergreen_get_vblank_counter
authorAlex Deucher <alexander.deucher@amd.com>
Wed, 15 Aug 2012 21:10:32 +0000 (17:10 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Thu, 20 Sep 2012 17:10:32 +0000 (13:10 -0400)
Use the new offset array rather than open coding it.

Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/radeon/evergreen.c

index 0c79d9eb2ce46b046724923c71610c3c50578f26..585c11741d020aa8881def23672b87833bccf58f 100644 (file)
@@ -2345,22 +2345,10 @@ int evergreen_asic_reset(struct radeon_device *rdev)
 
 u32 evergreen_get_vblank_counter(struct radeon_device *rdev, int crtc)
 {
-       switch (crtc) {
-       case 0:
-               return RREG32(CRTC_STATUS_FRAME_COUNT + EVERGREEN_CRTC0_REGISTER_OFFSET);
-       case 1:
-               return RREG32(CRTC_STATUS_FRAME_COUNT + EVERGREEN_CRTC1_REGISTER_OFFSET);
-       case 2:
-               return RREG32(CRTC_STATUS_FRAME_COUNT + EVERGREEN_CRTC2_REGISTER_OFFSET);
-       case 3:
-               return RREG32(CRTC_STATUS_FRAME_COUNT + EVERGREEN_CRTC3_REGISTER_OFFSET);
-       case 4:
-               return RREG32(CRTC_STATUS_FRAME_COUNT + EVERGREEN_CRTC4_REGISTER_OFFSET);
-       case 5:
-               return RREG32(CRTC_STATUS_FRAME_COUNT + EVERGREEN_CRTC5_REGISTER_OFFSET);
-       default:
+       if (crtc >= rdev->num_crtc)
                return 0;
-       }
+       else
+               return RREG32(CRTC_STATUS_FRAME_COUNT + crtc_offsets[crtc]);
 }
 
 void evergreen_disable_interrupt_state(struct radeon_device *rdev)