Making it easier to control when it is executed.
Signed-off-by: Christian König <deathsimple@vodafone.de>
Reviewed-by: Michel Dänzer <michel.daenzer@amd.com>
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
                return r;
        }
 
-       r = radeon_ib_ring_tests(rdev);
-       if (r)
-               return r;
-
        r = r600_audio_init(rdev);
        if (r) {
                DRM_ERROR("radeon: audio init failed\n");
 
                return r;
        }
 
-       r = radeon_ib_ring_tests(rdev);
-       if (r)
-               return r;
-
        r = radeon_vm_manager_init(rdev);
        if (r) {
                dev_err(rdev->dev, "vm manager initialization failed (%d).\n", r);
 
                return r;
        }
 
-       r = radeon_ib_ring_tests(rdev);
-       if (r)
-               return r;
-
        return 0;
 }
 
 
                return r;
        }
 
-       r = radeon_ib_ring_tests(rdev);
-       if (r)
-               return r;
-
        return 0;
 }
 
 
                return r;
        }
 
-       r = radeon_ib_ring_tests(rdev);
-       if (r)
-               return r;
-
        return 0;
 }
 
 
                return r;
        }
 
-       r = radeon_ib_ring_tests(rdev);
-       if (r)
-               return r;
-
        return 0;
 }
 
 
                return r;
        }
 
-       r = radeon_ib_ring_tests(rdev);
-       if (r)
-               return r;
-
        r = r600_audio_init(rdev);
        if (r) {
                DRM_ERROR("radeon: audio init failed\n");
 
        if (r)
                return r;
 
+       r = radeon_ib_ring_tests(rdev);
+       if (r)
+               DRM_ERROR("ib ring test failed (%d).\n", r);
+
        if (rdev->flags & RADEON_IS_AGP && !rdev->accel_working) {
                /* Acceleration not working on AGP card try again
                 * with fallback to PCI or PCIE GART
 {
        struct drm_connector *connector;
        struct radeon_device *rdev = dev->dev_private;
+       int r;
 
        if (dev->switch_power_state == DRM_SWITCH_POWER_OFF)
                return 0;
        /* resume AGP if in use */
        radeon_agp_resume(rdev);
        radeon_resume(rdev);
+
+       r = radeon_ib_ring_tests(rdev);
+       if (r)
+               DRM_ERROR("ib ring test failed (%d).\n", r);
+
        radeon_pm_resume(rdev);
        radeon_restore_bios_scratch_regs(rdev);
 
        if (!r) {
                dev_info(rdev->dev, "GPU reset succeed\n");
                radeon_resume(rdev);
+
+               r = radeon_ib_ring_tests(rdev);
+               if (r)
+                       DRM_ERROR("ib ring test failed (%d).\n", r);
+
                radeon_restore_bios_scratch_regs(rdev);
                drm_helper_resume_force_mode(rdev->ddev);
                ttm_bo_unlock_delayed_workqueue(&rdev->mman.bdev, resched);
 
                return r;
        }
 
-       r = radeon_ib_ring_tests(rdev);
-       if (r)
-               return r;
-
        return 0;
 }
 
 
                return r;
        }
 
-       r = radeon_ib_ring_tests(rdev);
-       if (r)
-               return r;
-
        r = r600_audio_init(rdev);
        if (r) {
                dev_err(rdev->dev, "failed initializing audio\n");
 
                return r;
        }
 
-       r = radeon_ib_ring_tests(rdev);
-       if (r)
-               return r;
-
        r = r600_audio_init(rdev);
        if (r) {
                dev_err(rdev->dev, "failed initializing audio\n");
 
                return r;
        }
 
-       r = radeon_ib_ring_tests(rdev);
-       if (r)
-               return r;
-
        return 0;
 }
 
 
                return r;
        }
 
-       r = radeon_ib_ring_tests(rdev);
-       if (r)
-               return r;
-
        r = r600_audio_init(rdev);
        if (r) {
                DRM_ERROR("radeon: audio init failed\n");
 
                return r;
        }
 
-       r = radeon_ib_test(rdev, RADEON_RING_TYPE_GFX_INDEX, &rdev->ring[RADEON_RING_TYPE_GFX_INDEX]);
-       if (r) {
-               DRM_ERROR("radeon: failed testing IB (%d) on CP ring 0\n", r);
-               rdev->accel_working = false;
-               return r;
-       }
-
-       r = radeon_ib_test(rdev, CAYMAN_RING_TYPE_CP1_INDEX, &rdev->ring[CAYMAN_RING_TYPE_CP1_INDEX]);
-       if (r) {
-               DRM_ERROR("radeon: failed testing IB (%d) on CP ring 1\n", r);
-               rdev->accel_working = false;
-               return r;
-       }
-
-       r = radeon_ib_test(rdev, CAYMAN_RING_TYPE_CP2_INDEX, &rdev->ring[CAYMAN_RING_TYPE_CP2_INDEX]);
-       if (r) {
-               DRM_ERROR("radeon: failed testing IB (%d) on CP ring 2\n", r);
-               rdev->accel_working = false;
-               return r;
-       }
-
        r = radeon_vm_manager_init(rdev);
        if (r) {
                dev_err(rdev->dev, "vm manager initialization failed (%d).\n", r);