drm/i915/gem: Give each object class a friendly name
authorChris Wilson <chris@chris-wilson.co.uk>
Fri, 29 May 2020 18:32:04 +0000 (19:32 +0100)
committerChris Wilson <chris@chris-wilson.co.uk>
Fri, 29 May 2020 22:38:29 +0000 (23:38 +0100)
Name the object classes and their offspring for easier lockdep
debugging.

Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Reviewed-by: Matthew Auld <matthew.auld@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20200529183204.16850-2-chris@chris-wilson.co.uk
14 files changed:
drivers/gpu/drm/i915/gem/i915_gem_dmabuf.c
drivers/gpu/drm/i915/gem/i915_gem_internal.c
drivers/gpu/drm/i915/gem/i915_gem_lmem.c
drivers/gpu/drm/i915/gem/i915_gem_object.c
drivers/gpu/drm/i915/gem/i915_gem_object_types.h
drivers/gpu/drm/i915/gem/i915_gem_phys.c
drivers/gpu/drm/i915/gem/i915_gem_shmem.c
drivers/gpu/drm/i915/gem/i915_gem_stolen.c
drivers/gpu/drm/i915/gem/i915_gem_userptr.c
drivers/gpu/drm/i915/gem/selftests/huge_gem_object.c
drivers/gpu/drm/i915/gem/selftests/huge_pages.c
drivers/gpu/drm/i915/gvt/dmabuf.c
drivers/gpu/drm/i915/selftests/i915_gem_gtt.c
drivers/gpu/drm/i915/selftests/mock_region.c

index 7db5a793739d23ff8e63af767fbbbb8a266b4a94..2679380159fc74f29a1ecf1e991276e55e2dd7db 100644 (file)
@@ -217,6 +217,7 @@ static void i915_gem_object_put_pages_dmabuf(struct drm_i915_gem_object *obj,
 }
 
 static const struct drm_i915_gem_object_ops i915_gem_object_dmabuf_ops = {
+       .name = "i915_gem_object_dmabuf",
        .get_pages = i915_gem_object_get_pages_dmabuf,
        .put_pages = i915_gem_object_put_pages_dmabuf,
 };
index cbbff81aa0affbe2a684dbf11c3528aabccbcd45..ad22f42541bda6944b90ac0ffdd838d423fdea3e 100644 (file)
@@ -137,6 +137,7 @@ static void i915_gem_object_put_pages_internal(struct drm_i915_gem_object *obj,
 }
 
 static const struct drm_i915_gem_object_ops i915_gem_object_internal_ops = {
+       .name = "i915_gem_object_internal",
        .flags = I915_GEM_OBJECT_HAS_STRUCT_PAGE |
                 I915_GEM_OBJECT_IS_SHRINKABLE,
        .get_pages = i915_gem_object_get_pages_internal,
index 70543c83df0630658187b0f96fbdb508bdd1496e..932ee21e6609c61935d94d1e801cf0ef1b92d8f4 100644 (file)
@@ -9,6 +9,7 @@
 #include "i915_drv.h"
 
 const struct drm_i915_gem_object_ops i915_gem_lmem_obj_ops = {
+       .name = "i915_gem_object_lmem",
        .flags = I915_GEM_OBJECT_HAS_IOMEM,
 
        .get_pages = i915_gem_object_get_pages_buddy,
index 21635dd415a33e562b7aeae7a8b81326d163777b..b6ec5b50d93bfacd61c4eccb89c4f256e2c83a01 100644 (file)
@@ -53,7 +53,7 @@ void i915_gem_object_init(struct drm_i915_gem_object *obj,
                          const struct drm_i915_gem_object_ops *ops,
                          struct lock_class_key *key)
 {
-       __mutex_init(&obj->mm.lock, "obj->mm.lock", key);
+       __mutex_init(&obj->mm.lock, ops->name ?: "obj->mm.lock", key);
 
        spin_lock_init(&obj->vma.lock);
        INIT_LIST_HEAD(&obj->vma.list);
index 54ee658bb168b60865ebec9ae0e90976bfeb4c8f..b1f82a11aef289eea39f6c4943d6b764e6a0194c 100644 (file)
@@ -61,6 +61,8 @@ struct drm_i915_gem_object_ops {
 
        int (*dmabuf_export)(struct drm_i915_gem_object *obj);
        void (*release)(struct drm_i915_gem_object *obj);
+
+       const char *name; /* friendly name for debug, e.g. lockdep classes */
 };
 
 enum i915_mmap_type {
index 021c747b5387cec2a30ff081c2ad9956a949bfc4..f4277afb89eb8f92c42672ca6bcae47f961f635e 100644 (file)
@@ -142,6 +142,7 @@ static void phys_release(struct drm_i915_gem_object *obj)
 }
 
 static const struct drm_i915_gem_object_ops i915_gem_phys_ops = {
+       .name = "i915_gem_object_phys",
        .get_pages = i915_gem_object_get_pages_phys,
        .put_pages = i915_gem_object_put_pages_phys,
 
index 7cf8548ff708b95033a5130b971a0986388b889e..38113d3c0138e915f78950f60190aa65d7e6dbde 100644 (file)
@@ -429,6 +429,7 @@ static void shmem_release(struct drm_i915_gem_object *obj)
 }
 
 const struct drm_i915_gem_object_ops i915_gem_shmem_ops = {
+       .name = "i915_gem_object_shmem",
        .flags = I915_GEM_OBJECT_HAS_STRUCT_PAGE |
                 I915_GEM_OBJECT_IS_SHRINKABLE,
 
index dc250278bd2ca90b62ccd57caffc424d6b33ff2f..e0f21f12d3ce4a7bbf9b80b2518e47bd4f956f27 100644 (file)
@@ -566,6 +566,7 @@ i915_gem_object_release_stolen(struct drm_i915_gem_object *obj)
 }
 
 static const struct drm_i915_gem_object_ops i915_gem_object_stolen_ops = {
+       .name = "i915_gem_object_stolen",
        .get_pages = i915_gem_object_get_pages_stolen,
        .put_pages = i915_gem_object_put_pages_stolen,
        .release = i915_gem_object_release_stolen,
index 2226146b01c983f1d622b38c908c49bc740e650d..2adc0ea429fb308f320ff4416b389c673360c09e 100644 (file)
@@ -700,6 +700,7 @@ i915_gem_userptr_dmabuf_export(struct drm_i915_gem_object *obj)
 }
 
 static const struct drm_i915_gem_object_ops i915_gem_userptr_ops = {
+       .name = "i915_gem_object_userptr",
        .flags = I915_GEM_OBJECT_HAS_STRUCT_PAGE |
                 I915_GEM_OBJECT_IS_SHRINKABLE |
                 I915_GEM_OBJECT_NO_MMAP |
index 2b46c6530da9eb3b55ed42b6d97351b47165905d..a768ec61e966326302eaea9d656d49f7022f06c8 100644 (file)
@@ -88,6 +88,7 @@ static void huge_put_pages(struct drm_i915_gem_object *obj,
 }
 
 static const struct drm_i915_gem_object_ops huge_ops = {
+       .name = "huge-gem",
        .flags = I915_GEM_OBJECT_HAS_STRUCT_PAGE,
        .get_pages = huge_get_pages,
        .put_pages = huge_put_pages,
index a0ed2fab0ff319a9015e537a1a3f08e6982f43f4..8291ede6902c47ead8720601c30b0ea6626f18e7 100644 (file)
@@ -139,6 +139,7 @@ static void put_huge_pages(struct drm_i915_gem_object *obj,
 }
 
 static const struct drm_i915_gem_object_ops huge_page_ops = {
+       .name = "huge-gem",
        .flags = I915_GEM_OBJECT_HAS_STRUCT_PAGE |
                 I915_GEM_OBJECT_IS_SHRINKABLE,
        .get_pages = get_huge_pages,
@@ -283,12 +284,14 @@ static void fake_put_huge_pages(struct drm_i915_gem_object *obj,
 }
 
 static const struct drm_i915_gem_object_ops fake_ops = {
+       .name = "fake-gem",
        .flags = I915_GEM_OBJECT_IS_SHRINKABLE,
        .get_pages = fake_get_huge_pages,
        .put_pages = fake_put_huge_pages,
 };
 
 static const struct drm_i915_gem_object_ops fake_ops_single = {
+       .name = "fake-gem",
        .flags = I915_GEM_OBJECT_IS_SHRINKABLE,
        .get_pages = fake_get_huge_pages_single,
        .put_pages = fake_put_huge_pages,
index 37fc460414a8f82689c92138ebd85fdc5a7e1666..c3eb3838fe8868e05fe4953f74021e1c2359232b 100644 (file)
@@ -198,6 +198,7 @@ static void vgpu_gem_release(struct drm_i915_gem_object *gem_obj)
 }
 
 static const struct drm_i915_gem_object_ops intel_vgpu_gem_ops = {
+       .name = "i915_gem_object_vgpu",
        .flags = I915_GEM_OBJECT_IS_PROXY,
        .get_pages = vgpu_gem_get_pages,
        .put_pages = vgpu_gem_put_pages,
index 2e471500a64632f20d1cf5f5f006ef8139918519..0016ffc7d914732387ee81de8f3b8287a5a938a9 100644 (file)
@@ -97,6 +97,7 @@ static void fake_put_pages(struct drm_i915_gem_object *obj,
 }
 
 static const struct drm_i915_gem_object_ops fake_ops = {
+       .name = "fake-gem",
        .flags = I915_GEM_OBJECT_IS_SHRINKABLE,
        .get_pages = fake_get_pages,
        .put_pages = fake_put_pages,
index b2ad41c27e67644db8c8ca20ac69c4eda991f45a..09660f5a0a4c9f6f4c0172662a209137ee473c03 100644 (file)
@@ -9,6 +9,7 @@
 #include "mock_region.h"
 
 static const struct drm_i915_gem_object_ops mock_region_obj_ops = {
+       .name = "mock-region",
        .get_pages = i915_gem_object_get_pages_buddy,
        .put_pages = i915_gem_object_put_pages_buddy,
        .release = i915_gem_object_release_memory_region,