drm/amdgpu: Add stolen reserved memory for MI25 SRIOV.
authorYongqiang Sun <yongqiang.sun@amd.com>
Tue, 15 Mar 2022 13:43:41 +0000 (09:43 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Tue, 15 Mar 2022 19:01:12 +0000 (15:01 -0400)
MI25 SRIOV guest driver loading failed due to allocated memory overlaps
with firmware reserved area.
Allocate stolen reserved memory for MI25 SRIOV specifically to avoid the
memory overlap.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Yongqiang Sun <yongqiang.sun@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.c

index a25ae3b..ca2cfb6 100644 (file)
@@ -639,6 +639,15 @@ void amdgpu_gmc_get_vbios_allocations(struct amdgpu_device *adev)
         */
        switch (adev->asic_type) {
        case CHIP_VEGA10:
+               adev->mman.keep_stolen_vga_memory = true;
+               /*
+                * VEGA10 SRIOV VF needs some firmware reserved area.
+                */
+               if (amdgpu_sriov_vf(adev)) {
+                       adev->mman.stolen_reserved_offset = 0x100000;
+                       adev->mman.stolen_reserved_size = 0x600000;
+               }
+               break;
        case CHIP_RAVEN:
        case CHIP_RENOIR:
                adev->mman.keep_stolen_vga_memory = true;