Submitted with incorrect address of i915 list out of top of my head in Cc:, sorry. Janusz On Fri, 2020-12-04 at 12:51 +0100, Janusz Krzysztofik wrote: > We may still be interested in results of a test even if it has tainted > the kernel. On the other hand, we need to kill the test on taint if no > other means of killing it on a jam is active. > > If abort on both kernel taint or a timeout is requested, decrease all > potential timeouts significantly while the taint is detected instead of > aborting immediately. However, report the taint as the reason of the > abort if a timeout decreased by the taint expires. > > Signed-off-by: Janusz Krzysztofik <janusz.krzysztofik@xxxxxxxxxxxxxxx> > --- > runner/executor.c | 30 ++++++++++++++++++++++-------- > 1 file changed, 22 insertions(+), 8 deletions(-) > > diff --git a/runner/executor.c b/runner/executor.c > index 1688ae41d..e39d8a73b 100644 > --- a/runner/executor.c > +++ b/runner/executor.c > @@ -726,6 +726,8 @@ static const char *need_to_timeout(struct settings *settings, > double time_since_kill, > size_t disk_usage) > { > + int decrease = 1; > + > if (killed) { > /* > * Timeout after being killed is a hardcoded amount > @@ -753,20 +755,32 @@ static const char *need_to_timeout(struct settings *settings, > } > > /* > - * If we're configured to care about taints, kill the > - * test if there's a taint. > + * If we're configured to care about taints, > + * decrease timeouts in use if there's a taint, > + * or kill the test if no timeouts have been requested. > */ > if (settings->abort_mask & ABORT_TAINT && > - is_tainted(taints)) > - return "Killing the test because the kernel is tainted.\n"; > + is_tainted(taints)) { > + /* list of timeouts that may postpone immediate kill on taint */ > + if (settings->per_test_timeout || settings->inactivity_timeout) > + decrease = 10; > + else > + return "Killing the test because the kernel is tainted.\n"; > + } > > if (settings->per_test_timeout != 0 && > - time_since_subtest > settings->per_test_timeout) > - return show_kernel_task_state("Per-test timeout exceeded. Killing the current test with SIGQUIT.\n"); > + time_since_subtest > settings->per_test_timeout / decrease) { > + if (decrease > 1) > + return "Killing the test because the kernel is tainted.\n"; > + return "Per-test timeout exceeded. Killing the current test with SIGQUIT.\n"; > + } > > if (settings->inactivity_timeout != 0 && > - time_since_activity > settings->inactivity_timeout) > - return show_kernel_task_state("Inactivity timeout exceeded. Killing the current test with SIGQUIT.\n"); > + time_since_activity > settings->inactivity_timeout / decrease ) { > + if (decrease > 1) > + return "Killing the test because the kernel is tainted.\n"; > + return "Inactivity timeout exceeded. Killing the current test with SIGQUIT.\n"; > + } > > if (disk_usage_limit_exceeded(settings, disk_usage)) > return "Disk usage limit exceeded.\n"; _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/intel-gfx