summaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915/intel_ringbuffer.c
diff options
context:
space:
mode:
authorNaresh Kumar Kachhi <naresh.kumar.kachhi@intel.com>2014-03-12 16:39:40 +0530
committerDaniel Vetter <daniel.vetter@ffwll.ch>2014-03-12 16:00:41 +0100
commita51435a3137ad8ae75c288c39bd2d8b2696bae8f (patch)
treea6bb3f29978fb67d0ea21c0c1410d6fe57649c45 /drivers/gpu/drm/i915/intel_ringbuffer.c
parent5a6c93fe802bd241c4287f116d0116aff0a4341a (diff)
downloadop-kernel-dev-a51435a3137ad8ae75c288c39bd2d8b2696bae8f.zip
op-kernel-dev-a51435a3137ad8ae75c288c39bd2d8b2696bae8f.tar.gz
drm/i915: disable rings before HW status page setup
Rings should be idle before issuing sync_flush (in intel_ring_setup_status_page). This patch moves the ring disabling before doing the HW status page setup. Signed-off-by: Naresh Kumar Kachhi <naresh.kumar.kachhi@intel.com> Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers/gpu/drm/i915/intel_ringbuffer.c')
-rw-r--r--drivers/gpu/drm/i915/intel_ringbuffer.c10
1 files changed, 5 insertions, 5 deletions
diff --git a/drivers/gpu/drm/i915/intel_ringbuffer.c b/drivers/gpu/drm/i915/intel_ringbuffer.c
index 8590921..42b4001 100644
--- a/drivers/gpu/drm/i915/intel_ringbuffer.c
+++ b/drivers/gpu/drm/i915/intel_ringbuffer.c
@@ -440,16 +440,16 @@ static int init_ring_common(struct intel_ring_buffer *ring)
gen6_gt_force_wake_get(dev_priv, FORCEWAKE_ALL);
- if (I915_NEED_GFX_HWS(dev))
- intel_ring_setup_status_page(ring);
- else
- ring_setup_phys_status_page(ring);
-
/* Stop the ring if it's running. */
I915_WRITE_CTL(ring, 0);
I915_WRITE_HEAD(ring, 0);
ring->write_tail(ring, 0);
+ if (I915_NEED_GFX_HWS(dev))
+ intel_ring_setup_status_page(ring);
+ else
+ ring_setup_phys_status_page(ring);
+
head = I915_READ_HEAD(ring) & HEAD_ADDR;
/* G45 ring initialization fails to reset head to zero */
OpenPOWER on IntegriCloud