]> git.baikalelectronics.ru Git - kernel.git/commitdiff
drm/i915: Flush the WCB following a WC write
authorChris Wilson <chris@chris-wilson.co.uk>
Fri, 6 Jul 2018 11:54:02 +0000 (12:54 +0100)
committerChris Wilson <chris@chris-wilson.co.uk>
Fri, 6 Jul 2018 13:05:23 +0000 (14:05 +0100)
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
drivers/gpu/drm/i915/i915_gem.c

index 0c0a1a959d0bd6481d33be75f3fbf8a54f506ec2..be63e8bbb6d21a87b46a5be588e2fce2886582d7 100644 (file)
@@ -837,6 +837,10 @@ flush_write_domain(struct drm_i915_gem_object *obj, unsigned int flush_domains)
                }
                break;
 
+       case I915_GEM_DOMAIN_WC:
+               wmb();
+               break;
+
        case I915_GEM_DOMAIN_CPU:
                i915_gem_clflush_object(obj, I915_CLFLUSH_SYNC);
                break;