diff options
author | Michel Dänzer <michel.daenzer@amd.com> | 2012-09-20 04:31:10 -0400 |
---|---|---|
committer | Alex Deucher <alexander.deucher@amd.com> | 2012-09-27 10:22:42 -0400 |
commit | af026c5bd14cb57b230a63bdee6f73677a06f010 (patch) | |
tree | 90f3287d137f48a62b79809f5baf6dc33954ebf4 /drivers/gpu/drm/radeon/r600.c | |
parent | bced76f27165ca7733437715185c3a1aa526f7a1 (diff) |
drm/radeon: Fix scratch register leak in IB test.
Restructure the code to jump out via labels instead of directly returning
early. Also make error reporting consistent across all hardware generations.
Signed-off-by: Michel Dänzer <michel.daenzer@amd.com>
Reviewed-by: Simon Kitching <skitching@vonos.net>
Reviewed-by: Christian König <christian.koenig@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu/drm/radeon/r600.c')
-rw-r--r-- | drivers/gpu/drm/radeon/r600.c | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/drivers/gpu/drm/radeon/r600.c b/drivers/gpu/drm/radeon/r600.c index 48460b4b3e2e..39b743fff791 100644 --- a/drivers/gpu/drm/radeon/r600.c +++ b/drivers/gpu/drm/radeon/r600.c | |||
@@ -2638,7 +2638,7 @@ int r600_ib_test(struct radeon_device *rdev, struct radeon_ring *ring) | |||
2638 | r = radeon_ib_get(rdev, ring->idx, &ib, NULL, 256); | 2638 | r = radeon_ib_get(rdev, ring->idx, &ib, NULL, 256); |
2639 | if (r) { | 2639 | if (r) { |
2640 | DRM_ERROR("radeon: failed to get ib (%d).\n", r); | 2640 | DRM_ERROR("radeon: failed to get ib (%d).\n", r); |
2641 | return r; | 2641 | goto free_scratch; |
2642 | } | 2642 | } |
2643 | ib.ptr[0] = PACKET3(PACKET3_SET_CONFIG_REG, 1); | 2643 | ib.ptr[0] = PACKET3(PACKET3_SET_CONFIG_REG, 1); |
2644 | ib.ptr[1] = ((scratch - PACKET3_SET_CONFIG_REG_OFFSET) >> 2); | 2644 | ib.ptr[1] = ((scratch - PACKET3_SET_CONFIG_REG_OFFSET) >> 2); |
@@ -2646,15 +2646,13 @@ int r600_ib_test(struct radeon_device *rdev, struct radeon_ring *ring) | |||
2646 | ib.length_dw = 3; | 2646 | ib.length_dw = 3; |
2647 | r = radeon_ib_schedule(rdev, &ib, NULL); | 2647 | r = radeon_ib_schedule(rdev, &ib, NULL); |
2648 | if (r) { | 2648 | if (r) { |
2649 | radeon_scratch_free(rdev, scratch); | ||
2650 | radeon_ib_free(rdev, &ib); | ||
2651 | DRM_ERROR("radeon: failed to schedule ib (%d).\n", r); | 2649 | DRM_ERROR("radeon: failed to schedule ib (%d).\n", r); |
2652 | return r; | 2650 | goto free_ib; |
2653 | } | 2651 | } |
2654 | r = radeon_fence_wait(ib.fence, false); | 2652 | r = radeon_fence_wait(ib.fence, false); |
2655 | if (r) { | 2653 | if (r) { |
2656 | DRM_ERROR("radeon: fence wait failed (%d).\n", r); | 2654 | DRM_ERROR("radeon: fence wait failed (%d).\n", r); |
2657 | return r; | 2655 | goto free_ib; |
2658 | } | 2656 | } |
2659 | for (i = 0; i < rdev->usec_timeout; i++) { | 2657 | for (i = 0; i < rdev->usec_timeout; i++) { |
2660 | tmp = RREG32(scratch); | 2658 | tmp = RREG32(scratch); |
@@ -2669,8 +2667,10 @@ int r600_ib_test(struct radeon_device *rdev, struct radeon_ring *ring) | |||
2669 | scratch, tmp); | 2667 | scratch, tmp); |
2670 | r = -EINVAL; | 2668 | r = -EINVAL; |
2671 | } | 2669 | } |
2672 | radeon_scratch_free(rdev, scratch); | 2670 | free_ib: |
2673 | radeon_ib_free(rdev, &ib); | 2671 | radeon_ib_free(rdev, &ib); |
2672 | free_scratch: | ||
2673 | radeon_scratch_free(rdev, scratch); | ||
2674 | return r; | 2674 | return r; |
2675 | } | 2675 | } |
2676 | 2676 | ||