Commit 5ebcdf07 authored by Adrian Hunter's avatar Adrian Hunter Committed by Arnaldo Carvalho de Melo

perf test: test_intel_pt.sh: Move helper functions for waiting

Move helper functions for waiting to a separate file so they can be
shared.
Signed-off-by: default avatarAdrian Hunter <adrian.hunter@intel.com>
Acked-by: default avatarNamhyung Kim <namhyung@kernel.org>
Cc: Ian Rogers <irogers@google.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Link: https://lore.kernel.org/r/20220914080150.5888-2-adrian.hunter@intel.comSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent fea753f8
# SPDX-License-Identifier: GPL-2.0
tenths=date\ +%s%1N
# Wait for PID $1 to have $2 number of threads started
wait_for_threads()
{
start_time=$($tenths)
while [ -e "/proc/$1/task" ] ; do
th_cnt=$(find "/proc/$1/task" -mindepth 1 -maxdepth 1 -printf x | wc -c)
if [ "${th_cnt}" -ge "$2" ] ; then
return 0
fi
# Wait at most 5 seconds
if [ $(($($tenths) - start_time)) -ge 50 ] ; then
echo "PID $1 does not have $2 threads"
return 1
fi
done
return 1
}
# Wait for perf record -vvv 2>$2 with PID $1 to start by looking at file $2
# It depends on capturing perf record debug message "perf record has started"
wait_for_perf_to_start()
{
echo "Waiting for \"perf record has started\" message"
start_time=$($tenths)
while [ -e "/proc/$1" ] ; do
if grep -q "perf record has started" "$2" ; then
echo OK
break
fi
# Wait at most 5 seconds
if [ $(($($tenths) - start_time)) -ge 50 ] ; then
echo "perf recording did not start"
return 1
fi
done
return 0
}
# Wait for process PID %1 to exit
wait_for_process_to_exit()
{
start_time=$($tenths)
while [ -e "/proc/$1" ] ; do
# Wait at most 5 seconds
if [ $(($($tenths) - start_time)) -ge 50 ] ; then
echo "PID $1 did not exit as expected"
return 1
fi
done
return 0
}
# Check if PID $1 is still running after 0.3 seconds
is_running()
{
start_time=$($tenths)
while [ -e "/proc/$1" ] ; do
# Check for at least 0.3s
if [ $(($($tenths) - start_time)) -gt 3 ] ; then
return 0
fi
done
echo "PID $1 exited prematurely"
return 1
}
...@@ -4,11 +4,12 @@ ...@@ -4,11 +4,12 @@
set -e set -e
tenths=date\ +%s%1N
# Skip if no Intel PT # Skip if no Intel PT
perf list | grep -q 'intel_pt//' || exit 2 perf list | grep -q 'intel_pt//' || exit 2
shelldir=$(dirname "$0")
. "${shelldir}"/lib/waiting.sh
skip_cnt=0 skip_cnt=0
ok_cnt=0 ok_cnt=0
err_cnt=0 err_cnt=0
...@@ -112,67 +113,6 @@ can_kernel() ...@@ -112,67 +113,6 @@ can_kernel()
return 0 return 0
} }
wait_for_threads()
{
start_time=$($tenths)
while [ -e "/proc/$1/task" ] ; do
th_cnt=$(find "/proc/$1/task" -mindepth 1 -maxdepth 1 -printf x | wc -c)
if [ "${th_cnt}" -ge "$2" ] ; then
return 0
fi
# Wait at most 5 seconds
if [ $(($($tenths) - start_time)) -ge 50 ] ; then
echo "PID $1 does not have $2 threads"
return 1
fi
done
return 1
}
wait_for_perf_to_start()
{
echo "Waiting for \"perf record has started\" message"
start_time=$($tenths)
while [ -e "/proc/$1" ] ; do
if grep -q "perf record has started" "${errfile}" ; then
echo OK
break
fi
# Wait at most 5 seconds
if [ $(($($tenths) - start_time)) -ge 50 ] ; then
echo "perf recording did not start"
return 1
fi
done
return 0
}
wait_for_process_to_exit()
{
start_time=$($tenths)
while [ -e "/proc/$1" ] ; do
# Wait at most 5 seconds
if [ $(($($tenths) - start_time)) -ge 50 ] ; then
echo "PID $1 did not exit as expected"
return 1
fi
done
return 0
}
is_running()
{
start_time=$($tenths)
while [ -e "/proc/$1" ] ; do
# Check for at least 0.3s
if [ $(($($tenths) - start_time)) -gt 3 ] ; then
return 0
fi
done
echo "PID $1 exited prematurely"
return 1
}
test_per_thread() test_per_thread()
{ {
k="$1" k="$1"
...@@ -298,7 +238,7 @@ test_per_thread() ...@@ -298,7 +238,7 @@ test_per_thread()
perf record -B -N --no-bpf-event -o "${perfdatafile}" -e intel_pt//u"${k}" -vvv --per-thread -p "${w1},${w2}" 2>"${errfile}" >"${outfile}" & perf record -B -N --no-bpf-event -o "${perfdatafile}" -e intel_pt//u"${k}" -vvv --per-thread -p "${w1},${w2}" 2>"${errfile}" >"${outfile}" &
ppid=$! ppid=$!
echo "perf PID is $ppid" echo "perf PID is $ppid"
wait_for_perf_to_start ${ppid} || return 1 wait_for_perf_to_start ${ppid} "${errfile}" || return 1
kill ${w1} kill ${w1}
wait_for_process_to_exit ${w1} || return 1 wait_for_process_to_exit ${w1} || return 1
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment