Skip to content

Commit

Permalink
kselftest/runner.sh: Propagate SIGTERM to runner child
Browse files Browse the repository at this point in the history
Timeouts in kselftest are done using the "timeout" command with the
"--foreground" option. Without the "foreground" option, it is not
possible for a user to cancel the runner using SIGINT, because the
signal is not propagated to timeout which is running in a different
process group. The "forground" options places the timeout in the same
process group as its parent, but only sends the SIGTERM (on timeout)
signal to the forked process. Unfortunately, this does not play nice
with all kselftests, e.g. "net:fcnal-test.sh", where the child
processes will linger because timeout does not send SIGTERM to the
group.

Some users have noted these hangs [1].

Fix this by nesting the timeout with an additional timeout without the
foreground option.

Link: https://lore.kernel.org/all/[email protected]/ # [1]
Fixes: 651e0d8 ("kselftest/runner: allow to properly deliver signals to tests")
Signed-off-by: Björn Töpel <[email protected]>
Signed-off-by: Shuah Khan <[email protected]>
  • Loading branch information
bjorn-rivos authored and shuahkh committed Sep 8, 2023
1 parent f4e4ada commit 9616cb3
Showing 1 changed file with 2 additions and 1 deletion.
3 changes: 2 additions & 1 deletion tools/testing/selftests/kselftest/runner.sh
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,8 @@ tap_timeout()
{
# Make sure tests will time out if utility is available.
if [ -x /usr/bin/timeout ] ; then
/usr/bin/timeout --foreground "$kselftest_timeout" $1
/usr/bin/timeout --foreground "$kselftest_timeout" \
/usr/bin/timeout "$kselftest_timeout" $1
else
$1
fi
Expand Down

0 comments on commit 9616cb3

Please sign in to comment.