forked from github/verilator
53 lines
1.6 KiB
Perl
53 lines
1.6 KiB
Perl
|
#!/usr/bin/env perl
|
||
|
if (!$::Driver) { use FindBin; exec("$FindBin::Bin/bootstrap.pl", @ARGV, $0); die; }
|
||
|
# DESCRIPTION: Verilator: Verilog Test driver/expect definition
|
||
|
#
|
||
|
# Copyright 2003 by Wilson Snyder. This program is free software; you
|
||
|
# can redistribute it and/or modify it under the terms of either the GNU
|
||
|
# Lesser General Public License Version 3 or the Perl Artistic License
|
||
|
# Version 2.0.
|
||
|
# SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
|
||
|
|
||
|
scenarios(vlt => 1);
|
||
|
|
||
|
# Use any top file
|
||
|
top_filename("t/t_gen_alw.v");
|
||
|
|
||
|
init_benchmarksim();
|
||
|
|
||
|
# As an example, compile and simulate the top file with varying optimization level
|
||
|
my @l_opt = (1,2,3);
|
||
|
|
||
|
foreach my $l_opt (@l_opt) {
|
||
|
compile(
|
||
|
benchmarksim => 1,
|
||
|
v_flags2 => ["-O$l_opt"]
|
||
|
);
|
||
|
|
||
|
execute(
|
||
|
check_finished => 1,
|
||
|
);
|
||
|
}
|
||
|
|
||
|
my $fh = IO::File->new("<".benchmarksim_filename()) or error("Benchmark data file not found");
|
||
|
my $lines = 0;
|
||
|
while (defined(my $line = $fh->getline)) {
|
||
|
if ($line =~ /^#/) { next; }
|
||
|
if ($lines == 0) {
|
||
|
error("Expected header but found $line") if $line ne "evals, time[s]\n";
|
||
|
} else {
|
||
|
my @data = grep {$_ != ""} ($line =~ /(\d*\.?\d*)/g);
|
||
|
error("Expected 2 tokens on line ".$lines." but got ".scalar(@data)) if scalar(@data) != 2;
|
||
|
my $cycles = $data[0];
|
||
|
my $time = $data[1];
|
||
|
error("Invalid data on line ".$lines) if $cycles <= 0.0 || $time <= 0.0;
|
||
|
}
|
||
|
$lines += 1;
|
||
|
}
|
||
|
my $n_lines_expected = scalar(@l_opt) + 1;
|
||
|
|
||
|
error("Expected ".$n_lines_expected." lines but found ".$lines) if int($lines) != int($n_lines_expected);
|
||
|
|
||
|
1;
|
||
|
ok(1);
|