]> git.baikalelectronics.ru Git - kernel.git/commitdiff
drm/amdgpu: Avoid accidental thread reactivation.
authorAndrey Grodzovsky <andrey.grodzovsky@amd.com>
Wed, 6 Nov 2019 17:36:29 +0000 (12:36 -0500)
committerAlex Deucher <alexander.deucher@amd.com>
Thu, 7 Nov 2019 23:08:07 +0000 (18:08 -0500)
Problem:
During GPU reset we call the GPU scheduler to suspend it's
thread, those two functions in amdgpu also suspend and resume
the sceduler for their needs but this can collide with GPU
reset in progress and accidently restart a suspended thread
before time.

Fix:
Serialize with GPU reset.

Signed-off-by: Andrey Grodzovsky <andrey.grodzovsky@amd.com>
Reviewed-by: Christian König <christian.koenig@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c

index 693f17e787914b493f028b43621457e4ec7189f4..8e6726e0d035fa261c2bc8e8cf9de6fe61f8c061 100644 (file)
@@ -859,6 +859,9 @@ static int amdgpu_debugfs_test_ib(struct seq_file *m, void *data)
        struct amdgpu_device *adev = dev->dev_private;
        int r = 0, i;
 
+       /* Avoid accidently unparking the sched thread during GPU reset */
+       mutex_lock(&adev->lock_reset);
+
        /* hold on the scheduler */
        for (i = 0; i < AMDGPU_MAX_RINGS; i++) {
                struct amdgpu_ring *ring = adev->rings[i];
@@ -884,6 +887,8 @@ static int amdgpu_debugfs_test_ib(struct seq_file *m, void *data)
                kthread_unpark(ring->sched.thread);
        }
 
+       mutex_unlock(&adev->lock_reset);
+
        return 0;
 }
 
@@ -1036,6 +1041,9 @@ static int amdgpu_debugfs_ib_preempt(void *data, u64 val)
        if (!fences)
                return -ENOMEM;
 
+       /* Avoid accidently unparking the sched thread during GPU reset */
+       mutex_lock(&adev->lock_reset);
+
        /* stop the scheduler */
        kthread_park(ring->sched.thread);
 
@@ -1075,6 +1083,8 @@ failure:
        /* restart the scheduler */
        kthread_unpark(ring->sched.thread);
 
+       mutex_unlock(&adev->lock_reset);
+
        ttm_bo_unlock_delayed_workqueue(&adev->mman.bdev, resched);
 
        kfree(fences);