drm/i915: Split memory_region initialisation into its own file
authorChris Wilson <chris@chris-wilson.co.uk>
Sat, 26 Oct 2019 20:20:32 +0000 (21:20 +0100)
committerChris Wilson <chris@chris-wilson.co.uk>
Sat, 26 Oct 2019 21:25:34 +0000 (22:25 +0100)
Pull the memory region bookkeeping into its file. Let's start clean and
see how long it lasts!

Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Matthew Auld <matthew.auld@intel.com>
Reviewed-by: Matthew Auld <matthew.auld@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20191026202032.4371-1-chris@chris-wilson.co.uk
drivers/gpu/drm/i915/i915_drv.c
drivers/gpu/drm/i915/i915_drv.h
drivers/gpu/drm/i915/i915_gem_gtt.c
drivers/gpu/drm/i915/intel_memory_region.c
drivers/gpu/drm/i915/intel_memory_region.h
drivers/gpu/drm/i915/selftests/mock_gem_device.c

index 355526a..21273b5 100644 (file)
@@ -76,6 +76,7 @@
 #include "i915_trace.h"
 #include "i915_vgpu.h"
 #include "intel_csr.h"
+#include "intel_memory_region.h"
 #include "intel_pm.h"
 
 static struct drm_driver driver;
@@ -1172,12 +1173,16 @@ static int i915_driver_hw_probe(struct drm_i915_private *dev_priv)
        if (ret)
                goto err_ggtt;
 
+       ret = intel_memory_regions_hw_probe(dev_priv);
+       if (ret)
+               goto err_ggtt;
+
        intel_gt_init_hw_early(dev_priv);
 
        ret = i915_ggtt_enable_hw(dev_priv);
        if (ret) {
                DRM_ERROR("failed to enable GGTT\n");
-               goto err_ggtt;
+               goto err_mem_regions;
        }
 
        pci_set_master(pdev);
@@ -1194,7 +1199,7 @@ static int i915_driver_hw_probe(struct drm_i915_private *dev_priv)
                if (ret) {
                        DRM_ERROR("failed to set DMA mask\n");
 
-                       goto err_ggtt;
+                       goto err_mem_regions;
                }
        }
 
@@ -1212,7 +1217,7 @@ static int i915_driver_hw_probe(struct drm_i915_private *dev_priv)
                if (ret) {
                        DRM_ERROR("failed to set DMA mask\n");
 
-                       goto err_ggtt;
+                       goto err_mem_regions;
                }
        }
 
@@ -1264,6 +1269,8 @@ err_msi:
        if (pdev->msi_enabled)
                pci_disable_msi(pdev);
        pm_qos_remove_request(&dev_priv->pm_qos);
+err_mem_regions:
+       intel_memory_regions_driver_release(dev_priv);
 err_ggtt:
        i915_ggtt_driver_release(dev_priv);
 err_perf:
@@ -1510,6 +1517,7 @@ int i915_driver_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
 
 out_cleanup_hw:
        i915_driver_hw_remove(dev_priv);
+       intel_memory_regions_driver_release(dev_priv);
        i915_ggtt_driver_release(dev_priv);
 out_cleanup_mmio:
        i915_driver_mmio_release(dev_priv);
@@ -1567,6 +1575,7 @@ static void i915_driver_release(struct drm_device *dev)
 
        i915_gem_driver_release(dev_priv);
 
+       intel_memory_regions_driver_release(dev_priv);
        i915_ggtt_driver_release(dev_priv);
 
        i915_driver_mmio_release(dev_priv);
index 96fe0e8..a22d969 100644 (file)
@@ -1916,9 +1916,6 @@ int __must_check i915_gem_evict_for_node(struct i915_address_space *vm,
                                         unsigned int flags);
 int i915_gem_evict_vm(struct i915_address_space *vm);
 
-void i915_gem_cleanup_memory_regions(struct drm_i915_private *i915);
-int i915_gem_init_memory_regions(struct drm_i915_private *i915);
-
 /* i915_gem_internal.c */
 struct drm_i915_gem_object *
 i915_gem_object_create_internal(struct drm_i915_private *dev_priv,
index 3d3a8db..eebc7fe 100644 (file)
@@ -2744,59 +2744,6 @@ int i915_init_ggtt(struct drm_i915_private *i915)
        return 0;
 }
 
-void i915_gem_cleanup_memory_regions(struct drm_i915_private *i915)
-{
-       int i;
-
-       for (i = 0; i < INTEL_REGION_UNKNOWN; i++) {
-               struct intel_memory_region *region = i915->mm.regions[i];
-
-               if (region)
-                       intel_memory_region_put(region);
-       }
-}
-
-int i915_gem_init_memory_regions(struct drm_i915_private *i915)
-{
-       int err, i;
-
-       for (i = 0; i < INTEL_REGION_UNKNOWN; i++) {
-               struct intel_memory_region *mem = ERR_PTR(-ENODEV);
-               u32 type;
-
-               if (!HAS_REGION(i915, BIT(i)))
-                       continue;
-
-               type = MEMORY_TYPE_FROM_REGION(intel_region_map[i]);
-               switch (type) {
-               case INTEL_MEMORY_SYSTEM:
-                       mem = i915_gem_shmem_setup(i915);
-                       break;
-               case INTEL_MEMORY_STOLEN:
-                       mem = i915_gem_stolen_setup(i915);
-                       break;
-               }
-
-               if (IS_ERR(mem)) {
-                       err = PTR_ERR(mem);
-                       DRM_ERROR("Failed to setup region(%d) type=%d\n", err, type);
-                       goto out_cleanup;
-               }
-
-               mem->id = intel_region_map[i];
-               mem->type = type;
-               mem->instance = MEMORY_INSTANCE_FROM_REGION(intel_region_map[i]);
-
-               i915->mm.regions[i] = mem;
-       }
-
-       return 0;
-
-out_cleanup:
-       i915_gem_cleanup_memory_regions(i915);
-       return err;
-}
-
 static void ggtt_cleanup_hw(struct i915_ggtt *ggtt)
 {
        struct i915_vma *vma, *vn;
@@ -2834,8 +2781,6 @@ void i915_ggtt_driver_release(struct drm_i915_private *i915)
 {
        struct pagevec *pvec;
 
-       i915_gem_cleanup_memory_regions(i915);
-
        fini_aliasing_ppgtt(&i915->ggtt);
 
        ggtt_cleanup_hw(&i915->ggtt);
@@ -3311,15 +3256,7 @@ int i915_ggtt_init_hw(struct drm_i915_private *dev_priv)
        if (ret)
                return ret;
 
-       ret = i915_gem_init_memory_regions(dev_priv);
-       if (ret)
-               goto out_gtt_cleanup;
-
        return 0;
-
-out_gtt_cleanup:
-       dev_priv->ggtt.vm.cleanup(&dev_priv->ggtt.vm);
-       return ret;
 }
 
 int i915_ggtt_enable_hw(struct drm_i915_private *dev_priv)
index 72f98a1..a60f77f 100644 (file)
@@ -207,6 +207,62 @@ void intel_memory_region_put(struct intel_memory_region *mem)
        kref_put(&mem->kref, __intel_memory_region_destroy);
 }
 
+/* Global memory region registration -- only slight layer inversions! */
+
+int intel_memory_regions_hw_probe(struct drm_i915_private *i915)
+{
+       int err, i;
+
+       for (i = 0; i < ARRAY_SIZE(i915->mm.regions); i++) {
+               struct intel_memory_region *mem = ERR_PTR(-ENODEV);
+               u32 type;
+
+               if (!HAS_REGION(i915, BIT(i)))
+                       continue;
+
+               type = MEMORY_TYPE_FROM_REGION(intel_region_map[i]);
+               switch (type) {
+               case INTEL_MEMORY_SYSTEM:
+                       mem = i915_gem_shmem_setup(i915);
+                       break;
+               case INTEL_MEMORY_STOLEN:
+                       mem = i915_gem_stolen_setup(i915);
+                       break;
+               }
+
+               if (IS_ERR(mem)) {
+                       err = PTR_ERR(mem);
+                       DRM_ERROR("Failed to setup region(%d) type=%d\n", err, type);
+                       goto out_cleanup;
+               }
+
+               mem->id = intel_region_map[i];
+               mem->type = type;
+               mem->instance = MEMORY_INSTANCE_FROM_REGION(intel_region_map[i]);
+
+               i915->mm.regions[i] = mem;
+       }
+
+       return 0;
+
+out_cleanup:
+       intel_memory_regions_driver_release(i915);
+       return err;
+}
+
+void intel_memory_regions_driver_release(struct drm_i915_private *i915)
+{
+       int i;
+
+       for (i = 0; i < ARRAY_SIZE(i915->mm.regions); i++) {
+               struct intel_memory_region *region =
+                       fetch_and_zero(&i915->mm.regions[i]);
+
+               if (region)
+                       intel_memory_region_put(region);
+       }
+}
+
 #if IS_ENABLED(CONFIG_DRM_I915_SELFTEST)
 #include "selftests/intel_memory_region.c"
 #include "selftests/mock_region.c"
index 49b059a..19920c2 100644 (file)
@@ -117,4 +117,7 @@ struct intel_memory_region *
 intel_memory_region_get(struct intel_memory_region *mem);
 void intel_memory_region_put(struct intel_memory_region *mem);
 
+int intel_memory_regions_hw_probe(struct drm_i915_private *i915);
+void intel_memory_regions_driver_release(struct drm_i915_private *i915);
+
 #endif
index c2f5775..a0da594 100644 (file)
@@ -28,6 +28,7 @@
 #include "gt/intel_gt.h"
 #include "gt/intel_gt_requests.h"
 #include "gt/mock_engine.h"
+#include "intel_memory_region.h"
 
 #include "mock_request.h"
 #include "mock_gem_device.h"
@@ -72,7 +73,7 @@ static void mock_device_release(struct drm_device *dev)
        mock_fini_ggtt(&i915->ggtt);
        destroy_workqueue(i915->wq);
 
-       i915_gem_cleanup_memory_regions(i915);
+       intel_memory_regions_driver_release(i915);
 
        drm_mode_config_cleanup(&i915->drm);
 
@@ -164,6 +165,7 @@ struct drm_i915_private *mock_gem_device(void)
                I915_GTT_PAGE_SIZE_2M;
 
        mkwrite_device_info(i915)->memory_regions = REGION_SMEM;
+       intel_memory_regions_hw_probe(i915);
 
        mock_uncore_init(&i915->uncore, i915);
 
@@ -198,10 +200,6 @@ struct drm_i915_private *mock_gem_device(void)
 
        intel_engines_driver_register(i915);
 
-       err = i915_gem_init_memory_regions(i915);
-       if (err)
-               goto err_context;
-
        return i915;
 
 err_context:
@@ -212,6 +210,7 @@ err_unlock:
        intel_timelines_fini(i915);
        destroy_workqueue(i915->wq);
 err_drv:
+       intel_memory_regions_driver_release(i915);
        drm_mode_config_cleanup(&i915->drm);
        drm_dev_fini(&i915->drm);
 put_device: