]> www.infradead.org Git - users/hch/misc.git/commitdiff
drm/xe: Call invalidation_fence_fini for PT inval fences in error state
authorDaniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>
Fri, 6 Dec 2024 01:50:22 +0000 (17:50 -0800)
committerThomas Hellström <thomas.hellstrom@linux.intel.com>
Thu, 12 Dec 2024 15:57:28 +0000 (16:57 +0100)
Invalidation_fence_init takes a PM reference, which is released in its
_fini counterpart, so we need to make sure that the latter is called,
even if the fence is in an error state.

Since we already have a function that calls _fini() and signals the
fence in the tlb inval code, we can expose that and call it from the PT
code.

Fixes: f002702290fc ("drm/xe: Hold a PM ref when GT TLB invalidations are inflight")
Signed-off-by: Daniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>
Cc: <stable@vger.kernel.org> # v6.11+
Cc: Matthew Brost <matthew.brost@intel.com>
Cc: Nirmoy Das <nirmoy.das@intel.com>
Cc: Rodrigo Vivi <rodrigo.vivi@intel.com>
Reviewed-by: Nirmoy Das <nirmoy.das@intel.com>
Reviewed-by: Matthew Brost <matthew.brost@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20241206015022.1567113-1-daniele.ceraolospurio@intel.com
(cherry picked from commit 65338639b79ce88aef5263cd518cde570a3c7c8e)
Signed-off-by: Thomas Hellström <thomas.hellstrom@linux.intel.com>
drivers/gpu/drm/xe/xe_gt_tlb_invalidation.c
drivers/gpu/drm/xe/xe_gt_tlb_invalidation.h
drivers/gpu/drm/xe/xe_pt.c

index 3cb228c773cd4b38856ead2d1a2ea9673124af13..6146d1776bdaccf9ef827db0048e3cfe00ae2366 100644 (file)
@@ -65,6 +65,14 @@ invalidation_fence_signal(struct xe_device *xe, struct xe_gt_tlb_invalidation_fe
        __invalidation_fence_signal(xe, fence);
 }
 
+void xe_gt_tlb_invalidation_fence_signal(struct xe_gt_tlb_invalidation_fence *fence)
+{
+       if (WARN_ON_ONCE(!fence->gt))
+               return;
+
+       __invalidation_fence_signal(gt_to_xe(fence->gt), fence);
+}
+
 static void xe_gt_tlb_fence_timeout(struct work_struct *work)
 {
        struct xe_gt *gt = container_of(work, struct xe_gt,
index f430d5797af701cd500f8b890169ffbeef9403fd..00b1c6c01e8d9591ca30d05d9f8e5a6871c142d6 100644 (file)
@@ -28,6 +28,7 @@ int xe_guc_tlb_invalidation_done_handler(struct xe_guc *guc, u32 *msg, u32 len);
 void xe_gt_tlb_invalidation_fence_init(struct xe_gt *gt,
                                       struct xe_gt_tlb_invalidation_fence *fence,
                                       bool stack);
+void xe_gt_tlb_invalidation_fence_signal(struct xe_gt_tlb_invalidation_fence *fence);
 
 static inline void
 xe_gt_tlb_invalidation_fence_wait(struct xe_gt_tlb_invalidation_fence *fence)
index f27f579f4d85aacc6511bb77c2523db40e3abb51..797576690356f23054e90b4d3ae174afc69404cc 100644 (file)
@@ -1333,8 +1333,7 @@ static void invalidation_fence_cb(struct dma_fence *fence,
                queue_work(system_wq, &ifence->work);
        } else {
                ifence->base.base.error = ifence->fence->error;
-               dma_fence_signal(&ifence->base.base);
-               dma_fence_put(&ifence->base.base);
+               xe_gt_tlb_invalidation_fence_signal(&ifence->base);
        }
        dma_fence_put(ifence->fence);
 }