* [PATCH i-g-t v3 1/2] xe_exec_reset: Add job cancel tests
2024-06-18 17:47 [PATCH i-g-t v3 0/2] Job cancel tests Matthew Brost
@ 2024-06-18 17:47 ` Matthew Brost
2024-06-18 17:47 ` [PATCH i-g-t v3 2/2] xe_exec_reset: Add timeslice preempt test Matthew Brost
2024-06-18 18:02 ` ✗ CI.Patch_applied: failure for Job cancel tests (rev2) Patchwork
2 siblings, 0 replies; 4+ messages in thread
From: Matthew Brost @ 2024-06-18 17:47 UTC (permalink / raw)
To: igt-dev; +Cc: intel-xe
This test has pulled out when the ability to set the job timeout via
IOCTL was removed from the uAPI while upstreaming Xe. Add this coverage
back in but only run on a single hardware engine given by default jobs
take 5 seconds to timeout.
Signed-off-by: Matthew Brost <matthew.brost@intel.com>
---
tests/intel/xe_exec_reset.c | 21 ++++++++++++++++++++-
1 file changed, 20 insertions(+), 1 deletion(-)
diff --git a/tests/intel/xe_exec_reset.c b/tests/intel/xe_exec_reset.c
index 8d731e6893..5e9e48adda 100644
--- a/tests/intel/xe_exec_reset.c
+++ b/tests/intel/xe_exec_reset.c
@@ -99,6 +99,7 @@ static void test_spin(int fd, struct drm_xe_engine_class_instance *eci)
#define VIRTUAL (0x1 << 3)
#define PARALLEL (0x1 << 4)
#define CAT_ERROR (0x1 << 5)
+#define PREEMPT (0x1 << 6)
/**
* SUBTEST: %s-cat-error
@@ -280,6 +281,12 @@ test_balancer(int fd, int gt, int class, int n_exec_queues, int n_execs,
* SUBTEST: cat-error
* Description: Test cat error
*
+ * SUBTEST: cancel
+ * Description: Test job cancel
+ *
+ * SUBTEST: cancel-preempt
+ * Description: Test job cancel with a preemptable job
+ *
* SUBTEST: gt-reset
* Description: Test GT reset
*
@@ -318,7 +325,7 @@ test_legacy_mode(int fd, struct drm_xe_engine_class_instance *eci,
uint64_t pad;
uint32_t data;
} *data;
- struct xe_spin_opts spin_opts = { .preempt = false };
+ struct xe_spin_opts spin_opts = { .preempt = flags & PREEMPT };
int i, b;
igt_assert(n_exec_queues <= MAX_N_EXECQUEUES);
@@ -727,6 +734,18 @@ igt_main
xe_for_each_engine(fd, hwe)
test_legacy_mode(fd, hwe, 2, 2, CAT_ERROR);
+ igt_subtest("cancel")
+ xe_for_each_engine(fd, hwe) {
+ test_legacy_mode(fd, hwe, 1, 1, 0);
+ break;
+ }
+
+ igt_subtest("cancel-preempt")
+ xe_for_each_engine(fd, hwe) {
+ test_legacy_mode(fd, hwe, 1, 1, PREEMPT);
+ break;
+ }
+
igt_subtest("gt-reset")
xe_for_each_engine(fd, hwe)
test_legacy_mode(fd, hwe, 2, 2, GT_RESET);
--
2.34.1
^ permalink raw reply related [flat|nested] 4+ messages in thread* [PATCH i-g-t v3 2/2] xe_exec_reset: Add timeslice preempt test
2024-06-18 17:47 [PATCH i-g-t v3 0/2] Job cancel tests Matthew Brost
2024-06-18 17:47 ` [PATCH i-g-t v3 1/2] xe_exec_reset: Add job " Matthew Brost
@ 2024-06-18 17:47 ` Matthew Brost
2024-06-18 18:02 ` ✗ CI.Patch_applied: failure for Job cancel tests (rev2) Patchwork
2 siblings, 0 replies; 4+ messages in thread
From: Matthew Brost @ 2024-06-18 17:47 UTC (permalink / raw)
To: igt-dev; +Cc: intel-xe
Add tests in which submit multiple preemptable spinners to same hardware
engine ensuring a cumulative longer timeout and validating the restart
paths in the DRM scheduler TDR (Timeout Detection and Recovery).
v3:
- Spell out TDR (Kamal)
Signed-off-by: Matthew Brost <matthew.brost@intel.com>
---
tests/intel/xe_exec_reset.c | 23 +++++++++++++++++++++--
1 file changed, 21 insertions(+), 2 deletions(-)
diff --git a/tests/intel/xe_exec_reset.c b/tests/intel/xe_exec_reset.c
index 5e9e48adda..144e3b3884 100644
--- a/tests/intel/xe_exec_reset.c
+++ b/tests/intel/xe_exec_reset.c
@@ -100,6 +100,7 @@ static void test_spin(int fd, struct drm_xe_engine_class_instance *eci)
#define PARALLEL (0x1 << 4)
#define CAT_ERROR (0x1 << 5)
#define PREEMPT (0x1 << 6)
+#define CANCEL (0x1 << 7)
/**
* SUBTEST: %s-cat-error
@@ -287,6 +288,12 @@ test_balancer(int fd, int gt, int class, int n_exec_queues, int n_execs,
* SUBTEST: cancel-preempt
* Description: Test job cancel with a preemptable job
*
+ * SUBTEST: cancel-timeslice-preempt
+ * Description: Test job cancel with 2 preemptable jobs
+ *
+ * SUBTEST: cancel-timeslice-many-preempt
+ * Description: Test job cancel with many preemptable jobs
+ *
* SUBTEST: gt-reset
* Description: Test GT reset
*
@@ -361,7 +368,7 @@ test_legacy_mode(int fd, struct drm_xe_engine_class_instance *eci,
uint64_t exec_addr;
int e = i % n_exec_queues;
- if (!i) {
+ if (!i || flags & CANCEL) {
spin_opts.addr = base_addr + spin_offset;
xe_spin_init(&data[i].spin, &spin_opts);
exec_addr = spin_opts.addr;
@@ -411,7 +418,7 @@ test_legacy_mode(int fd, struct drm_xe_engine_class_instance *eci,
xe_vm_unbind_async(fd, vm, 0, 0, addr, bo_size, sync, 1);
igt_assert(syncobj_wait(fd, &sync[0].handle, 1, INT64_MAX, 0, NULL));
- if (!(flags & GT_RESET)) {
+ if (!(flags & (GT_RESET | CANCEL))) {
for (i = 1; i < n_execs; i++)
igt_assert_eq(data[i].data, 0xc0ffee);
}
@@ -746,6 +753,18 @@ igt_main
break;
}
+ igt_subtest("cancel-timeslice-preempt")
+ xe_for_each_engine(fd, hwe) {
+ test_legacy_mode(fd, hwe, 2, 2, CANCEL | PREEMPT);
+ break;
+ }
+
+ igt_subtest("cancel-timeslice-many-preempt")
+ xe_for_each_engine(fd, hwe) {
+ test_legacy_mode(fd, hwe, 4, 4, CANCEL | PREEMPT);
+ break;
+ }
+
igt_subtest("gt-reset")
xe_for_each_engine(fd, hwe)
test_legacy_mode(fd, hwe, 2, 2, GT_RESET);
--
2.34.1
^ permalink raw reply related [flat|nested] 4+ messages in thread