]> www.infradead.org Git - users/hch/configfs.git/commitdiff
drm/amdgpu: skip kfd init if GFX is not ready.
authorYifan Zhang <yifan1.zhang@amd.com>
Thu, 18 Jul 2024 05:18:53 +0000 (13:18 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 24 Jul 2024 18:43:58 +0000 (14:43 -0400)
avoid kfd init crash in that case.

Signed-off-by: Yifan Zhang <yifan1.zhang@amd.com>
Acked-by: Alex Deucher <alexander.deucher@amd.com>
Tested-by: Jesse Zhang <Jesse.Zhang@amd.com>
Reviewed-by: Jesse Zhang <Jesse.Zhang@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_device.c

index bcacf2e35eba08e8829b2c7ceaf0bef39c6d06a8..730dae77570c415a661017476bfc0bdf1943af99 100644 (file)
@@ -2471,6 +2471,7 @@ out:
  */
 static int amdgpu_device_ip_early_init(struct amdgpu_device *adev)
 {
+       struct amdgpu_ip_block *ip_block;
        struct pci_dev *parent;
        int i, r;
        bool total;
@@ -2608,7 +2609,10 @@ static int amdgpu_device_ip_early_init(struct amdgpu_device *adev)
        if (!total)
                return -ENODEV;
 
-       amdgpu_amdkfd_device_probe(adev);
+       ip_block = amdgpu_device_ip_get_ip_block(adev, AMD_IP_BLOCK_TYPE_GFX);
+       if (ip_block->status.valid != false)
+               amdgpu_amdkfd_device_probe(adev);
+
        adev->cg_flags &= amdgpu_cg_mask;
        adev->pg_flags &= amdgpu_pg_mask;