2012-05-10 23:10:03 +08:00
|
|
|
#!/bin/bash
|
2015-12-08 04:18:50 +08:00
|
|
|
#
|
|
|
|
# Script that checks that critical functions in TSan runtime have correct number
|
|
|
|
# of push/pop/rsp instructions to verify that runtime is efficient enough.
|
2017-08-19 03:22:39 +08:00
|
|
|
#
|
|
|
|
# This test can fail when backend code generation changes the output for various
|
|
|
|
# tsan interceptors. When such a change happens, you can ensure that the
|
|
|
|
# performance has not regressed by running the following benchmarks before and
|
|
|
|
# after the breaking change to verify that the values in this file are safe to
|
|
|
|
# update:
|
2018-11-22 08:00:26 +08:00
|
|
|
# ./projects/compiler-rt/lib/tsan/tests/rtl/TsanRtlTest-x86_64-Test
|
2017-08-19 03:22:39 +08:00
|
|
|
# --gtest_also_run_disabled_tests --gtest_filter=DISABLED_BENCH.Mop*
|
2015-12-08 04:18:50 +08:00
|
|
|
|
2012-05-10 23:10:03 +08:00
|
|
|
set -u
|
|
|
|
|
2015-12-08 04:18:50 +08:00
|
|
|
if [[ "$#" != 1 ]]; then
|
|
|
|
echo "Usage: $0 /path/to/binary/built/with/tsan"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
SCRIPTDIR=$(dirname $0)
|
|
|
|
RES=$(${SCRIPTDIR}/analyze_libtsan.sh $1)
|
2012-05-10 23:10:03 +08:00
|
|
|
PrintRes() {
|
|
|
|
printf "%s\n" "$RES"
|
|
|
|
}
|
|
|
|
|
|
|
|
PrintRes
|
|
|
|
|
|
|
|
check() {
|
|
|
|
res=$(PrintRes | egrep "$1 .* $2 $3; ")
|
|
|
|
if [ "$res" == "" ]; then
|
|
|
|
echo FAILED $1 must contain $2 $3
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2019-02-07 20:43:09 +08:00
|
|
|
for f in write1 write2 write4 write8; do
|
2015-02-03 06:17:23 +08:00
|
|
|
check $f rsp 1
|
2018-09-13 06:16:14 +08:00
|
|
|
check $f push 2
|
2019-02-07 20:43:09 +08:00
|
|
|
done
|
|
|
|
|
2019-02-13 21:21:24 +08:00
|
|
|
for f in read1 read2 read4 read8; do
|
2019-02-07 20:43:09 +08:00
|
|
|
check $f rsp 1
|
2019-04-12 02:05:37 +08:00
|
|
|
check $f push 3
|
2012-05-10 23:10:03 +08:00
|
|
|
done
|
|
|
|
|
2015-02-03 06:17:23 +08:00
|
|
|
for f in func_entry func_exit; do
|
2012-05-10 23:10:03 +08:00
|
|
|
check $f rsp 0
|
|
|
|
check $f push 0
|
|
|
|
check $f pop 0
|
|
|
|
check $f call 1 # TraceSwitch()
|
|
|
|
done
|
|
|
|
|
|
|
|
echo LGTM
|