drm/i915/execlists: Split the atomic test_and_clear_bit for irq handler
authorChris Wilson <chris@chris-wilson.co.uk>
Tue, 21 Mar 2017 11:33:20 +0000 (11:33 +0000)
committerChris Wilson <chris@chris-wilson.co.uk>
Tue, 21 Mar 2017 14:14:55 +0000 (14:14 +0000)
commit899f6204c0f8117d33226e586d3a630b3cf9bce0
tree366786612877abc5581dfec13a8ed18e6f26677e
parent272bce17cc3ef4629e28c38324d81ca72a862115
drm/i915/execlists: Split the atomic test_and_clear_bit for irq handler

Rather than impose the cost of a locked test before queuing a new
request, reduce it to a simple test_bit() with a following clear_bit()
prior to doing the CSB check. This ensure that if an interrupt does
occur whilst reading from the CSB, we still detect it (the interrupt
would trigger a rescheduling of the tasklet anyway).

Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Link: http://patchwork.freedesktop.org/patch/msgid/20170321113320.2603-1-chris@chris-wilson.co.uk
Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
drivers/gpu/drm/i915/intel_lrc.c