Commit 9f9f09d4 authored by Matthew Brost's avatar Matthew Brost Committed by Rodrigo Vivi

drm/xe: Signal invalidation fence immediately if CT send fails

This means we are in the middle of a GT reset and no need to do TLB
invalidation so just signal invalidation fence immediately.
Signed-off-by: default avatarMatthew Brost <matthew.brost@intel.com>
Signed-off-by: default avatarRodrigo Vivi <rodrigo.vivi@intel.com>
Reviewed-by: default avatarNiranjana Vishwanathapura <niranjana.vishwanathapura@intel.com>
parent bae8ddae
...@@ -69,6 +69,15 @@ int xe_gt_tlb_invalidation_init(struct xe_gt *gt) ...@@ -69,6 +69,15 @@ int xe_gt_tlb_invalidation_init(struct xe_gt *gt)
return 0; return 0;
} }
static void
invalidation_fence_signal(struct xe_gt_tlb_invalidation_fence *fence)
{
trace_xe_gt_tlb_invalidation_fence_signal(fence);
list_del(&fence->link);
dma_fence_signal(&fence->base);
dma_fence_put(&fence->base);
}
/** /**
* xe_gt_tlb_invalidation_reset - Initialize GT TLB invalidation reset * xe_gt_tlb_invalidation_reset - Initialize GT TLB invalidation reset
* @gt: graphics tile * @gt: graphics tile
...@@ -83,11 +92,8 @@ int xe_gt_tlb_invalidation_init(struct xe_gt *gt) ...@@ -83,11 +92,8 @@ int xe_gt_tlb_invalidation_init(struct xe_gt *gt)
mutex_lock(&gt->uc.guc.ct.lock); mutex_lock(&gt->uc.guc.ct.lock);
list_for_each_entry_safe(fence, next, list_for_each_entry_safe(fence, next,
&gt->tlb_invalidation.pending_fences, link) { &gt->tlb_invalidation.pending_fences, link)
list_del(&fence->link); invalidation_fence_signal(fence);
dma_fence_signal(&fence->base);
dma_fence_put(&fence->base);
}
mutex_unlock(&gt->uc.guc.ct.lock); mutex_unlock(&gt->uc.guc.ct.lock);
} }
...@@ -130,6 +136,8 @@ static int send_tlb_invalidation(struct xe_guc *guc, ...@@ -130,6 +136,8 @@ static int send_tlb_invalidation(struct xe_guc *guc,
} }
if (!ret) if (!ret)
ret = seqno; ret = seqno;
if (ret < 0 && fence)
invalidation_fence_signal(fence);
mutex_unlock(&guc->ct.lock); mutex_unlock(&guc->ct.lock);
return ret; return ret;
...@@ -321,16 +329,13 @@ int xe_guc_tlb_invalidation_done_handler(struct xe_guc *guc, u32 *msg, u32 len) ...@@ -321,16 +329,13 @@ int xe_guc_tlb_invalidation_done_handler(struct xe_guc *guc, u32 *msg, u32 len)
if (fence) if (fence)
trace_xe_gt_tlb_invalidation_fence_recv(fence); trace_xe_gt_tlb_invalidation_fence_recv(fence);
if (fence && tlb_invalidation_seqno_past(gt, fence->seqno)) { if (fence && tlb_invalidation_seqno_past(gt, fence->seqno)) {
trace_xe_gt_tlb_invalidation_fence_signal(fence); invalidation_fence_signal(fence);
list_del(&fence->link);
if (!list_empty(&gt->tlb_invalidation.pending_fences)) if (!list_empty(&gt->tlb_invalidation.pending_fences))
mod_delayed_work(system_wq, mod_delayed_work(system_wq,
&gt->tlb_invalidation.fence_tdr, &gt->tlb_invalidation.fence_tdr,
TLB_TIMEOUT); TLB_TIMEOUT);
else else
cancel_delayed_work(&gt->tlb_invalidation.fence_tdr); cancel_delayed_work(&gt->tlb_invalidation.fence_tdr);
dma_fence_signal(&fence->base);
dma_fence_put(&fence->base);
} }
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment