Tests: Support remote test obj_

This commit is contained in:
Wilson Snyder 2019-06-15 16:37:58 -04:00
parent 659c7b78d5
commit 0edd3c9e95

View File

@ -20,6 +20,7 @@ use Getopt::Long;
use IO::File; use IO::File;
use Pod::Usage; use Pod::Usage;
use Data::Dumper; $Data::Dumper::Sortkeys=1; use Data::Dumper; $Data::Dumper::Sortkeys=1;
use FindBin qw($RealBin);
use strict; use strict;
use vars qw($Debug %Vars $Driver $Fork); use vars qw($Debug %Vars $Driver $Fork);
use POSIX qw(strftime); use POSIX qw(strftime);
@ -125,7 +126,7 @@ our @Test_Dirs = "t";
push @Test_Dirs, split(/:/,$ENV{VERILATOR_TESTS_SITE}) push @Test_Dirs, split(/:/,$ENV{VERILATOR_TESTS_SITE})
if (($#opt_tests<0 ? $opt_site : 1) && $ENV{VERILATOR_TESTS_SITE}); if (($#opt_tests<0 ? $opt_site : 1) && $ENV{VERILATOR_TESTS_SITE});
if ($#opt_tests<0) { if ($#opt_tests<0) { # Run everything
my %uniq; my %uniq;
foreach my $dir (@Test_Dirs) { foreach my $dir (@Test_Dirs) {
my @stats = stat($dir); # Uniquify by inode, so different paths to same place get combined my @stats = stat($dir); # Uniquify by inode, so different paths to same place get combined
@ -313,6 +314,7 @@ use Carp;
use Cwd; use Cwd;
use Data::Dumper; use Data::Dumper;
use File::Spec; use File::Spec;
use File::Path qw(mkpath);
use vars qw($Self $Self); use vars qw($Self $Self);
use strict; use strict;
@ -334,10 +336,6 @@ sub new {
$self->{scenario} ||= "ms" if $self->{ms}; $self->{scenario} ||= "ms" if $self->{ms};
$self->{scenario} ||= "iv" if $self->{iv}; $self->{scenario} ||= "iv" if $self->{iv};
# For backward compatibility, the verilator tests have no prefix
mkdir "obj_$self->{scenario}";
$self->{obj_dir} ||= ("obj_$self->{scenario}/$self->{name}");
foreach my $dir (@::Test_Dirs) { foreach my $dir (@::Test_Dirs) {
# t_dir used both absolutely and under obj_dir # t_dir used both absolutely and under obj_dir
if (-e "$dir/$self->{name}.pl") { if (-e "$dir/$self->{name}.pl") {
@ -351,6 +349,13 @@ sub new {
} }
$self->{t_dir} or die "%Error: Can't locate dir for $self->{name},"; $self->{t_dir} or die "%Error: Can't locate dir for $self->{name},";
if (!$self->{obj_dir}) {
my $scen_dir = File::Spec->abs2rel("$self->{t_dir}/../obj_$self->{scenario}");
$scen_dir =~ s!^t/\.\./!!; # Simplify filenames on local runs
mkdir $scen_dir; # Not a mkpath so find out if trying to build somewhere odd
$self->{obj_dir} ="$scen_dir/$self->{name}";
}
$self = { $self = {
name => undef, # Set below, name of this test name => undef, # Set below, name of this test
pl_filename => undef, # Name of .pl file to get setup from pl_filename => undef, # Name of .pl file to get setup from
@ -362,14 +367,15 @@ sub new {
verbose => $opt_verbose, verbose => $opt_verbose,
run_env => '', run_env => '',
# All compilers # All compilers
v_flags => [split(/\s+/,(" -f input.vc " v_flags => [split(/\s+/,
.($self->{t_dir} !~ m!/test_regress! # Don't include standard dir, only site's ((-r 'input.vc' ? " -f input.vc " : "")
? " +incdir+$self->{t_dir} -y $self->{t_dir}" : "") .($self->{t_dir} !~ m!/test_regress! # Don't include standard dir, only site's
. " +define+TEST_OBJ_DIR=$self->{obj_dir}" ? " +incdir+$self->{t_dir} -y $self->{t_dir}" : "")
.($opt_verbose ? " +define+TEST_VERBOSE=1":"") . " +define+TEST_OBJ_DIR=$self->{obj_dir}"
.($opt_benchmark ? " +define+TEST_BENCHMARK=$opt_benchmark":"") .($opt_verbose ? " +define+TEST_VERBOSE=1":"")
.($opt_trace ? " +define+WAVES=1":"") .($opt_benchmark ? " +define+TEST_BENCHMARK=$opt_benchmark":"")
))], .($opt_trace ? " +define+WAVES=1":"")
))],
v_flags2 => [], # Overridden in some sim files v_flags2 => [], # Overridden in some sim files
v_other_filenames => [], # After the filename so we can spec multiple files v_other_filenames => [], # After the filename so we can spec multiple files
all_run_flags => [], all_run_flags => [],
@ -624,7 +630,7 @@ sub compile_vlt_flags {
unshift @verilator_flags, "--O".$letters; unshift @verilator_flags, "--O".$letters;
} }
my @cmdargs = ("perl","../bin/verilator", my @cmdargs = ("perl", "$ENV{VERILATOR_ROOT}/bin/verilator",
"--prefix ".$param{VM_PREFIX}, "--prefix ".$param{VM_PREFIX},
@verilator_flags, @verilator_flags,
@{$param{verilator_flags2}}, @{$param{verilator_flags2}},
@ -797,7 +803,7 @@ sub compile {
$self->_run(logfile=>"$self->{obj_dir}/vlt_gcc.log", $self->_run(logfile=>"$self->{obj_dir}/vlt_gcc.log",
cmd=>["make", cmd=>["make",
"-C ".$self->{obj_dir}, "-C ".$self->{obj_dir},
"-f ".getcwd()."/Makefile_obj", "-f ".$::RealBin."/Makefile_obj",
"VM_PREFIX=$self->{VM_PREFIX}", "VM_PREFIX=$self->{VM_PREFIX}",
"TEST_OBJ_DIR=$self->{obj_dir}", "TEST_OBJ_DIR=$self->{obj_dir}",
"CPPFLAGS_DRIVER=-D".uc($self->{name}), "CPPFLAGS_DRIVER=-D".uc($self->{name}),
@ -1560,7 +1566,7 @@ sub _read_inputs_vhdl {
our $_Verilator_Version; our $_Verilator_Version;
sub verilator_version { sub verilator_version {
if (!defined $_Verilator_Version) { if (!defined $_Verilator_Version) {
my @args = ("perl","../bin/verilator", "--version"); my @args = ("perl", "$ENV{VERILATOR_ROOT}/bin/verilator", "--version");
my $args = join(' ',@args); my $args = join(' ',@args);
$_Verilator_Version = `$args`; $_Verilator_Version = `$args`;
$_Verilator_Version or die "can't fork: $! ".join(' ',@args); $_Verilator_Version or die "can't fork: $! ".join(' ',@args);
@ -2224,7 +2230,7 @@ Command to use to invoke ncverilog.
=item VERILATOR_TESTS_SITE =item VERILATOR_TESTS_SITE
With --site, directory of tests to be added to testlist. Used with --site, a colon-separated list of directories with tests to be added to testlist.
=item VERILATOR_VCS =item VERILATOR_VCS