Add a function which groups filling of reserve region information. It
may not cover all as info on some regions are still filled outside like
those from atomfirmware tables.

Signed-off-by: Lijo Lazar <[email protected]>
---
 drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.c |  5 +++-
 drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.h |  2 +-
 drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c | 39 +++++++++++++------------
 drivers/gpu/drm/amd/amdgpu/gmc_v10_0.c  |  2 --
 drivers/gpu/drm/amd/amdgpu/gmc_v11_0.c  |  2 --
 drivers/gpu/drm/amd/amdgpu/gmc_v12_0.c  |  2 --
 drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c   |  2 --
 drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c   |  2 --
 drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c   |  2 --
 drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c   |  2 --
 10 files changed, 26 insertions(+), 34 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.c 
b/drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.c
index 2bbed5fe5121..18e459957041 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.c
@@ -1032,10 +1032,13 @@ void amdgpu_gmc_set_vm_fault_masks(struct amdgpu_device 
*adev, int hub_type,
        }
 }
 
-void amdgpu_gmc_get_vbios_allocations(struct amdgpu_device *adev)
+void amdgpu_gmc_init_vga_resv_regions(struct amdgpu_device *adev)
 {
        unsigned size;
 
+       if (adev->gmc.is_app_apu)
+               return;
+
        /*
         * Some ASICs need to reserve a region of video memory to avoid access
         * from driver
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.h 
b/drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.h
index b9fdc3276e81..7c5fffbbce35 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.h
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.h
@@ -456,7 +456,7 @@ extern void
 amdgpu_gmc_set_vm_fault_masks(struct amdgpu_device *adev, int hub_type,
                              bool enable);
 
-void amdgpu_gmc_get_vbios_allocations(struct amdgpu_device *adev);
+void amdgpu_gmc_init_vga_resv_regions(struct amdgpu_device *adev);
 
 void amdgpu_gmc_init_pdb0(struct amdgpu_device *adev);
 uint64_t amdgpu_gmc_vram_mc2pa(struct amdgpu_device *adev, uint64_t mc_addr);
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c 
b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
index 3c1b03d3625a..d5bd6f1a307f 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
@@ -1693,6 +1693,16 @@ void amdgpu_ttm_init_vram_resv(struct amdgpu_device 
*adev,
        resv->needs_cpu_map = needs_cpu_map;
 }
 
+static void amdgpu_ttm_init_vram_resv_regions(struct amdgpu_device *adev)
+{
+       /* Initialize memory reservations as required for VGA.
+        * This is used for VGA emulation and pre-OS scanout buffers to
+        * avoid display artifacts while transitioning between pre-OS
+        * and driver.
+        */
+       amdgpu_gmc_init_vga_resv_regions(adev);
+}
+
 int amdgpu_ttm_mark_vram_reserved(struct amdgpu_device *adev,
                                  enum amdgpu_resv_region_id id)
 {
@@ -2093,6 +2103,8 @@ int amdgpu_ttm_init(struct amdgpu_device *adev)
                                adev->gmc.visible_vram_size);
 #endif
 
+       amdgpu_ttm_init_vram_resv_regions(adev);
+
        /*
         *The reserved vram for firmware must be pinned to the specified
         *place on the VRAM, so reserve it early.
@@ -2130,26 +2142,17 @@ int amdgpu_ttm_init(struct amdgpu_device *adev)
                        return r;
        }
 
-       /* allocate memory as required for VGA
-        * This is used for VGA emulation and pre-OS scanout buffers to
-        * avoid display artifacts while transitioning between pre-OS
-        * and driver.
-        */
-       if (!adev->gmc.is_app_apu) {
-               r = amdgpu_ttm_mark_vram_reserved(adev, AMDGPU_RESV_STOLEN_VGA);
-               if (r)
-                       return r;
+       r = amdgpu_ttm_mark_vram_reserved(adev, AMDGPU_RESV_STOLEN_VGA);
+       if (r)
+               return r;
 
-               r = amdgpu_ttm_mark_vram_reserved(adev, 
AMDGPU_RESV_STOLEN_EXTENDED);
-               if (r)
-                       return r;
+       r = amdgpu_ttm_mark_vram_reserved(adev, AMDGPU_RESV_STOLEN_EXTENDED);
+       if (r)
+               return r;
 
-               r = amdgpu_ttm_mark_vram_reserved(adev, 
AMDGPU_RESV_STOLEN_RESERVED);
-               if (r)
-                       return r;
-       } else {
-               DRM_DEBUG_DRIVER("Skipped stolen memory reservation\n");
-       }
+       r = amdgpu_ttm_mark_vram_reserved(adev, AMDGPU_RESV_STOLEN_RESERVED);
+       if (r)
+               return r;
 
        dev_info(adev->dev, " %uM of VRAM memory ready\n",
                 (unsigned int)(adev->gmc.real_vram_size / (1024 * 1024)));
diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v10_0.c 
b/drivers/gpu/drm/amd/amdgpu/gmc_v10_0.c
index 2568eeaae945..039d52799357 100644
--- a/drivers/gpu/drm/amd/amdgpu/gmc_v10_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/gmc_v10_0.c
@@ -860,8 +860,6 @@ static int gmc_v10_0_sw_init(struct amdgpu_ip_block 
*ip_block)
        if (r)
                return r;
 
-       amdgpu_gmc_get_vbios_allocations(adev);
-
        /* Memory manager */
        r = amdgpu_bo_init(adev);
        if (r)
diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v11_0.c 
b/drivers/gpu/drm/amd/amdgpu/gmc_v11_0.c
index 6349e239a367..fcf48e19d857 100644
--- a/drivers/gpu/drm/amd/amdgpu/gmc_v11_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/gmc_v11_0.c
@@ -834,8 +834,6 @@ static int gmc_v11_0_sw_init(struct amdgpu_ip_block 
*ip_block)
        if (r)
                return r;
 
-       amdgpu_gmc_get_vbios_allocations(adev);
-
        /* Memory manager */
        r = amdgpu_bo_init(adev);
        if (r)
diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v12_0.c 
b/drivers/gpu/drm/amd/amdgpu/gmc_v12_0.c
index f1079bd8cf00..577b3c68fb6b 100644
--- a/drivers/gpu/drm/amd/amdgpu/gmc_v12_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/gmc_v12_0.c
@@ -924,8 +924,6 @@ static int gmc_v12_0_sw_init(struct amdgpu_ip_block 
*ip_block)
        if (r)
                return r;
 
-       amdgpu_gmc_get_vbios_allocations(adev);
-
 #ifdef HAVE_ACPI_DEV_GET_FIRST_MATCH_DEV
        if (amdgpu_ip_version(adev, GC_HWIP, 0) == IP_VERSION(12, 1, 0)) {
                r = amdgpu_gmc_init_mem_ranges(adev);
diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c 
b/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c
index 886bf77309a5..cc272a96fcef 100644
--- a/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c
@@ -854,8 +854,6 @@ static int gmc_v6_0_sw_init(struct amdgpu_ip_block 
*ip_block)
        if (r)
                return r;
 
-       amdgpu_gmc_get_vbios_allocations(adev);
-
        r = amdgpu_bo_init(adev);
        if (r)
                return r;
diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c 
b/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c
index b2e87d3aa203..fb5e33c8a5ee 100644
--- a/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c
@@ -1034,8 +1034,6 @@ static int gmc_v7_0_sw_init(struct amdgpu_ip_block 
*ip_block)
        if (r)
                return r;
 
-       amdgpu_gmc_get_vbios_allocations(adev);
-
        /* Memory manager */
        r = amdgpu_bo_init(adev);
        if (r)
diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c 
b/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c
index 1d5bd90ac57f..963d5b0fa87b 100644
--- a/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c
@@ -1149,8 +1149,6 @@ static int gmc_v8_0_sw_init(struct amdgpu_ip_block 
*ip_block)
        if (r)
                return r;
 
-       amdgpu_gmc_get_vbios_allocations(adev);
-
        /* Memory manager */
        r = amdgpu_bo_init(adev);
        if (r)
diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c 
b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
index 1ca0202cfdea..e64a25f7d713 100644
--- a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
@@ -2004,8 +2004,6 @@ static int gmc_v9_0_sw_init(struct amdgpu_ip_block 
*ip_block)
        if (r)
                return r;
 
-       amdgpu_gmc_get_vbios_allocations(adev);
-
        if (amdgpu_is_multi_aid(adev)) {
                r = amdgpu_gmc_init_mem_ranges(adev);
                if (r)
-- 
2.49.0

Reply via email to