[PATCH 06/53] drm/i915/selftests: Allow for larger engine counts
Lucas De Marchi
lucas.demarchi at intel.com
Thu Jul 1 22:33:03 UTC 2021
On Thu, Jul 01, 2021 at 01:23:40PM -0700, Matt Roper wrote:
>From: John Harrison <John.C.Harrison at Intel.com>
>
>Increasing the engine count causes a couple of local array variables
>to exceed the kernel stack limit. So make them dynamic allocations
>instead.
>
>Signed-off-by: John Harrison <John.C.Harrison at Intel.com>
>Signed-off-by: Daniele Ceraolo Spurio <daniele.ceraolospurio at intel.com>
>Signed-off-by: Matt Roper <matthew.d.roper at intel.com>
>---
> drivers/gpu/drm/i915/gt/selftest_execlists.c | 10 ++++--
> .../gpu/drm/i915/gt/selftest_workarounds.c | 32 ++++++++++++-------
> 2 files changed, 29 insertions(+), 13 deletions(-)
>
>diff --git a/drivers/gpu/drm/i915/gt/selftest_execlists.c b/drivers/gpu/drm/i915/gt/selftest_execlists.c
>index 08896ae027d5..1e7fe2222479 100644
>--- a/drivers/gpu/drm/i915/gt/selftest_execlists.c
>+++ b/drivers/gpu/drm/i915/gt/selftest_execlists.c
>@@ -3561,12 +3561,16 @@ static int smoke_crescendo(struct preempt_smoke *smoke, unsigned int flags)
> #define BATCH BIT(0)
> {
> struct task_struct *tsk[I915_NUM_ENGINES] = {};
>- struct preempt_smoke arg[I915_NUM_ENGINES];
>+ struct preempt_smoke *arg;
> struct intel_engine_cs *engine;
> enum intel_engine_id id;
> unsigned long count;
> int err = 0;
>
>+ arg = kmalloc_array(I915_NUM_ENGINES, sizeof(*arg), GFP_KERNEL);
>+ if (!arg)
>+ return -ENOMEM;
>+
> for_each_engine(engine, smoke->gt, id) {
> arg[id] = *smoke;
> arg[id].engine = engine;
>@@ -3574,7 +3578,7 @@ static int smoke_crescendo(struct preempt_smoke *smoke, unsigned int flags)
> arg[id].batch = NULL;
> arg[id].count = 0;
>
>- tsk[id] = kthread_run(smoke_crescendo_thread, &arg,
>+ tsk[id] = kthread_run(smoke_crescendo_thread, arg,
> "igt/smoke:%d", id);
> if (IS_ERR(tsk[id])) {
> err = PTR_ERR(tsk[id]);
>@@ -3603,6 +3607,8 @@ static int smoke_crescendo(struct preempt_smoke *smoke, unsigned int flags)
>
> pr_info("Submitted %lu crescendo:%x requests across %d engines and %d contexts\n",
> count, flags, smoke->gt->info.num_engines, smoke->ncontext);
>+
>+ kfree(arg);
> return 0;
this looks correctly, but apparently this test doesn't test anything as
`err` is write-only - there is only one read, but basically to avoid
overriding an earlier error.
looks like this should be `return err;` ?
+Chris
This patch itself looks good.
Reviewed-by: Lucas De Marchi <lucas.demarchi at intel.com>
Lucas De Marchi
More information about the dri-devel
mailing list