mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-22 18:52:54 +07:00
drm/i915: Flush the WCB following a WC write
If we have just completed a WC write, we must ensure that the WCB (Write Combining Buffer) is flushed out to main memory before we can expect to see the results. This is especially important when mixing WC with GTT as the physical paths are different and cachelines are not naturally flushed. Testcase: igt/drv_selftests/live_coherency #gdg Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Reviewed-by: Matthew Auld <matthew.auld@intel.com> Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20180706115402.18547-1-chris@chris-wilson.co.uk
This commit is contained in:
parent
03bbc508a3
commit
add00e6d89
@ -837,6 +837,10 @@ flush_write_domain(struct drm_i915_gem_object *obj, unsigned int flush_domains)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case I915_GEM_DOMAIN_WC:
|
||||||
|
wmb();
|
||||||
|
break;
|
||||||
|
|
||||||
case I915_GEM_DOMAIN_CPU:
|
case I915_GEM_DOMAIN_CPU:
|
||||||
i915_gem_clflush_object(obj, I915_CLFLUSH_SYNC);
|
i915_gem_clflush_object(obj, I915_CLFLUSH_SYNC);
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user