diff mbox series

TGL HAX drm/i915/tgl: Defer direct submission from interrupt context

Message ID 20191001075527.12879-1-chris@chris-wilson.co.uk (mailing list archive)
State New, archived
Headers show
Series TGL HAX drm/i915/tgl: Defer direct submission from interrupt context | expand

Commit Message

Chris Wilson Oct. 1, 2019, 7:55 a.m. UTC
---
 drivers/gpu/drm/i915/gt/intel_lrc.c | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff mbox series

Patch

diff --git a/drivers/gpu/drm/i915/gt/intel_lrc.c b/drivers/gpu/drm/i915/gt/intel_lrc.c
index ef9eb3330a37..8906d86c76de 100644
--- a/drivers/gpu/drm/i915/gt/intel_lrc.c
+++ b/drivers/gpu/drm/i915/gt/intel_lrc.c
@@ -2167,10 +2167,14 @@  static void __submit_queue_imm(struct intel_engine_cs *engine)
 {
 	struct intel_engine_execlists * const execlists = &engine->execlists;
 
+	if (READ_ONCE(engine->execlists.pending[0]))
+		return;
+
 	if (reset_in_progress(execlists))
 		return; /* defer until we restart the engine following reset */
 
-	if (execlists->tasklet.func == execlists_submission_tasklet)
+	if (execlists->tasklet.func == execlists_submission_tasklet &&
+	    !in_irq())
 		__execlists_submission_tasklet(engine);
 	else
 		tasklet_hi_schedule(&execlists->tasklet);