data-aggregator: script overhaul + modularization
Change-Id: I4353db1475f00956d19d91c8c558c34506ec836b
This commit is contained in:
@ -1,44 +1,24 @@
|
||||
#!/bin/bash
|
||||
set -e
|
||||
|
||||
if [ "$1" = -t ]; then
|
||||
FORMAT=-t
|
||||
shift
|
||||
else
|
||||
FORMAT=-B
|
||||
fi
|
||||
|
||||
if [ ! $# -eq 3 ]; then
|
||||
echo "usage: $0 [ -t ] DATABASE VARIANT BENCHMARK" >&2
|
||||
echo " -t Display output in table format (tab-separated CSV otherwise)" >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
DATABASE=$1
|
||||
VARIANT=$2
|
||||
BENCHMARK=$3
|
||||
MYSQL="mysql $FORMAT $DATABASE"
|
||||
source $(dirname $0)/fail-analysis-common.inc.sh
|
||||
|
||||
$MYSQL << EOT
|
||||
SELECT v.benchmark, v.variant, s.name, s.size, r.resulttype,
|
||||
SUM(t.time2-t.time1+1)
|
||||
/
|
||||
(SELECT SUM(t.time2-t.time1+1)
|
||||
FROM variant v
|
||||
INNER JOIN symbol s ON v.id = s.variant_id
|
||||
INNER JOIN trace t ON t.variant_id = v.id AND t.data_address BETWEEN s.address AND s.address + s.size - 1
|
||||
INNER JOIN fspgroup g ON t.variant_id = g.variant_id AND t.data_address = g.data_address AND t.instr2 = g.instr2
|
||||
INNER JOIN result_GenericExperimentMessage r ON r.pilot_id = g.pilot_id
|
||||
WHERE v.variant="$VARIANT"
|
||||
AND v.benchmark="$BENCHMARK"
|
||||
) AS coverage
|
||||
FROM variant v
|
||||
INNER JOIN symbol s ON v.id = s.variant_id
|
||||
INNER JOIN trace t ON t.variant_id = v.id AND t.data_address BETWEEN s.address AND s.address + s.size - 1
|
||||
INNER JOIN fspgroup g ON t.variant_id = g.variant_id AND t.data_address = g.data_address AND t.instr2 = g.instr2
|
||||
INNER JOIN result_GenericExperimentMessage r ON r.pilot_id = g.pilot_id
|
||||
WHERE v.variant="$VARIANT"
|
||||
AND v.benchmark="$BENCHMARK"
|
||||
GROUP BY v.benchmark, v.variant, s.name, r.resulttype
|
||||
ORDER BY v.benchmark, v.variant, s.name, r.resulttype;
|
||||
SELECT v.benchmark, v.variant, s.name, s.size, r.resulttype,
|
||||
SUM(t.time2-t.time1+1)
|
||||
/
|
||||
(SELECT SUM(t.time2-t.time1+1)
|
||||
FROM symbol s
|
||||
INNER JOIN trace t ON t.variant_id = s.variant_id AND t.data_address BETWEEN s.address AND s.address + s.size - 1
|
||||
INNER JOIN fspgroup g ON t.variant_id = g.variant_id AND t.data_address = g.data_address AND t.instr2 = g.instr2
|
||||
INNER JOIN result_GenericExperimentMessage r ON r.pilot_id = g.pilot_id
|
||||
WHERE t.variant_id = v.id -- refers to parent query
|
||||
) AS coverage
|
||||
FROM variant v
|
||||
INNER JOIN symbol s ON v.id = s.variant_id
|
||||
INNER JOIN trace t ON t.variant_id = v.id AND t.data_address BETWEEN s.address AND s.address + s.size - 1
|
||||
INNER JOIN fspgroup g ON t.variant_id = g.variant_id AND t.data_address = g.data_address AND t.instr2 = g.instr2
|
||||
INNER JOIN result_GenericExperimentMessage r ON r.pilot_id = g.pilot_id
|
||||
WHERE $FILTER
|
||||
GROUP BY v.id, s.name, r.resulttype
|
||||
ORDER BY v.benchmark, v.variant, s.name, r.resulttype;
|
||||
EOT
|
||||
|
||||
Reference in New Issue
Block a user