diff options
author | Naresh Kumar Kachhi <naresh.kumar.kachhi@intel.com> | 2014-03-12 07:09:40 -0400 |
---|---|---|
committer | Daniel Vetter <daniel.vetter@ffwll.ch> | 2014-03-12 11:00:41 -0400 |
commit | a51435a3137ad8ae75c288c39bd2d8b2696bae8f (patch) | |
tree | a6bb3f29978fb67d0ea21c0c1410d6fe57649c45 /drivers/gpu/drm/i915/intel_ringbuffer.c | |
parent | 5a6c93fe802bd241c4287f116d0116aff0a4341a (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.c | 10 |
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 */ |