aboutsummaryrefslogtreecommitdiffstats
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 07:09:40 -0400
committerDaniel Vetter <daniel.vetter@ffwll.ch>2014-03-12 11:00:41 -0400
commita51435a3137ad8ae75c288c39bd2d8b2696bae8f (patch)
treea6bb3f29978fb67d0ea21c0c1410d6fe57649c45 /drivers/gpu/drm/i915/intel_ringbuffer.c
parent5a6c93fe802bd241c4287f116d0116aff0a4341a (diff)
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 859092130c18..42b400144379 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)
440 440
441 gen6_gt_force_wake_get(dev_priv, FORCEWAKE_ALL); 441 gen6_gt_force_wake_get(dev_priv, FORCEWAKE_ALL);
442 442
443 if (I915_NEED_GFX_HWS(dev))
444 intel_ring_setup_status_page(ring);
445 else
446 ring_setup_phys_status_page(ring);
447
448 /* Stop the ring if it's running. */ 443 /* Stop the ring if it's running. */
449 I915_WRITE_CTL(ring, 0); 444 I915_WRITE_CTL(ring, 0);
450 I915_WRITE_HEAD(ring, 0); 445 I915_WRITE_HEAD(ring, 0);
451 ring->write_tail(ring, 0); 446 ring->write_tail(ring, 0);
452 447
448 if (I915_NEED_GFX_HWS(dev))
449 intel_ring_setup_status_page(ring);
450 else
451 ring_setup_phys_status_page(ring);
452
453 head = I915_READ_HEAD(ring) & HEAD_ADDR; 453 head = I915_READ_HEAD(ring) & HEAD_ADDR;
454 454
455 /* G45 ring initialization fails to reset head to zero */ 455 /* G45 ring initialization fails to reset head to zero */