drm/i915: Mark the addition of the initial-breadcrumb in the request
The initial-breadcrumb is used to mark the end of the awaiting and the beginning of the user payload. We verify that we do not start the user payload before all signaler are completed, checking our semaphore setup by looking for the initial breadcrumb being written too early. We also want to ensure that we do not add semaphore waits after we have already closed the semaphore section, an issue for later deferred waits. 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/20200513165937.9508-2-chris@chris-wilson.co.uk
This commit is contained in:
@@ -951,6 +951,7 @@ __emit_semaphore_wait(struct i915_request *to,
|
||||
u32 *cs;
|
||||
|
||||
GEM_BUG_ON(INTEL_GEN(to->i915) < 8);
|
||||
GEM_BUG_ON(i915_request_has_initial_breadcrumb(to));
|
||||
|
||||
/* We need to pin the signaler's HWSP until we are finished reading. */
|
||||
err = intel_timeline_read_hwsp(from, to, &hwsp_offset);
|
||||
@@ -1000,6 +1001,9 @@ emit_semaphore_wait(struct i915_request *to,
|
||||
if (!intel_context_use_semaphores(to->context))
|
||||
goto await_fence;
|
||||
|
||||
if (i915_request_has_initial_breadcrumb(to))
|
||||
goto await_fence;
|
||||
|
||||
if (!rcu_access_pointer(from->hwsp_cacheline))
|
||||
goto await_fence;
|
||||
|
||||
@@ -1256,7 +1260,8 @@ __i915_request_await_execution(struct i915_request *to,
|
||||
* immediate execution, and so we must wait until it reaches the
|
||||
* active slot.
|
||||
*/
|
||||
if (intel_engine_has_semaphores(to->engine)) {
|
||||
if (intel_engine_has_semaphores(to->engine) &&
|
||||
!i915_request_has_initial_breadcrumb(to)) {
|
||||
err = __emit_semaphore_wait(to, from, from->fence.seqno - 1);
|
||||
if (err < 0)
|
||||
return err;
|
||||
|
Reference in New Issue
Block a user