|
@@ -2638,7 +2638,7 @@ int r600_ib_test(struct radeon_device *rdev, struct radeon_ring *ring)
|
|
r = radeon_ib_get(rdev, ring->idx, &ib, NULL, 256);
|
|
r = radeon_ib_get(rdev, ring->idx, &ib, NULL, 256);
|
|
if (r) {
|
|
if (r) {
|
|
DRM_ERROR("radeon: failed to get ib (%d).\n", 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[0] = PACKET3(PACKET3_SET_CONFIG_REG, 1);
|
|
ib.ptr[1] = ((scratch - PACKET3_SET_CONFIG_REG_OFFSET) >> 2);
|
|
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;
|
|
ib.length_dw = 3;
|
|
r = radeon_ib_schedule(rdev, &ib, NULL);
|
|
r = radeon_ib_schedule(rdev, &ib, NULL);
|
|
if (r) {
|
|
if (r) {
|
|
- radeon_scratch_free(rdev, scratch);
|
|
|
|
- radeon_ib_free(rdev, &ib);
|
|
|
|
DRM_ERROR("radeon: failed to schedule ib (%d).\n", r);
|
|
DRM_ERROR("radeon: failed to schedule ib (%d).\n", r);
|
|
- return r;
|
|
|
|
|
|
+ goto free_ib;
|
|
}
|
|
}
|
|
r = radeon_fence_wait(ib.fence, false);
|
|
r = radeon_fence_wait(ib.fence, false);
|
|
if (r) {
|
|
if (r) {
|
|
DRM_ERROR("radeon: fence wait failed (%d).\n", r);
|
|
DRM_ERROR("radeon: fence wait failed (%d).\n", r);
|
|
- return r;
|
|
|
|
|
|
+ goto free_ib;
|
|
}
|
|
}
|
|
for (i = 0; i < rdev->usec_timeout; i++) {
|
|
for (i = 0; i < rdev->usec_timeout; i++) {
|
|
tmp = RREG32(scratch);
|
|
tmp = RREG32(scratch);
|
|
@@ -2669,8 +2667,10 @@ int r600_ib_test(struct radeon_device *rdev, struct radeon_ring *ring)
|
|
scratch, tmp);
|
|
scratch, tmp);
|
|
r = -EINVAL;
|
|
r = -EINVAL;
|
|
}
|
|
}
|
|
- radeon_scratch_free(rdev, scratch);
|
|
|
|
|
|
+free_ib:
|
|
radeon_ib_free(rdev, &ib);
|
|
radeon_ib_free(rdev, &ib);
|
|
|
|
+free_scratch:
|
|
|
|
+ radeon_scratch_free(rdev, scratch);
|
|
return r;
|
|
return r;
|
|
}
|
|
}
|
|
|
|
|