From: Abdiel Janulgue <abdiel.janul...@linux.intel.com>

Nothing to enumerate yet...

Signed-off-by: Abdiel Janulgue <abdiel.janul...@linux.intel.com>
Signed-off-by: Matthew Auld <matthew.a...@intel.com>
Cc: Joonas Lahtinen <joonas.lahti...@linux.intel.com>
---
 drivers/gpu/drm/i915/i915_gem_gtt.c | 73 ++++++++++++++++++++++++++---
 1 file changed, 67 insertions(+), 6 deletions(-)

diff --git a/drivers/gpu/drm/i915/i915_gem_gtt.c 
b/drivers/gpu/drm/i915/i915_gem_gtt.c
index 045c6715d5a6..e0a8e90b1480 100644
--- a/drivers/gpu/drm/i915/i915_gem_gtt.c
+++ b/drivers/gpu/drm/i915/i915_gem_gtt.c
@@ -2798,6 +2798,71 @@ int i915_gem_init_ggtt(struct drm_i915_private *dev_priv)
        return ret;
 }
 
+static void i915_gem_cleanup_memory_regions(struct drm_i915_private *i915)
+{
+       int i;
+
+       i915_gem_cleanup_stolen(i915);
+
+       for (i = 0; i < ARRAY_SIZE(i915->regions); ++i) {
+               struct intel_memory_region *region = i915->regions[i];
+
+               if (region)
+                       intel_memory_region_destroy(region);
+       }
+}
+
+static int i915_gem_init_memory_regions(struct drm_i915_private *i915)
+{
+       int err, i;
+
+       /* All platforms currently have system memory */
+       GEM_BUG_ON(!HAS_REGION(i915, REGION_SMEM));
+
+       /*
+        * Initialise stolen early so that we may reserve preallocated
+        * objects for the BIOS to KMS transition.
+        */
+       /* XXX: stolen will become a region at some point */
+       err = i915_gem_init_stolen(i915);
+       if (err)
+               return err;
+
+       for (i = 0; i < ARRAY_SIZE(intel_region_map); i++) {
+               struct intel_memory_region *mem = NULL;
+               u32 type;
+
+               if (!HAS_REGION(i915, BIT(i)))
+                       continue;
+
+               type = MEMORY_TYPE_FROM_REGION(intel_region_map[i]);
+               switch (type) {
+               default:
+                       break;
+               }
+
+               if (IS_ERR(mem)) {
+                       err = PTR_ERR(mem);
+                       DRM_ERROR("Failed to setup region(%d) type=%d\n", err, 
type);
+                       goto out_cleanup;
+               }
+
+               if (mem) {
+                       mem->id = intel_region_map[i];
+                       mem->type = type;
+                       mem->instance = 
MEMORY_INSTANCE_FROM_REGION(intel_region_map[i]);
+               }
+
+               i915->regions[i] = mem;
+       }
+
+       return 0;
+
+out_cleanup:
+       i915_gem_cleanup_memory_regions(i915);
+       return err;
+}
+
 /**
  * i915_ggtt_cleanup_hw - Clean up GGTT hardware initialization
  * @dev_priv: i915 device
@@ -2839,7 +2904,7 @@ void i915_ggtt_cleanup_hw(struct drm_i915_private 
*dev_priv)
                io_mapping_fini(&ggtt->iomap);
        }
 
-       i915_gem_cleanup_stolen(dev_priv);
+       i915_gem_cleanup_memory_regions(dev_priv);
 }
 
 static unsigned int gen6_get_total_gtt_size(u16 snb_gmch_ctl)
@@ -3474,11 +3539,7 @@ int i915_ggtt_init_hw(struct drm_i915_private *dev_priv)
                                              ggtt->mappable_end);
        }
 
-       /*
-        * Initialise stolen early so that we may reserve preallocated
-        * objects for the BIOS to KMS transition.
-        */
-       ret = i915_gem_init_stolen(dev_priv);
+       ret = i915_gem_init_memory_regions(dev_priv);
        if (ret)
                goto out_gtt_cleanup;
 
-- 
2.20.1

_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx

Reply via email to