Commit 72bae5c2 authored by Matthew Brost's avatar Matthew Brost Committed by Maarten Lankhorst

drm/xe: Drop ggtt invalidate from display code

Only buffers mapped in the GGTT used by the GuC require an invalidation.
Display buffers do not require an invalidation. Delete the invalidatio
from display code and make invalidation a static function in xe_ggtt.c.

Cc: Maarten Lankhorst <maarten.lankhorst@linux.intel.com>
Signed-off-by: default avatarMatthew Brost <matthew.brost@intel.com>
Signed-off-by: default avatarMaarten Lankhorst <maarten.lankhorst@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240306052002.311196-3-matthew.brost@intel.com
parent a6eff8f9
...@@ -241,7 +241,6 @@ static int __xe_pin_fb_vma_ggtt(struct intel_framebuffer *fb, ...@@ -241,7 +241,6 @@ static int __xe_pin_fb_vma_ggtt(struct intel_framebuffer *fb,
rot_info->plane[i].dst_stride); rot_info->plane[i].dst_stride);
} }
xe_ggtt_invalidate(ggtt);
out_unlock: out_unlock:
mutex_unlock(&ggtt->lock); mutex_unlock(&ggtt->lock);
out: out:
...@@ -384,4 +383,4 @@ struct i915_address_space *intel_dpt_create(struct intel_framebuffer *fb) ...@@ -384,4 +383,4 @@ struct i915_address_space *intel_dpt_create(struct intel_framebuffer *fb)
void intel_dpt_destroy(struct i915_address_space *vm) void intel_dpt_destroy(struct i915_address_space *vm)
{ {
return; return;
} }
\ No newline at end of file
...@@ -200,6 +200,8 @@ int xe_ggtt_init_early(struct xe_ggtt *ggtt) ...@@ -200,6 +200,8 @@ int xe_ggtt_init_early(struct xe_ggtt *ggtt)
return drmm_add_action_or_reset(&xe->drm, ggtt_fini_early, ggtt); return drmm_add_action_or_reset(&xe->drm, ggtt_fini_early, ggtt);
} }
static void xe_ggtt_invalidate(struct xe_ggtt *ggtt);
static void xe_ggtt_initial_clear(struct xe_ggtt *ggtt) static void xe_ggtt_initial_clear(struct xe_ggtt *ggtt)
{ {
struct drm_mm_node *hole; struct drm_mm_node *hole;
...@@ -261,7 +263,7 @@ static void ggtt_invalidate_gt_tlb(struct xe_gt *gt) ...@@ -261,7 +263,7 @@ static void ggtt_invalidate_gt_tlb(struct xe_gt *gt)
drm_warn(&gt_to_xe(gt)->drm, "xe_gt_tlb_invalidation_ggtt error=%d", err); drm_warn(&gt_to_xe(gt)->drm, "xe_gt_tlb_invalidation_ggtt error=%d", err);
} }
void xe_ggtt_invalidate(struct xe_ggtt *ggtt) static void xe_ggtt_invalidate(struct xe_ggtt *ggtt)
{ {
/* Each GT in a tile has its own TLB to cache GGTT lookups */ /* Each GT in a tile has its own TLB to cache GGTT lookups */
ggtt_invalidate_gt_tlb(ggtt->tile->primary_gt); ggtt_invalidate_gt_tlb(ggtt->tile->primary_gt);
......
...@@ -11,7 +11,6 @@ ...@@ -11,7 +11,6 @@
struct drm_printer; struct drm_printer;
void xe_ggtt_set_pte(struct xe_ggtt *ggtt, u64 addr, u64 pte); void xe_ggtt_set_pte(struct xe_ggtt *ggtt, u64 addr, u64 pte);
void xe_ggtt_invalidate(struct xe_ggtt *ggtt);
int xe_ggtt_init_early(struct xe_ggtt *ggtt); int xe_ggtt_init_early(struct xe_ggtt *ggtt);
int xe_ggtt_init(struct xe_ggtt *ggtt); int xe_ggtt_init(struct xe_ggtt *ggtt);
void xe_ggtt_printk(struct xe_ggtt *ggtt, const char *prefix); void xe_ggtt_printk(struct xe_ggtt *ggtt, const char *prefix);
......
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