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/r100.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/r100.c')
-rw-r--r-- | drivers/gpu/drm/radeon/r100.c | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/drivers/gpu/drm/radeon/r100.c b/drivers/gpu/drm/radeon/r100.c index f3892efcf7f4..b41237bf884b 100644 --- a/drivers/gpu/drm/radeon/r100.c +++ b/drivers/gpu/drm/radeon/r100.c | |||
@@ -3758,7 +3758,8 @@ int r100_ib_test(struct radeon_device *rdev, struct radeon_ring *ring) | |||
3758 | WREG32(scratch, 0xCAFEDEAD); | 3758 | WREG32(scratch, 0xCAFEDEAD); |
3759 | r = radeon_ib_get(rdev, RADEON_RING_TYPE_GFX_INDEX, &ib, NULL, 256); | 3759 | r = radeon_ib_get(rdev, RADEON_RING_TYPE_GFX_INDEX, &ib, NULL, 256); |
3760 | if (r) { | 3760 | if (r) { |
3761 | return r; | 3761 | DRM_ERROR("radeon: failed to get ib (%d).\n", r); |
3762 | goto free_scratch; | ||
3762 | } | 3763 | } |
3763 | ib.ptr[0] = PACKET0(scratch, 0); | 3764 | ib.ptr[0] = PACKET0(scratch, 0); |
3764 | ib.ptr[1] = 0xDEADBEEF; | 3765 | ib.ptr[1] = 0xDEADBEEF; |
@@ -3771,13 +3772,13 @@ int r100_ib_test(struct radeon_device *rdev, struct radeon_ring *ring) | |||
3771 | ib.length_dw = 8; | 3772 | ib.length_dw = 8; |
3772 | r = radeon_ib_schedule(rdev, &ib, NULL); | 3773 | r = radeon_ib_schedule(rdev, &ib, NULL); |
3773 | if (r) { | 3774 | if (r) { |
3774 | radeon_scratch_free(rdev, scratch); | 3775 | DRM_ERROR("radeon: failed to schedule ib (%d).\n", r); |
3775 | radeon_ib_free(rdev, &ib); | 3776 | goto free_ib; |
3776 | return r; | ||
3777 | } | 3777 | } |
3778 | r = radeon_fence_wait(ib.fence, false); | 3778 | r = radeon_fence_wait(ib.fence, false); |
3779 | if (r) { | 3779 | if (r) { |
3780 | return r; | 3780 | DRM_ERROR("radeon: fence wait failed (%d).\n", r); |
3781 | goto free_ib; | ||
3781 | } | 3782 | } |
3782 | for (i = 0; i < rdev->usec_timeout; i++) { | 3783 | for (i = 0; i < rdev->usec_timeout; i++) { |
3783 | tmp = RREG32(scratch); | 3784 | tmp = RREG32(scratch); |
@@ -3793,8 +3794,10 @@ int r100_ib_test(struct radeon_device *rdev, struct radeon_ring *ring) | |||
3793 | scratch, tmp); | 3794 | scratch, tmp); |
3794 | r = -EINVAL; | 3795 | r = -EINVAL; |
3795 | } | 3796 | } |
3796 | radeon_scratch_free(rdev, scratch); | 3797 | free_ib: |
3797 | radeon_ib_free(rdev, &ib); | 3798 | radeon_ib_free(rdev, &ib); |
3799 | free_scratch: | ||
3800 | radeon_scratch_free(rdev, scratch); | ||
3798 | return r; | 3801 | return r; |
3799 | } | 3802 | } |
3800 | 3803 | ||