[Public]

Ping...

Regards,
Guchun

-----Original Message-----
From: Chen, Guchun <guchun.c...@amd.com> 
Sent: Saturday, September 18, 2021 2:09 PM
To: amd-gfx@lists.freedesktop.org; Koenig, Christian 
<christian.koe...@amd.com>; Pan, Xinhui <xinhui....@amd.com>; Deucher, 
Alexander <alexander.deuc...@amd.com>; Grodzovsky, Andrey 
<andrey.grodzov...@amd.com>; Liu, Monk <monk....@amd.com>
Cc: Chen, Guchun <guchun.c...@amd.com>; Shi, Leslie <yuliang....@amd.com>
Subject: [PATCH] drm/amdgpu: move amdgpu_virt_release_full_gpu to fini_early 
stage

adev->rmmio is set to be NULL in amdgpu_device_unmap_mmio to prevent
access after pci_remove, however, in SRIOV case, amdgpu_virt_release_full_gpu 
will still use adev->rmmio for access after amdgpu_device_unmap_mmio.
The patch is to move such SRIOV calling earlier to fini_early stage.

Fixes: 07775fc13878("drm/amdgpu: Unmap all MMIO mappings")
Cc: Andrey Grodzovsky <andrey.grodzov...@amd.com>
Signed-off-by: Leslie Shi <yuliang....@amd.com>
Signed-off-by: Guchun Chen <guchun.c...@amd.com>
---
 drivers/gpu/drm/amd/amdgpu/amdgpu_device.c | 9 +++++----
 1 file changed, 5 insertions(+), 4 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c 
b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
index f3da97086f7d..2a75c09c4884 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
@@ -2810,6 +2810,11 @@ static int amdgpu_device_ip_fini_early(struct 
amdgpu_device *adev)
                adev->ip_blocks[i].status.hw = false;
        }
 
+       if (amdgpu_sriov_vf(adev)) {
+               if (amdgpu_virt_release_full_gpu(adev, false))
+                       DRM_ERROR("failed to release exclusive mode on fini\n");
+       }
+
        return 0;
 }
 
@@ -2870,10 +2875,6 @@ static int amdgpu_device_ip_fini(struct amdgpu_device 
*adev)
 
        amdgpu_ras_fini(adev);
 
-       if (amdgpu_sriov_vf(adev))
-               if (amdgpu_virt_release_full_gpu(adev, false))
-                       DRM_ERROR("failed to release exclusive mode on fini\n");
-
        return 0;
 }
 
--
2.17.1

Reply via email to