Chris Wilson 317e0395cc drm/i915/execlists: Take a reference while capturing the guilty request
Thanks to preempt-to-busy, we leave the request on the HW as we submit
the preemption request. This means that the request may complete at any
moment as we process HW events, and in particular the request may be
retired as we are planning to capture it for a preemption timeout.

Be more careful while obtaining the request to capture after a
preemption timeout, and check to see if it completed before we were able
to put it on the on-hold list. If we do see it did complete just before
we capture the request, proclaim the preemption-timeout a false positive
and pardon the reset as we should hit an arbitration point momentarily
and so be able to process the preemption.

Note that even after we move the request to be on hold it may be retired
(as the reset to stop the HW comes after), so we do require to hold our
own reference as we work on the request for capture (and all of the
peeking at state within the request needs to be carefully protected).

Fixes: c3f1ed90e6ff ("drm/i915/gt: Allow temporary suspension of inflight requests")
Closes: https://gitlab.freedesktop.org/drm/intel/issues/997
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20200122140243.495621-1-chris@chris-wilson.co.uk
(cherry picked from commit 4ba5c086a1d8e38d6927967ae1a3271a6ab7a927)
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
2020-02-12 17:02:53 +02:00
..
2019-12-27 15:25:04 +10:00
2019-10-23 06:26:33 -04:00
2019-12-17 13:57:54 +01:00
2019-10-24 08:45:31 +03:00
2020-01-17 05:54:18 -08:00
2020-01-16 19:42:08 -08:00
2019-12-01 18:43:25 -08:00
2020-01-03 11:43:44 +10:00
2020-01-20 11:42:57 +10:00
2019-10-31 11:24:52 +01:00
2019-11-30 14:35:43 -08:00
2019-12-01 18:42:02 -08:00
2019-11-03 19:54:53 +01:00
2020-01-20 11:42:57 +10:00
2019-12-06 08:28:51 -08:00
2019-12-03 13:58:22 -08:00
2020-01-20 11:42:57 +10:00
2020-01-13 18:50:18 -08:00
2019-10-21 09:08:15 +02:00
2019-12-01 18:43:25 -08:00
2019-12-05 11:43:31 -08:00
2019-11-25 19:40:40 -08:00
2020-01-20 11:42:57 +10:00
2019-12-05 11:28:14 -08:00
2020-01-06 12:04:31 -08:00
2019-12-01 18:39:24 -08:00
2020-01-18 12:12:36 -08:00
2020-01-20 11:42:57 +10:00
2020-01-06 12:34:44 -08:00
2020-01-20 11:42:57 +10:00
2019-12-27 17:28:41 -08:00
2020-01-20 11:42:57 +10:00
2020-01-17 19:40:06 +01:00
2019-12-07 14:51:04 -08:00
2019-11-14 13:06:33 +08:00
2020-01-20 11:42:57 +10:00