mirror of
https://github.com/torvalds/linux.git
synced 2025-01-01 07:42:07 +00:00
drm/amdgpu: Fix compute ring 1.0.0 failure after reset
Problem: After GPU reset on dGPUs with gfx8 compute ring 1.0.0 fails to pass the ring test. Ring registers inspection shows that it's active and no hang is observed (rptr == wptr) No significant diffs were observed between CP_HQD* registers for the ring in good and bad shape. Fix: No clear reason why but reversing the order of ring tests fixes the problem. Signed-off-by: Andrey Grodzovsky <andrey.grodzovsky@amd.com> Acked-by: Christian König <christian.koenig@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
4faaaa7623
commit
31e3aad62a
@ -4815,8 +4815,10 @@ static int gfx_v8_0_kcq_resume(struct amdgpu_device *adev)
|
|||||||
if (r)
|
if (r)
|
||||||
goto done;
|
goto done;
|
||||||
|
|
||||||
/* Test KCQs */
|
/* Test KCQs - reversing the order of rings seems to fix ring test failure
|
||||||
for (i = 0; i < adev->gfx.num_compute_rings; i++) {
|
* after GPU reset
|
||||||
|
*/
|
||||||
|
for (i = adev->gfx.num_compute_rings - 1; i >= 0; i--) {
|
||||||
ring = &adev->gfx.compute_ring[i];
|
ring = &adev->gfx.compute_ring[i];
|
||||||
ring->ready = true;
|
ring->ready = true;
|
||||||
r = amdgpu_ring_test_ring(ring);
|
r = amdgpu_ring_test_ring(ring);
|
||||||
|
Loading…
Reference in New Issue
Block a user