On Thu, Sep 20, 2012 at 4:31 AM, Michel Dänzer <michel@xxxxxxxxxxx> wrote: > From: Michel Dänzer <michel.daenzer@xxxxxxx> > > 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@xxxxxxx> > Reviewed-by: Simon Kitching <skitching@xxxxxxxxx> > Reviewed-by: Christian König <christian.koenig@xxxxxxx> Added to my -next tree. Alex > --- > drivers/gpu/drm/radeon/r100.c | 15 +++++++++------ > drivers/gpu/drm/radeon/r600.c | 12 ++++++------ > 2 files changed, 15 insertions(+), 12 deletions(-) > > diff --git a/drivers/gpu/drm/radeon/r100.c b/drivers/gpu/drm/radeon/r100.c > index 8acb34f..693e33e 100644 > --- a/drivers/gpu/drm/radeon/r100.c > +++ b/drivers/gpu/drm/radeon/r100.c > @@ -3818,7 +3818,8 @@ int r100_ib_test(struct radeon_device *rdev, struct radeon_ring *ring) > WREG32(scratch, 0xCAFEDEAD); > r = radeon_ib_get(rdev, RADEON_RING_TYPE_GFX_INDEX, &ib, 256); > if (r) { > - return r; > + DRM_ERROR("radeon: failed to get ib (%d).\n", r); > + goto free_scratch; > } > ib.ptr[0] = PACKET0(scratch, 0); > ib.ptr[1] = 0xDEADBEEF; > @@ -3831,13 +3832,13 @@ int r100_ib_test(struct radeon_device *rdev, struct radeon_ring *ring) > ib.length_dw = 8; > r = radeon_ib_schedule(rdev, &ib, NULL); > if (r) { > - radeon_scratch_free(rdev, scratch); > - radeon_ib_free(rdev, &ib); > - return r; > + DRM_ERROR("radeon: failed to schedule ib (%d).\n", r); > + goto free_ib; > } > r = radeon_fence_wait(ib.fence, false); > if (r) { > - return r; > + DRM_ERROR("radeon: fence wait failed (%d).\n", r); > + goto free_ib; > } > for (i = 0; i < rdev->usec_timeout; i++) { > tmp = RREG32(scratch); > @@ -3853,8 +3854,10 @@ int r100_ib_test(struct radeon_device *rdev, struct radeon_ring *ring) > scratch, tmp); > r = -EINVAL; > } > - radeon_scratch_free(rdev, scratch); > +free_ib: > radeon_ib_free(rdev, &ib); > +free_scratch: > + radeon_scratch_free(rdev, scratch); > return r; > } > > diff --git a/drivers/gpu/drm/radeon/r600.c b/drivers/gpu/drm/radeon/r600.c > index d79c639..38b546e 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) > r = radeon_ib_get(rdev, ring->idx, &ib, 256); > if (r) { > DRM_ERROR("radeon: failed to get ib (%d).\n", r); > - return r; > + goto free_scratch; > } > ib.ptr[0] = PACKET3(PACKET3_SET_CONFIG_REG, 1); > 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) > ib.length_dw = 3; > r = radeon_ib_schedule(rdev, &ib, NULL); > if (r) { > - radeon_scratch_free(rdev, scratch); > - radeon_ib_free(rdev, &ib); > DRM_ERROR("radeon: failed to schedule ib (%d).\n", r); > - return r; > + goto free_ib; > } > r = radeon_fence_wait(ib.fence, false); > if (r) { > DRM_ERROR("radeon: fence wait failed (%d).\n", r); > - return r; > + goto free_ib; > } > for (i = 0; i < rdev->usec_timeout; i++) { > tmp = RREG32(scratch); > @@ -2669,8 +2667,10 @@ int r600_ib_test(struct radeon_device *rdev, struct radeon_ring *ring) > scratch, tmp); > r = -EINVAL; > } > - radeon_scratch_free(rdev, scratch); > +free_ib: > radeon_ib_free(rdev, &ib); > +free_scratch: > + radeon_scratch_free(rdev, scratch); > return r; > } > > -- > 1.7.10.4 > > _______________________________________________ > dri-devel mailing list > dri-devel@xxxxxxxxxxxxxxxxxxxxx > http://lists.freedesktop.org/mailman/listinfo/dri-devel _______________________________________________ dri-devel mailing list dri-devel@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/dri-devel