]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/xe: Clear pending_disable before signaling suspend fence
authorTangudu Tilak Tirumalesh <tilak.tirumalesh.tangudu@intel.com>
Wed, 3 Jun 2026 06:52:16 +0000 (12:22 +0530)
committerMatthew Brost <matthew.brost@intel.com>
Tue, 16 Jun 2026 17:18:20 +0000 (10:18 -0700)
In the schedule-disable done path for suspend, we
signal the suspend fence before clearing pending_disable.

That wakeup can let suspend_wait complete and resume be queued
immediately. The resume path may then reach enable_scheduling()
while pending_disable is still set and hit the
!exec_queue_pending_disable(q) assertion.

Fix this by clearing pending_disable before signaling
the suspend fence, so any resumed transition observes a
consistent state.

Fixes: 87651f31ae4e ("drm/xe/guc_submit: fix race around suspend_pending")
Cc: stable@vger.kernel.org # v7.0+
Signed-off-by: Tangudu Tilak Tirumalesh <tilak.tirumalesh.tangudu@intel.com>
Reviewed-by: Thomas Hellstrom <thomas.hellstrom@linux.intel.com>
Signed-off-by: Daniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>
Link: https://patch.msgid.link/20260603065217.3131066-3-tilak.tirumalesh.tangudu@intel.com
(cherry picked from commit 4b1ae138b0e103d753773956a84eebc2edbf62c4)
Signed-off-by: Matthew Brost <matthew.brost@intel.com>
drivers/gpu/drm/xe/xe_guc_submit.c

index d1ab66ca1856a15d891c4dc1cc6a37005f97827b..122a0983df18996ff7f68380d366c4d5a8d08984 100644 (file)
@@ -2791,8 +2791,8 @@ static void handle_sched_done(struct xe_guc *guc, struct xe_exec_queue *q,
                xe_gt_assert(guc_to_gt(guc), exec_queue_pending_disable(q));
 
                if (q->guc->suspend_pending) {
-                       suspend_fence_signal(q);
                        clear_exec_queue_pending_disable(q);
+                       suspend_fence_signal(q);
                } else {
                        if (exec_queue_banned(q)) {
                                smp_wmb();