drm/i915/gt: Wait longer for tasks in migrate selftest
authorJonathan Cavitt <jonathan.cavitt@intel.com>
Mon, 28 Aug 2023 19:28:52 +0000 (12:28 -0700)
committerAndi Shyti <andi.shyti@linux.intel.com>
Thu, 31 Aug 2023 16:58:01 +0000 (18:58 +0200)
The thread_global_copy subtest of the live migrate selftest creates a
large number of threads and waits 10ms for them all to start.  This is
not enough time to wait for the threaded tasks to start, as some may
need to wait for additional ring space to be granted.  Threads that do
so are at risk of getting stopped (signaled) in the middle of waiting
for additional space, which can result in ERESTARTSYS getting reported
erroneously by i915_request_wait.

Instead of waiting a flat 10ms for the threads to start, wait 10ms per
thread.  This grants enough of a buffer for each thread to wait for
additional ring space when needed.

Signed-off-by: Jonathan Cavitt <jonathan.cavitt@intel.com>
Reviewed-by: Andi Shyti <andi.shyti@linux.intel.com>
Signed-off-by: Andi Shyti <andi.shyti@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20230828192852.2894671-2-jonathan.cavitt@intel.com
drivers/gpu/drm/i915/gt/selftest_migrate.c

index 3def5ca72decfd32295cd46d0e9f7bba73c69d65..1a34cbe04fb64692832a3fe0474f1dc19ff311de 100644 (file)
@@ -710,7 +710,7 @@ static int threaded_migrate(struct intel_migrate *migrate,
                thread[i].tsk = tsk;
        }
 
-       msleep(10); /* start all threads before we kthread_stop() */
+       msleep(10 * n_cpus); /* start all threads before we kthread_stop() */
 
        for (i = 0; i < n_cpus; ++i) {
                struct task_struct *tsk = thread[i].tsk;