drm/xe: Only use reserved BCS instances for usm migrate exec queue
authorMatthew Brost <matthew.brost@intel.com>
Mon, 15 Apr 2024 19:04:53 +0000 (12:04 -0700)
committerThomas Hellström <thomas.hellstrom@linux.intel.com>
Tue, 28 May 2024 06:53:35 +0000 (08:53 +0200)
commitc8ea2c31f5ea437199b239d76ad5db27343edb0c
tree3d0e8f0713e2b2306935aba5e710768087585c58
parent77b79df0268bee3ef38fd5e76e86a076ce02995d
drm/xe: Only use reserved BCS instances for usm migrate exec queue

The GuC context scheduling queue is 2 entires deep, thus it is possible
for a migration job to be stuck behind a fault if migration exec queue
shares engines with user jobs. This can deadlock as the migrate exec
queue is required to service page faults. Avoid deadlock by only using
reserved BCS instances for usm migrate exec queue.

Fixes: a043fbab7af5 ("drm/xe/pvc: Use fast copy engines as migrate engine on PVC")
Cc: Matt Roper <matthew.d.roper@intel.com>
Cc: Niranjana Vishwanathapura <niranjana.vishwanathapura@intel.com>
Signed-off-by: Matthew Brost <matthew.brost@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240415190453.696553-2-matthew.brost@intel.com
Reviewed-by: Brian Welty <brian.welty@intel.com>
(cherry picked from commit 04f4a70a183a688a60fe3882d6e4236ea02cfc67)
Signed-off-by: Thomas Hellström <thomas.hellstrom@linux.intel.com>
drivers/gpu/drm/xe/xe_migrate.c