summaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915
diff options
context:
space:
mode:
authorChris Wilson2012-11-27 17:22:53 +0100
committerDaniel Vetter2012-11-29 11:43:53 +0100
commitb662a0663230853fccdfceeda5db031f5d4b657c (patch)
tree4c5d4cab41b4008e44d5553ffa48aa19b591d6d8 /drivers/gpu/drm/i915
parentdrm/i915: Preallocate next seqno before touching the ring (diff)
downloadkernel-qcow2-linux-b662a0663230853fccdfceeda5db031f5d4b657c.tar.gz
kernel-qcow2-linux-b662a0663230853fccdfceeda5db031f5d4b657c.tar.xz
kernel-qcow2-linux-b662a0663230853fccdfceeda5db031f5d4b657c.zip
drm/i915: Simplify flushing activity on the ring
As we now always preallocate the seqno before writing to the ring, we can trivially test if we have any pending activity on the ring by inspecting the olr. This makes it then possible to flush operations that are not normally associated with a request, like power-management. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Reviewed-by: Mika Kuoppala <mika.kuoppala@intel.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers/gpu/drm/i915')
-rw-r--r--drivers/gpu/drm/i915/i915_gem.c10
1 files changed, 3 insertions, 7 deletions
diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c
index 3b9b250ceac4..e594435eec9d 100644
--- a/drivers/gpu/drm/i915/i915_gem.c
+++ b/drivers/gpu/drm/i915/i915_gem.c
@@ -2485,13 +2485,9 @@ static int i915_ring_idle(struct intel_ring_buffer *ring)
u32 seqno;
int ret;
- /* We need to add any requests required to flush the objects */
- if (!list_empty(&ring->active_list)) {
- seqno = list_entry(ring->active_list.prev,
- struct drm_i915_gem_object,
- ring_list)->last_read_seqno;
-
- ret = i915_gem_check_olr(ring, seqno);
+ /* We need to add any requests required to flush the objects and ring */
+ if (ring->outstanding_lazy_request) {
+ ret = i915_add_request(ring, NULL, NULL);
if (ret)
return ret;
}