drm/i915: Flush execution tasklets before checking request status
authorChris Wilson <chris@chris-wilson.co.uk>
Wed, 5 Feb 2020 09:54:40 +0000 (09:54 +0000)
committerChris Wilson <chris@chris-wilson.co.uk>
Wed, 5 Feb 2020 18:51:52 +0000 (18:51 +0000)
Rather than flushing the submission tasklets just before we sleep, flush
before we check the request status. Ideally this gives us a moment to
process the tasklets after sleeping just before we timeout.

v2: Compromise by pushing the flush prior to the timeout, but after the
check on completion so that we do not further delay the ready client.

Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Reviewed-by: Mika Kuoppala <mika.kuoppala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20200205095441.1769599-1-chris@chris-wilson.co.uk
drivers/gpu/drm/i915/i915_request.c

index f56b046a32de19e255b69e9baaeff6fd56d7d29a..0ecc2cf6421626d6f0011150618966d35648a75e 100644 (file)
@@ -1571,6 +1571,8 @@ long i915_request_wait(struct i915_request *rq,
                        break;
                }
 
+               intel_engine_flush_submission(rq->engine);
+
                if (signal_pending_state(state, current)) {
                        timeout = -ERESTARTSYS;
                        break;
@@ -1581,7 +1583,6 @@ long i915_request_wait(struct i915_request *rq,
                        break;
                }
 
-               intel_engine_flush_submission(rq->engine);
                timeout = io_schedule_timeout(timeout);
        }
        __set_current_state(TASK_RUNNING);