[PATCH 4/4] tweaks

Matthew Auld matthew.auld at intel.com
Thu Dec 1 19:38:08 UTC 2022


---
 drivers/gpu/drm/i915/gt/selftest_migrate.c | 93 +++++++---------------
 1 file changed, 28 insertions(+), 65 deletions(-)

diff --git a/drivers/gpu/drm/i915/gt/selftest_migrate.c b/drivers/gpu/drm/i915/gt/selftest_migrate.c
index 1da51add2c02..306cd47d1f7d 100644
--- a/drivers/gpu/drm/i915/gt/selftest_migrate.c
+++ b/drivers/gpu/drm/i915/gt/selftest_migrate.c
@@ -530,14 +530,17 @@ static int live_migrate_clear(void *arg)
 	return 0;
 }
 
-static int spinner_kill(void *arg)
+struct spinner_timer {
+	struct timer_list timer;
+	struct igt_spinner spin;
+};
+
+static void spinner_kill(struct timer_list *timer)
 {
-	struct igt_spinner *spin = arg;
+	struct spinner_timer *st = from_timer(st, timer, timer);
 
-	msleep(2000); /* Should be plenty */
-	igt_spinner_end(spin);
+	igt_spinner_end(&st->spin);
 	pr_info("%s\n", __func__);
-	return 0;
 }
 
 static int live_emit_pte_full_ring(void *arg)
@@ -547,13 +550,11 @@ static int live_emit_pte_full_ring(void *arg)
 	struct drm_i915_private *i915 = migrate->context->engine->i915;
 	struct drm_i915_gem_object *obj;
 	struct intel_context *ce;
-	struct i915_request *rq, *prev;
-	struct igt_spinner spin;
-	struct task_struct *tsk = NULL;
+	struct i915_request *rq;
+	struct spinner_timer st;
 	struct sgt_dma it;
-	int len, sz, err;
-	int status;
-	u32 *cs;
+	int len, err;
+
 
 	/*
 	 * Simple regression test to check that we don't trample the
@@ -561,7 +562,7 @@ static int live_emit_pte_full_ring(void *arg)
 	 * nearly full.
 	 */
 
-	if (igt_spinner_init(&spin, to_gt(i915)))
+	if (igt_spinner_init(&st.spin, to_gt(i915)))
 		return -ENOMEM;
 
 	obj = i915_gem_object_create_internal(i915, 2 * PAGE_SIZE);
@@ -586,18 +587,24 @@ static int live_emit_pte_full_ring(void *arg)
 	if (err)
 		goto out_put;
 
-	rq = igt_spinner_create_request(&spin, ce, MI_ARB_CHECK);
+	rq = igt_spinner_create_request(&st.spin, ce, MI_ARB_CHECK);
 	if (IS_ERR(rq)) {
 		err = PTR_ERR(rq);
 		goto out_unpin;
 	}
 
 	i915_request_add(rq);
-	if (!igt_wait_for_spinner(&spin, rq)) {
+	if (!igt_wait_for_spinner(&st.spin, rq)) {
 		err = -EIO;
 		goto out_unpin;
 	}
 
+	rq = i915_request_create(ce);
+	if (IS_ERR(rq)) {
+		err = PTR_ERR(rq);
+		goto out_unpin;
+	}
+
 	/*
 	 * Fill the rest of the ring leaving I915_EMIT_PTE_NUM_DWORDS +
 	 * ring->reserved_space at the end. To actually emit the PTEs we require
@@ -606,55 +613,17 @@ static int live_emit_pte_full_ring(void *arg)
 	 * ring space in emit_pte(), otherwise we trample on the reserved_space
 	 * resulting in crashes when later submitting the rq.
 	 */
+	rq->ring->space = rq->reserved_space + I915_EMIT_PTE_NUM_DWORDS * sizeof(u32);
 
-	prev = NULL;
-	do {
-		if (prev)
-			i915_request_add(rq);
-
-		rq = i915_request_create(ce);
-		if (IS_ERR(rq)) {
-			err = PTR_ERR(rq);
-			goto out_unpin;
-		}
-
-		sz = (rq->ring->space - rq->reserved_space) / sizeof(u32) -
-			I915_EMIT_PTE_NUM_DWORDS;
-		sz = min_t(u32, sz, (SZ_1K - rq->reserved_space) / sizeof(u32) -
-			   I915_EMIT_PTE_NUM_DWORDS);
-		cs = intel_ring_begin(rq, sz);
-		if (IS_ERR(cs)) {
-			err = PTR_ERR(cs);
-			goto out_rq;
-		}
-
-		memset32(cs, MI_NOOP, sz);
-		cs += sz;
-		intel_ring_advance(rq, cs);
-
-		pr_info("%s emit=%u sz=%d\n", __func__, rq->ring->emit, sz);
-
-		prev = rq;
-	} while (rq->ring->space > (rq->reserved_space +
-				    I915_EMIT_PTE_NUM_DWORDS * sizeof(u32)));
-
-	it = sg_sgt(obj->mm.pages->sgl);
-
-	tsk = kthread_run(spinner_kill, &spin, "igt-kill-spinner");
-	if (IS_ERR(tsk)) {
-		err = PTR_ERR(tsk);
-		goto out_rq;
-	}
-
-	get_task_struct(tsk);
-
-	msleep(10); /* start all threads before we kthread_stop() */
+	timer_setup_on_stack(&st.timer, spinner_kill, 0);
+	mod_timer(&st.timer, jiffies + 3 * HZ);
 
 	/*
 	 * This should wait for the spinner to be killed, otherwise we should go
 	 * down in flames when doing i915_request_add().
 	 */
 	pr_info("%s emite_pte ring space=%u\n", __func__, rq->ring->space);
+	it = sg_sgt(obj->mm.pages->sgl);
 	len = emit_pte(rq, &it, obj->cache_level, false, 0, CHUNK_SZ);
 	if (!len) {
 		err = -EINVAL;
@@ -667,14 +636,8 @@ static int live_emit_pte_full_ring(void *arg)
 
 out_rq:
 	i915_request_add(rq); /* GEM_BUG_ON(rq->reserved_space > ring->space)? */
-
-	if (!IS_ERR_OR_NULL(tsk)) {
-		status = kthread_stop(tsk);
-		if (status && !err)
-			err = status;
-
-		put_task_struct(tsk);
-	}
+	del_timer_sync(&st.timer);
+	destroy_timer_on_stack(&st.timer);
 out_unpin:
 	intel_context_unpin(ce);
 out_put:
@@ -682,7 +645,7 @@ static int live_emit_pte_full_ring(void *arg)
 out_obj:
 	i915_gem_object_put(obj);
 out_spinner:
-	igt_spinner_fini(&spin);
+	igt_spinner_fini(&st.spin);
 	return err;
 }
 
-- 
2.38.1



More information about the Intel-gfx-trybot mailing list