mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-04 20:19:47 +08:00
drm/i915: Use maximum write flush for pwrite_gtt
As recently disovered by forcing big-core (!llc) machines to use the GTT paths, we need our full GTT write flush before manipulating the GTT PTE or else the writes may be directed to the wrong page. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Cc: Joonas Lahtinen <joonas.lahtinen@linux.intel.com> Cc: Matthew Auld <matthew.william.auld@gmail.com> Cc: Ville Syrjälä <ville.syrjala@linux.intel.com> Cc: stable@vger.kernel.org Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20190718145407.21352-2-chris@chris-wilson.co.uk
This commit is contained in:
parent
d45a4dd527
commit
bdae33b8b8
@ -610,7 +610,8 @@ i915_gem_gtt_pwrite_fast(struct drm_i915_gem_object *obj,
|
|||||||
unsigned int page_length = PAGE_SIZE - page_offset;
|
unsigned int page_length = PAGE_SIZE - page_offset;
|
||||||
page_length = remain < page_length ? remain : page_length;
|
page_length = remain < page_length ? remain : page_length;
|
||||||
if (node.allocated) {
|
if (node.allocated) {
|
||||||
wmb(); /* flush the write before we modify the GGTT */
|
/* flush the write before we modify the GGTT */
|
||||||
|
intel_gt_flush_ggtt_writes(ggtt->vm.gt);
|
||||||
ggtt->vm.insert_page(&ggtt->vm,
|
ggtt->vm.insert_page(&ggtt->vm,
|
||||||
i915_gem_object_get_dma_address(obj, offset >> PAGE_SHIFT),
|
i915_gem_object_get_dma_address(obj, offset >> PAGE_SHIFT),
|
||||||
node.start, I915_CACHE_NONE, 0);
|
node.start, I915_CACHE_NONE, 0);
|
||||||
@ -639,8 +640,8 @@ i915_gem_gtt_pwrite_fast(struct drm_i915_gem_object *obj,
|
|||||||
i915_gem_object_unlock_fence(obj, fence);
|
i915_gem_object_unlock_fence(obj, fence);
|
||||||
out_unpin:
|
out_unpin:
|
||||||
mutex_lock(&i915->drm.struct_mutex);
|
mutex_lock(&i915->drm.struct_mutex);
|
||||||
|
intel_gt_flush_ggtt_writes(ggtt->vm.gt);
|
||||||
if (node.allocated) {
|
if (node.allocated) {
|
||||||
wmb();
|
|
||||||
ggtt->vm.clear_range(&ggtt->vm, node.start, node.size);
|
ggtt->vm.clear_range(&ggtt->vm, node.start, node.size);
|
||||||
remove_mappable_node(&node);
|
remove_mappable_node(&node);
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
Reference in New Issue
Block a user