summaryrefslogtreecommitdiffstats
path: root/drivers/gpu/vga
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2015-01-22 14:42:00 +0100
committerJani Nikula <jani.nikula@intel.com>2015-02-09 19:03:15 +0100
commitf0a1fb10e5f79f5aaf8d7e94b9fa6bf2fa9aeebf (patch)
tree7631f5895d3be97bef2c09f4c9404d03733eb588 /drivers/gpu/vga
parentdrm/i915: Drop vblank wait from intel_dp_link_down (diff)
downloadlinux-f0a1fb10e5f79f5aaf8d7e94b9fa6bf2fa9aeebf.tar.xz
linux-f0a1fb10e5f79f5aaf8d7e94b9fa6bf2fa9aeebf.zip
drm/i915: Insert a command barrier on BLT/BSD cache flushes
This looked like an odd regression from commit ec5cc0f9b019af95e4571a9fa162d94294c8d90b Author: Chris Wilson <chris@chris-wilson.co.uk> Date: Thu Jun 12 10:28:55 2014 +0100 drm/i915: Restrict GPU boost to the RCS engine but in reality it undercovered a much older coherency bug. The issue that boosting the GPU frequency on the BCS ring was masking was that we could wake the CPU up after completion of a BCS batch and inspect memory prior to the write cache being fully evicted. In order to serialise the breadcrumb interrupt (and so ensure that the CPU's view of memory is coherent) we need to perform a post-sync operation in the MI_FLUSH_DW. v2: Fix all the MI_FLUSH_DW (bsd plus the duplication in execlists). Also fix the invalidate_domains mask in gen8_emit_flush() for ring != VCS. Testcase: gpuX-rcs-gpu-read-after-write Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Cc: stable@vger.kernel.org Acked-by: Daniel Vetter <daniel@ffwll.ch> Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Diffstat (limited to 'drivers/gpu/vga')
0 files changed, 0 insertions, 0 deletions