blob: 249dfe48cf6ad490d1f3066e137d7f843cce00ab [file] [log] [blame]
#!/bin/sh
# perf stat metrics (shadow stat) test
# SPDX-License-Identifier: GPL-2.0
set -e
# skip if system-wide mode is forbidden
perf stat -a true > /dev/null 2>&1 || exit 2
test_global_aggr()
{
local cyc
perf stat -a --no-big-num -e cycles,instructions sleep 1 2>&1 | \
grep -e cycles -e instructions | \
while read num evt hash ipc rest
do
# skip not counted events
if [[ $num == "<not" ]]; then
continue
fi
# save cycles count
if [[ $evt == "cycles" ]]; then
cyc=$num
continue
fi
# skip if no cycles
if [[ -z $cyc ]]; then
continue
fi
# use printf for rounding and a leading zero
local res=`printf "%.2f" $(echo "scale=6; $num / $cyc" | bc -q)`
if [[ $ipc != $res ]]; then
echo "IPC is different: $res != $ipc ($num / $cyc)"
exit 1
fi
done
}
test_no_aggr()
{
declare -A results
perf stat -a -A --no-big-num -e cycles,instructions sleep 1 2>&1 | \
grep ^CPU | \
while read cpu num evt hash ipc rest
do
# skip not counted events
if [[ $num == "<not" ]]; then
continue
fi
# save cycles count
if [[ $evt == "cycles" ]]; then
results[$cpu]=$num
continue
fi
# skip if no cycles
local cyc=${results[$cpu]}
if [[ -z $cyc ]]; then
continue
fi
# use printf for rounding and a leading zero
local res=`printf "%.2f" $(echo "scale=6; $num / $cyc" | bc -q)`
if [[ $ipc != $res ]]; then
echo "IPC is different for $cpu: $res != $ipc ($num / $cyc)"
exit 1
fi
done
}
test_global_aggr
test_no_aggr
exit 0