]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/xe/bo: add some annotations in bo_put()
authorMatthew Auld <matthew.auld@intel.com>
Wed, 11 Sep 2024 15:55:30 +0000 (16:55 +0100)
committerLucas De Marchi <lucas.demarchi@intel.com>
Wed, 18 Sep 2024 04:31:06 +0000 (23:31 -0500)
If the put() triggers bo destroy then there is at least one potential
sleeping lock. Also annotate bos_lock and ggtt lock.

Signed-off-by: Matthew Auld <matthew.auld@intel.com>
Cc: Himal Prasad Ghimiray <himal.prasad.ghimiray@intel.com>
Cc: Tejas Upadhyay <tejas.upadhyay@intel.com>
Cc: "Thomas Hellström" <thomas.hellstrom@linux.intel.com>
Reviewed-by: Matthew Brost <matthew.brost@intel.com>
Reviewed-by: Tejas Upadhyay <tejas.upadhyay@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240911155527.178910-8-matthew.auld@intel.com
(cherry picked from commit 3b04c2cfd71c54117237c72f2a08ff0ae1f602e2)
Signed-off-by: Lucas De Marchi <lucas.demarchi@intel.com>
drivers/gpu/drm/xe/xe_bo.c
drivers/gpu/drm/xe/xe_bo.h

index 06911e9a3bf5199549da2e4063022f92a322cc84..f379df3a12bfa0c29e189c905bce39cf52ac0e67 100644 (file)
@@ -2320,6 +2320,20 @@ void xe_bo_put_commit(struct llist_head *deferred)
                drm_gem_object_free(&bo->ttm.base.refcount);
 }
 
+void xe_bo_put(struct xe_bo *bo)
+{
+       might_sleep();
+       if (bo) {
+#ifdef CONFIG_PROC_FS
+               if (bo->client)
+                       might_lock(&bo->client->bos_lock);
+#endif
+               if (bo->ggtt_node && bo->ggtt_node->ggtt)
+                       might_lock(&bo->ggtt_node->ggtt->lock);
+               drm_gem_object_put(&bo->ttm.base);
+       }
+}
+
 /**
  * xe_bo_dumb_create - Create a dumb bo as backing for a fb
  * @file_priv: ...
index dbfb3209615dfadb090e38d48c0f1f91aca93851..6e4be52306dfc9f85e61b0c4f767e05a80bbde93 100644 (file)
@@ -126,11 +126,7 @@ static inline struct xe_bo *xe_bo_get(struct xe_bo *bo)
        return bo;
 }
 
-static inline void xe_bo_put(struct xe_bo *bo)
-{
-       if (bo)
-               drm_gem_object_put(&bo->ttm.base);
-}
+void xe_bo_put(struct xe_bo *bo);
 
 static inline void __xe_bo_unset_bulk_move(struct xe_bo *bo)
 {