1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39
|
#!/bin/sh
#
# Check decoding of threads when a non-leader thread invokes execve.
#
# Copyright (c) 2016 Dmitry V. Levin <ldv@strace.io>
# Copyright (c) 2016-2023 The strace developers.
# All rights reserved.
#
# SPDX-License-Identifier: GPL-2.0-or-later
. "${srcdir=.}/init.sh"
# Check that PTRACE_EVENT_EXEC support in kernel is good enough.
# The kernel before commit v3.1-rc1~308^2~7 reported 0 instead of old pid.
require_min_kernel_version_or_skip 3.1
# This test requires some concurrency between threads.
require_min_nproc 2
opts="${*:-}"
check_prog diff
run_prog_skip_if_failed date +%s > /dev/null
s0="$(date +%s)"
run_prog > /dev/null
set -- -a21 -f -esignal=none -e trace=execve,exit,nanosleep,rt_sigsuspend $opts $args
# Due to probabilistic nature of the test, try it several times.
while :; do
run_strace "$@" > "$EXP"
sed 1d < "$LOG" > "$OUT"
diff -- "$EXP" "$OUT" && exit 0
s1="$(date +%s)"
if [ "$((s1-s0))" -gt "$((TIMEOUT_DURATION/2))" ]; then
fail_ "$STRACE $* output mismatch"
fi
done
|