drm/amdgpu: skip amdgpu_device_cache_pci_state under sriov
authorVictor Zhao <Victor.Zhao@amd.com>
Thu, 24 Oct 2024 05:40:39 +0000 (13:40 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Mon, 4 Nov 2024 17:05:30 +0000 (12:05 -0500)
Under sriov, host driver will save and restore vf pci cfg space during
reset. And during device init, under sriov, pci_restore_state happens after
fullaccess released, and it can have race condition with mmio protection
enable from host side leading to missing interrupts.

So skip amdgpu_device_cache_pci_state for sriov.

Signed-off-by: Victor Zhao <Victor.Zhao@amd.com>
Acked-by: Lijo Lazar <lijo.lazar@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_device.c

index a7b55d6..d97417c 100644 (file)
@@ -6451,6 +6451,9 @@ bool amdgpu_device_cache_pci_state(struct pci_dev *pdev)
        struct amdgpu_device *adev = drm_to_adev(dev);
        int r;
 
+       if (amdgpu_sriov_vf(adev))
+               return false;
+
        r = pci_save_state(pdev);
        if (!r) {
                kfree(adev->pci_state);