30 lines
794 B
Perl
30 lines
794 B
Perl
package Queries::Faults;
|
|
|
|
use strict;
|
|
use warnings;
|
|
use diagnostics;
|
|
|
|
sub query {
|
|
my ($experiment) = @_;
|
|
|
|
return "SELECT
|
|
benchmark, resulttype, SUM(t.time2 - t.time1 + 1) AS faults,
|
|
CONCAT('0x', HEX(p.injection_instr_absolute)) AS fault_address
|
|
FROM variant v
|
|
JOIN trace t ON v.id = t.variant_id
|
|
JOIN fspgroup g ON g.variant_id = t.variant_id AND g.instr2 = t.instr2 AND g.data_address = t.data_address
|
|
JOIN result_GenericExperimentMessage r ON r.pilot_id = g.pilot_id
|
|
JOIN fsppilot p ON r.pilot_id = p.id
|
|
WHERE v.variant = '$experiment'
|
|
GROUP BY benchmark, resulttype, p.injection_instr_absolute
|
|
ORDER BY benchmark, resulttype, SUM(t.time2 - t.time1 + 1) DESC;"
|
|
}
|
|
|
|
sub args { return "--batch --raw"; }
|
|
|
|
sub filename { return "faults.csv"; }
|
|
|
|
sub postprocess { $_[0] =~ s/\t/,/g; }
|
|
|
|
1;
|