2022-05-24 10:54:22 +03:00
|
|
|
#!/bin/sh
|
|
|
|
|
# Miscellaneous Intel PT testing
|
|
|
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
|
|
|
|
|
# Skip if no Intel PT
|
|
|
|
|
perf list | grep -q 'intel_pt//' || exit 2
|
|
|
|
|
|
|
|
|
|
skip_cnt=0
|
|
|
|
|
ok_cnt=0
|
|
|
|
|
err_cnt=0
|
|
|
|
|
|
2022-09-12 11:34:03 +03:00
|
|
|
temp_dir=$(mktemp -d /tmp/perf-test-intel-pt-sh.XXXXXXXXXX)
|
|
|
|
|
|
|
|
|
|
tmpfile="${temp_dir}/tmp-perf.data"
|
|
|
|
|
perfdatafile="${temp_dir}/test-perf.data"
|
2022-05-24 10:54:22 +03:00
|
|
|
|
2022-09-12 11:34:02 +03:00
|
|
|
cleanup()
|
|
|
|
|
{
|
|
|
|
|
trap - EXIT TERM INT
|
2022-09-12 11:34:03 +03:00
|
|
|
sane=$(echo "${temp_dir}" | cut -b 1-26)
|
|
|
|
|
if [ "${sane}" = "/tmp/perf-test-intel-pt-sh" ] ; then
|
|
|
|
|
echo "--- Cleaning up ---"
|
|
|
|
|
rm -f "${temp_dir}/"*
|
|
|
|
|
rmdir "${temp_dir}"
|
|
|
|
|
fi
|
2022-09-12 11:34:02 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
trap_cleanup()
|
|
|
|
|
{
|
|
|
|
|
cleanup
|
|
|
|
|
exit 1
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
trap trap_cleanup EXIT TERM INT
|
|
|
|
|
|
2022-05-24 10:54:22 +03:00
|
|
|
can_cpu_wide()
|
|
|
|
|
{
|
2022-09-12 11:34:08 +03:00
|
|
|
perf record -o "${tmpfile}" -B -N --no-bpf-event -e dummy:u -C "$1" true >/dev/null 2>&1 || return 2
|
2022-05-24 10:54:22 +03:00
|
|
|
return 0
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
test_system_wide_side_band()
|
|
|
|
|
{
|
|
|
|
|
# Need CPU 0 and CPU 1
|
|
|
|
|
can_cpu_wide 0 || return $?
|
|
|
|
|
can_cpu_wide 1 || return $?
|
|
|
|
|
|
|
|
|
|
# Record on CPU 0 a task running on CPU 1
|
2022-09-12 11:34:08 +03:00
|
|
|
perf record -B -N --no-bpf-event -o "${perfdatafile}" -e intel_pt//u -C 0 -- taskset --cpu-list 1 uname
|
2022-05-24 10:54:22 +03:00
|
|
|
|
|
|
|
|
# Should get MMAP events from CPU 1 because they can be needed to decode
|
2022-09-12 11:34:08 +03:00
|
|
|
mmap_cnt=$(perf script -i "${perfdatafile}" --no-itrace --show-mmap-events -C 1 2>/dev/null | grep -c MMAP)
|
2022-05-24 10:54:22 +03:00
|
|
|
|
2022-09-12 11:34:08 +03:00
|
|
|
if [ "${mmap_cnt}" -gt 0 ] ; then
|
2022-05-24 10:54:22 +03:00
|
|
|
return 0
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
echo "Failed to record MMAP events on CPU 1 when tracing CPU 0"
|
|
|
|
|
return 1
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
count_result()
|
|
|
|
|
{
|
2022-09-12 11:34:08 +03:00
|
|
|
if [ "$1" -eq 2 ] ; then
|
2022-09-12 11:34:05 +03:00
|
|
|
skip_cnt=$((skip_cnt + 1))
|
2022-05-24 10:54:22 +03:00
|
|
|
return
|
|
|
|
|
fi
|
2022-09-12 11:34:08 +03:00
|
|
|
if [ "$1" -eq 0 ] ; then
|
2022-09-12 11:34:05 +03:00
|
|
|
ok_cnt=$((ok_cnt + 1))
|
2022-05-24 10:54:22 +03:00
|
|
|
return
|
|
|
|
|
fi
|
2022-09-12 11:34:05 +03:00
|
|
|
err_cnt=$((err_cnt + 1))
|
2022-09-12 11:34:09 +03:00
|
|
|
ret=0
|
2022-05-24 10:54:22 +03:00
|
|
|
}
|
|
|
|
|
|
2022-09-12 11:34:09 +03:00
|
|
|
ret=0
|
|
|
|
|
test_system_wide_side_band || ret=$? ; count_result $ret
|
2022-05-24 10:54:22 +03:00
|
|
|
|
2022-09-12 11:34:02 +03:00
|
|
|
cleanup
|
2022-05-24 10:54:22 +03:00
|
|
|
|
|
|
|
|
if [ ${err_cnt} -gt 0 ] ; then
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
if [ ${ok_cnt} -gt 0 ] ; then
|
|
|
|
|
exit 0
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
exit 2
|