Commit 22036829 authored by Ian Rogers's avatar Ian Rogers Committed by Arnaldo Carvalho de Melo

perf test stat+csv_output: Write CSV output to a file

Write the CSV output to a file, then sanity check this output. This
avoids problems with debug/warning/error output corrupting the file
format.
Signed-off-by: default avatarIan Rogers <irogers@google.com>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Athira Rajeev <atrajeev@linux.vnet.ibm.com>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Sumanth Korikkar <sumanthk@linux.ibm.com>
Cc: Thomas Richter <tmricht@linux.ibm.com>
Link: https://lore.kernel.org/r/20230408054456.3001367-2-irogers@google.comSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 3a8b8fc3
...@@ -9,6 +9,20 @@ set -e ...@@ -9,6 +9,20 @@ set -e
skip_test=0 skip_test=0
csv_sep=@ csv_sep=@
stat_output=$(mktemp /tmp/__perf_test.stat_output.csv.XXXXX)
cleanup() {
rm -f "${stat_output}"
trap - EXIT TERM INT
}
trap_cleanup() {
cleanup
exit 1
}
trap trap_cleanup EXIT TERM INT
function commachecker() function commachecker()
{ {
local -i cnt=0 local -i cnt=0
...@@ -30,9 +44,11 @@ function commachecker() ...@@ -30,9 +44,11 @@ function commachecker()
while read line while read line
do do
# Check for lines beginning with Failed # Ignore initial "started on" comment.
x=${line:0:6} x=${line:0:1}
[ "$x" = "Failed" ] && continue [ "$x" = "#" ] && continue
# Ignore initial blank line.
[ "$line" = "" ] && continue
# Count the number of commas # Count the number of commas
x=$(echo $line | tr -d -c $csv_sep) x=$(echo $line | tr -d -c $csv_sep)
...@@ -42,7 +58,7 @@ function commachecker() ...@@ -42,7 +58,7 @@ function commachecker()
echo "wrong number of fields. expected $exp in $line" 1>&2 echo "wrong number of fields. expected $exp in $line" 1>&2
exit 1; exit 1;
} }
done done < "${stat_output}"
return 0 return 0
} }
...@@ -55,7 +71,8 @@ function ParanoidAndNotRoot() ...@@ -55,7 +71,8 @@ function ParanoidAndNotRoot()
check_no_args() check_no_args()
{ {
echo -n "Checking CSV output: no args " echo -n "Checking CSV output: no args "
perf stat -x$csv_sep true 2>&1 | commachecker --no-args perf stat -x$csv_sep -o "${stat_output}" true
commachecker --no-args
echo "[Success]" echo "[Success]"
} }
...@@ -67,27 +84,29 @@ check_system_wide() ...@@ -67,27 +84,29 @@ check_system_wide()
echo "[Skip] paranoid and not root" echo "[Skip] paranoid and not root"
return return
fi fi
perf stat -x$csv_sep -a true 2>&1 | commachecker --system-wide perf stat -x$csv_sep -a -o "${stat_output}" true
commachecker --system-wide
echo "[Success]" echo "[Success]"
} }
check_system_wide_no_aggr() check_system_wide_no_aggr()
{ {
echo -n "Checking CSV output: system wide " echo -n "Checking CSV output: system wide no aggregation "
if ParanoidAndNotRoot 0 if ParanoidAndNotRoot 0
then then
echo "[Skip] paranoid and not root" echo "[Skip] paranoid and not root"
return return
fi fi
echo -n "Checking CSV output: system wide no aggregation " perf stat -x$csv_sep -A -a --no-merge -o "${stat_output}" true
perf stat -x$csv_sep -A -a --no-merge true 2>&1 | commachecker --system-wide-no-aggr commachecker --system-wide-no-aggr
echo "[Success]" echo "[Success]"
} }
check_interval() check_interval()
{ {
echo -n "Checking CSV output: interval " echo -n "Checking CSV output: interval "
perf stat -x$csv_sep -I 1000 true 2>&1 | commachecker --interval perf stat -x$csv_sep -I 1000 -o "${stat_output}" true
commachecker --interval
echo "[Success]" echo "[Success]"
} }
...@@ -95,7 +114,8 @@ check_interval() ...@@ -95,7 +114,8 @@ check_interval()
check_event() check_event()
{ {
echo -n "Checking CSV output: event " echo -n "Checking CSV output: event "
perf stat -x$csv_sep -e cpu-clock true 2>&1 | commachecker --event perf stat -x$csv_sep -e cpu-clock -o "${stat_output}" true
commachecker --event
echo "[Success]" echo "[Success]"
} }
...@@ -107,7 +127,8 @@ check_per_core() ...@@ -107,7 +127,8 @@ check_per_core()
echo "[Skip] paranoid and not root" echo "[Skip] paranoid and not root"
return return
fi fi
perf stat -x$csv_sep --per-core -a true 2>&1 | commachecker --per-core perf stat -x$csv_sep --per-core -a -o "${stat_output}" true
commachecker --per-core
echo "[Success]" echo "[Success]"
} }
...@@ -119,7 +140,8 @@ check_per_thread() ...@@ -119,7 +140,8 @@ check_per_thread()
echo "[Skip] paranoid and not root" echo "[Skip] paranoid and not root"
return return
fi fi
perf stat -x$csv_sep --per-thread -a true 2>&1 | commachecker --per-thread perf stat -x$csv_sep --per-thread -a -o "${stat_output}" true
commachecker --per-thread
echo "[Success]" echo "[Success]"
} }
...@@ -131,7 +153,8 @@ check_per_die() ...@@ -131,7 +153,8 @@ check_per_die()
echo "[Skip] paranoid and not root" echo "[Skip] paranoid and not root"
return return
fi fi
perf stat -x$csv_sep --per-die -a true 2>&1 | commachecker --per-die perf stat -x$csv_sep --per-die -a -o "${stat_output}" true
commachecker --per-die
echo "[Success]" echo "[Success]"
} }
...@@ -143,7 +166,8 @@ check_per_node() ...@@ -143,7 +166,8 @@ check_per_node()
echo "[Skip] paranoid and not root" echo "[Skip] paranoid and not root"
return return
fi fi
perf stat -x$csv_sep --per-node -a true 2>&1 | commachecker --per-node perf stat -x$csv_sep --per-node -a -o "${stat_output}" true
commachecker --per-node
echo "[Success]" echo "[Success]"
} }
...@@ -155,7 +179,8 @@ check_per_socket() ...@@ -155,7 +179,8 @@ check_per_socket()
echo "[Skip] paranoid and not root" echo "[Skip] paranoid and not root"
return return
fi fi
perf stat -x$csv_sep --per-socket -a true 2>&1 | commachecker --per-socket perf stat -x$csv_sep --per-socket -a -o "${stat_output}" true
commachecker --per-socket
echo "[Success]" echo "[Success]"
} }
...@@ -202,4 +227,5 @@ then ...@@ -202,4 +227,5 @@ then
else else
echo "[Skip] Skipping tests for system_wide_no_aggr, per_core, per_die and per_socket since socket id exposed via topology is invalid" echo "[Skip] Skipping tests for system_wide_no_aggr, per_core, per_die and per_socket since socket id exposed via topology is invalid"
fi fi
cleanup
exit 0 exit 0
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