]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
drm/xe/vm: Don't pin the vm_resv during validation
authorThomas Hellström <thomas.hellstrom@linux.intel.com>
Thu, 21 Aug 2025 14:30:43 +0000 (16:30 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 4 Sep 2025 14:55:38 +0000 (16:55 +0200)
[ Upstream commit 7551865cd12af2dc47e5a174eebcfb0b94b5449b ]

The pinning has the odd side-effect that unlocking *any* resv
during validation triggers an "unlocking pinned lock" warning.

Cc: Matthew Brost <matthew.brost@intel.com>
Fixes: 5cc3325584c4 ("drm/xe: Rework eviction rejection of bound external bos")
Signed-off-by: Thomas Hellström <thomas.hellstrom@linux.intel.com>
Reviewed-by: Matthew Brost <matthew.brost@intel.com>
Link: https://lore.kernel.org/r/20250821143045.106005-2-thomas.hellstrom@linux.intel.com
(cherry picked from commit 0a51bf3e54dd8b77e6f1febbbb66def0660862d2)
Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/gpu/drm/xe/xe_bo.c
drivers/gpu/drm/xe/xe_vm.h

index 7aa2c17825da9abce0dea946b94e12dc6b522c8c..e2c6493cb70d94c8904e796641a28db2bb80ae24 100644 (file)
@@ -2435,7 +2435,6 @@ int xe_bo_validate(struct xe_bo *bo, struct xe_vm *vm, bool allow_res_evict)
                .no_wait_gpu = false,
                .gfp_retry_mayfail = true,
        };
-       struct pin_cookie cookie;
        int ret;
 
        if (vm) {
@@ -2446,10 +2445,10 @@ int xe_bo_validate(struct xe_bo *bo, struct xe_vm *vm, bool allow_res_evict)
                ctx.resv = xe_vm_resv(vm);
        }
 
-       cookie = xe_vm_set_validating(vm, allow_res_evict);
+       xe_vm_set_validating(vm, allow_res_evict);
        trace_xe_bo_validate(bo);
        ret = ttm_bo_validate(&bo->ttm, &bo->placement, &ctx);
-       xe_vm_clear_validating(vm, allow_res_evict, cookie);
+       xe_vm_clear_validating(vm, allow_res_evict);
 
        return ret;
 }
index 0158ec0ae3b2301f9da1bbf6957b1a0b85266fb2..e54ca835b582824d105dd1b26c920d31beafd213 100644 (file)
@@ -310,22 +310,14 @@ void xe_vm_snapshot_free(struct xe_vm_snapshot *snap);
  * Register this task as currently making bos resident for the vm. Intended
  * to avoid eviction by the same task of shared bos bound to the vm.
  * Call with the vm's resv lock held.
- *
- * Return: A pin cookie that should be used for xe_vm_clear_validating().
  */
-static inline struct pin_cookie xe_vm_set_validating(struct xe_vm *vm,
-                                                    bool allow_res_evict)
+static inline void xe_vm_set_validating(struct xe_vm *vm, bool allow_res_evict)
 {
-       struct pin_cookie cookie = {};
-
        if (vm && !allow_res_evict) {
                xe_vm_assert_held(vm);
-               cookie = lockdep_pin_lock(&xe_vm_resv(vm)->lock.base);
                /* Pairs with READ_ONCE in xe_vm_is_validating() */
                WRITE_ONCE(vm->validating, current);
        }
-
-       return cookie;
 }
 
 /**
@@ -333,17 +325,14 @@ static inline struct pin_cookie xe_vm_set_validating(struct xe_vm *vm,
  * @vm: Pointer to the vm or NULL
  * @allow_res_evict: Eviction from @vm was allowed. Must be set to the same
  * value as for xe_vm_set_validation().
- * @cookie: Cookie obtained from xe_vm_set_validating().
  *
  * Register this task as currently making bos resident for the vm. Intended
  * to avoid eviction by the same task of shared bos bound to the vm.
  * Call with the vm's resv lock held.
  */
-static inline void xe_vm_clear_validating(struct xe_vm *vm, bool allow_res_evict,
-                                         struct pin_cookie cookie)
+static inline void xe_vm_clear_validating(struct xe_vm *vm, bool allow_res_evict)
 {
        if (vm && !allow_res_evict) {
-               lockdep_unpin_lock(&xe_vm_resv(vm)->lock.base, cookie);
                /* Pairs with READ_ONCE in xe_vm_is_validating() */
                WRITE_ONCE(vm->validating, NULL);
        }