2012-05-29 19:21:44 +04:00
|
|
|
#!/usr/bin/env perl
|
|
|
|
#
|
|
|
|
# Copyright (c) 2012 Los Alamos National Security, Inc.
|
|
|
|
# All rights reserved.
|
2016-10-12 09:28:16 +03:00
|
|
|
# Copyright (c) 2015-2016 Intel, Inc. All rights reserved.
|
2012-05-29 19:21:44 +04:00
|
|
|
|
|
|
|
use strict;
|
2015-11-08 22:34:06 +03:00
|
|
|
use Getopt::Long;
|
2012-05-29 19:21:44 +04:00
|
|
|
|
|
|
|
# globals
|
2015-11-08 22:34:06 +03:00
|
|
|
my $num_nodes = 2;
|
2012-05-29 19:21:44 +04:00
|
|
|
my $my_arg;
|
2016-12-03 20:59:18 +03:00
|
|
|
my $reps = 5;
|
2015-11-08 00:13:36 +03:00
|
|
|
my $usedvm = 0;
|
2015-11-08 22:34:06 +03:00
|
|
|
my $usesrun = 0;
|
|
|
|
my $usempirun = 0;
|
2015-11-11 12:25:17 +03:00
|
|
|
my $useaprun = 0;
|
2015-11-12 00:29:04 +03:00
|
|
|
my $useaprun = 0;
|
|
|
|
my $myapp;
|
2015-11-08 22:34:06 +03:00
|
|
|
my $runall = 0;
|
2015-11-12 23:11:17 +03:00
|
|
|
my $rawoutput = 0;
|
2016-12-03 20:59:18 +03:00
|
|
|
my $myresults = "myresults";
|
2017-01-30 01:12:51 +03:00
|
|
|
my $ppn = 1;
|
2015-11-12 00:29:04 +03:00
|
|
|
my @csvrow;
|
2012-05-29 19:21:44 +04:00
|
|
|
|
2016-10-12 09:24:52 +03:00
|
|
|
my @tests = qw(/bin/true ./orte_no_op ./mpi_no_op ./mpi_no_op ./mpi_no_op);
|
2017-02-02 03:33:14 +03:00
|
|
|
my @options = ("", "", "", "--fwd-mpirun-port -mca mpi_add_procs_cutoff 0 -mca pmix_base_async_modex 1", "--fwd-mpirun-port -mca mpi_add_procs_cutoff 0 -mca pmix_base_async_modex 1 -mca async_mpi_init 1 -mca async_mpi_finalize 1");
|
2017-01-30 01:12:51 +03:00
|
|
|
my @starterlist = qw(mpirun orterun srun aprun);
|
|
|
|
my @starteroptionlist = ("--novm",
|
|
|
|
"--hnp file:dvm_uri",
|
|
|
|
"--distribution=cyclic -N",
|
|
|
|
"-N");
|
2015-11-08 22:34:06 +03:00
|
|
|
|
|
|
|
# Set to true if the script should merely print the cmds
|
|
|
|
# it would run, but don't run them
|
2016-10-12 09:28:16 +03:00
|
|
|
my $SHOWME = 0;
|
2015-11-08 22:34:06 +03:00
|
|
|
# Set to true to suppress most informational messages.
|
|
|
|
my $QUIET = 0;
|
|
|
|
# Set to true if we just want to see the help message
|
|
|
|
my $HELP = 0;
|
|
|
|
|
|
|
|
GetOptions(
|
|
|
|
"help" => \$HELP,
|
|
|
|
"quiet" => \$QUIET,
|
|
|
|
"showme" => \$SHOWME,
|
|
|
|
"reps=s" => \$reps,
|
|
|
|
"dvm" => \$usedvm,
|
|
|
|
"srun" => \$usesrun,
|
2015-11-11 12:25:17 +03:00
|
|
|
"aprun" => \$useaprun,
|
2015-11-08 22:34:06 +03:00
|
|
|
"mpirun" => \$usempirun,
|
2015-11-12 00:29:04 +03:00
|
|
|
"myapp=s" => \$myapp,
|
2015-11-08 22:34:06 +03:00
|
|
|
"all" => \$runall,
|
2015-11-12 00:29:04 +03:00
|
|
|
"results=s" => \$myresults,
|
2015-11-12 23:11:17 +03:00
|
|
|
"rawout" => \$rawoutput,
|
2017-01-30 01:12:51 +03:00
|
|
|
"ppn=s" => \$ppn,
|
2015-11-08 22:34:06 +03:00
|
|
|
) or die "unable to parse options, stopped";
|
2012-05-29 19:21:44 +04:00
|
|
|
|
2015-11-08 22:34:06 +03:00
|
|
|
if ($HELP) {
|
2016-12-08 20:25:08 +03:00
|
|
|
print "$0 [options]
|
2015-11-08 22:34:06 +03:00
|
|
|
|
|
|
|
--help | -h This help message
|
|
|
|
--quiet | -q Only output critical messages to stdout
|
|
|
|
--showme Show the actual commands without executing them
|
2015-11-12 00:29:04 +03:00
|
|
|
--reps=s Number of times to run each test (for statistics)
|
2017-01-30 01:12:51 +03:00
|
|
|
--mpirun Use mpirun (or its equivalent orterun)
|
|
|
|
--dvm Use orte-dvm to execute the test
|
|
|
|
--srun Use srun (if available) to execute the test
|
|
|
|
--arpun Use aprun (if available) to execute the test
|
2015-11-12 00:29:04 +03:00
|
|
|
--myapp=s In addition to the standard tests, run this specific application (including any args)
|
2015-11-08 22:34:06 +03:00
|
|
|
--all Use all available start commands [default]
|
2015-11-12 00:29:04 +03:00
|
|
|
--results=file File where results are to stored in comma-separated value format
|
2015-11-12 23:11:17 +03:00
|
|
|
--rawout Provide raw timing output to the file
|
2017-01-30 01:12:51 +03:00
|
|
|
--ppn=n Run n procs/node
|
2016-12-08 20:25:08 +03:00
|
|
|
";
|
2015-11-08 22:34:06 +03:00
|
|
|
exit(0);
|
2015-11-08 00:13:36 +03:00
|
|
|
}
|
|
|
|
|
2012-05-29 19:21:44 +04:00
|
|
|
my $n = 1;
|
|
|
|
my $cmd;
|
2015-11-08 00:13:36 +03:00
|
|
|
my $starter;
|
2012-05-29 19:21:44 +04:00
|
|
|
my $test;
|
2012-05-29 21:41:38 +04:00
|
|
|
my $output;
|
2012-05-29 22:21:47 +04:00
|
|
|
my @lines;
|
|
|
|
my $line;
|
2012-05-29 21:41:38 +04:00
|
|
|
my @results;
|
2012-05-29 22:21:47 +04:00
|
|
|
my $res;
|
2012-05-30 01:33:06 +04:00
|
|
|
my $idx;
|
2012-06-01 06:35:15 +04:00
|
|
|
my $option;
|
2015-11-08 22:34:06 +03:00
|
|
|
my $havedvm = 0;
|
2017-01-30 01:12:51 +03:00
|
|
|
my @starters;
|
|
|
|
my @starteroptions;
|
|
|
|
|
|
|
|
# if they asked for all, then set all starters to requested
|
|
|
|
if ($runall) {
|
|
|
|
$useaprun = 1;
|
|
|
|
$usempirun = 1;
|
|
|
|
$usesrun = 1;
|
|
|
|
$usedvm = 1;
|
|
|
|
}
|
2015-11-08 00:13:36 +03:00
|
|
|
|
2015-11-08 22:34:06 +03:00
|
|
|
# see which starters are available
|
|
|
|
my @path = split(":", $ENV{PATH});
|
|
|
|
my $exists = 0;
|
2017-01-30 01:12:51 +03:00
|
|
|
my $opt;
|
2015-11-08 22:34:06 +03:00
|
|
|
$idx=0;
|
2017-01-30 01:12:51 +03:00
|
|
|
foreach $starter (@starterlist) {
|
2015-11-08 22:34:06 +03:00
|
|
|
$exists = 0;
|
|
|
|
foreach my $path (@path) {
|
|
|
|
if ( -x "$path/$starter") {
|
|
|
|
$exists = 1;
|
|
|
|
last;
|
|
|
|
}
|
2015-11-08 00:13:36 +03:00
|
|
|
}
|
2017-01-30 01:12:51 +03:00
|
|
|
if ($exists) {
|
|
|
|
if ($usedvm && $starter eq "orterun") {
|
|
|
|
push @starters, $starter;
|
|
|
|
$opt = $starteroptionlist[$idx] . " --npernode " . $ppn;
|
|
|
|
push @starteroptions, $opt;
|
|
|
|
} elsif ($usempirun && $starter eq "mpirun") {
|
|
|
|
push @starters, $starter;
|
|
|
|
$opt = $starteroptionlist[$idx] . " --npernode " . $ppn;
|
|
|
|
push @starteroptions, $opt;
|
|
|
|
} elsif ($useaprun && $starter eq "aprun") {
|
|
|
|
push @starters, $starter;
|
|
|
|
$opt = $starteroptionlist[$idx] . " " . $ppn;
|
|
|
|
push @starteroptions, $opt;
|
|
|
|
} elsif ($usesrun && $starter eq "srun") {
|
|
|
|
push @starters, $starter;
|
|
|
|
$opt = $starteroptionlist[$idx] . " " . $ppn;
|
|
|
|
push @starteroptions, $opt;
|
|
|
|
}
|
2015-11-08 22:34:06 +03:00
|
|
|
}
|
|
|
|
$idx = $idx + 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
# bozo check
|
|
|
|
if (scalar @starters == 0) {
|
|
|
|
print "No available starters\n";
|
|
|
|
exit;
|
2015-11-08 00:13:36 +03:00
|
|
|
}
|
|
|
|
|
2015-11-12 00:29:04 +03:00
|
|
|
# if they gave us an app, add it to the list of tests
|
|
|
|
if ($myapp) {
|
|
|
|
push @tests, $myapp;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($myresults) {
|
|
|
|
# open the results file
|
|
|
|
open FILE, ">$myresults" || die "file could not be opened";
|
|
|
|
}
|
|
|
|
|
2015-11-08 22:34:06 +03:00
|
|
|
# determine the number of nodes - doesn't
|
|
|
|
# matter which starter we use
|
2017-03-12 18:31:08 +03:00
|
|
|
$cmd = "mpirun --pernode hostname";
|
2015-11-08 22:34:06 +03:00
|
|
|
$output = `$cmd`;
|
|
|
|
@lines = split(/\n/, $output);
|
|
|
|
$num_nodes = $#lines + 1;
|
|
|
|
|
2015-11-12 00:29:04 +03:00
|
|
|
# get the local date and time
|
|
|
|
my ($sec,$min,$hour,$day,$month,$yr19,@rest) = localtime(time);
|
2015-11-08 22:34:06 +03:00
|
|
|
|
2017-01-30 01:12:51 +03:00
|
|
|
my $pstarts = join(", ", @starters);
|
2015-11-12 00:29:04 +03:00
|
|
|
# start by printing out the resulting configuration
|
2015-11-08 22:34:06 +03:00
|
|
|
print "\n--------------------------------------------------\n";
|
2015-11-12 00:29:04 +03:00
|
|
|
print "\nTest configuration:\n";
|
|
|
|
print "\tDate:\t" . "$day-".++$month. "-".($yr19+1900) . " " . sprintf("%02d",$hour).":".sprintf("%02d",$min).":".sprintf("%02d",$sec) . "\n";;
|
|
|
|
print "\tNum nodes:\t" . $num_nodes . "\n";
|
2017-01-30 01:12:51 +03:00
|
|
|
print "\tStarters:\t" . $pstarts . "\n";
|
2015-11-12 00:29:04 +03:00
|
|
|
print "\n--------------------------------------------------\n";
|
|
|
|
|
|
|
|
# and tag the output file as well
|
|
|
|
if ($myresults) {
|
|
|
|
print FILE "Test configuration:\n";
|
|
|
|
print FILE "Date:\t" . "$day-".++$month. "-".($yr19+1900) . " " . sprintf("%02d",$hour).":".sprintf("%02d",$min).":".sprintf("%02d",$sec) . "\n";;
|
|
|
|
print FILE "Num nodes:\t" . $num_nodes . "\n";
|
2017-01-30 01:12:51 +03:00
|
|
|
print FILE "Starters:\t" . $pstarts . "\n";
|
2015-11-12 00:29:04 +03:00
|
|
|
}
|
2015-11-08 22:34:06 +03:00
|
|
|
|
|
|
|
my $index = 0;
|
2015-11-12 23:11:17 +03:00
|
|
|
|
|
|
|
sub runcmd()
|
|
|
|
{
|
|
|
|
for (1..$reps) {
|
|
|
|
$output = `$cmd`;
|
|
|
|
if ($myresults && $rawoutput) {
|
|
|
|
print FILE $n . " " . $output . "\n";
|
|
|
|
}
|
|
|
|
@lines = split(/\n/, $output);
|
|
|
|
foreach $line (@lines) {
|
|
|
|
if (0 <= index($line, "real") ||
|
|
|
|
0 <= index($line, "elapsed")) {
|
|
|
|
# we know that at least one item of interest is
|
|
|
|
# in this line, so let's look for it - start
|
|
|
|
# by getting rid of any leading whitespace
|
|
|
|
$line =~ s/^\s+//;
|
|
|
|
@results = split (/ +/,$line);
|
|
|
|
$idx = 0;
|
|
|
|
foreach $res (@results) {
|
|
|
|
# we are only interested in the real or elapsed time
|
|
|
|
my $strloc = index($res, "real");
|
|
|
|
if (0 <= $strloc) {
|
|
|
|
# some systems put the number in front of
|
|
|
|
# this word, and some append the word to
|
|
|
|
# the number - consider both cases
|
|
|
|
if (0 == $strloc) {
|
|
|
|
if (0 == $idx) {
|
|
|
|
# it must be in the next location
|
|
|
|
push @csvrow,$results[1];
|
|
|
|
} else {
|
|
|
|
# it must be in the prior location
|
|
|
|
push @csvrow,$results[$idx-1];
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
# take the portion of the string up to the tag
|
|
|
|
push @csvrow,substr($res, 0, $strloc);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$strloc = index($res, "elapsed");
|
|
|
|
if (0 <= $strloc) {
|
|
|
|
# some systems put the number in front of
|
|
|
|
# this word, and some append the word to
|
|
|
|
# the number - consider both cases
|
|
|
|
if (0 == $strloc) {
|
|
|
|
if (0 == $idx) {
|
|
|
|
# it must be in the next location
|
|
|
|
push @csvrow,$results[1];
|
|
|
|
} else {
|
|
|
|
# it must be in the prior location
|
|
|
|
push @csvrow,$results[$idx-1];
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
# take the portion of the string up to the tag
|
|
|
|
push @csvrow,substr($res, 0, $strloc);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$idx = $idx + 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
# we have now completed all the reps, so log the results
|
|
|
|
if ($myresults) {
|
|
|
|
my $myout;
|
|
|
|
my $mycnt=0;
|
|
|
|
while ($mycnt <= $#csvrow) {
|
|
|
|
if (0 == $mycnt) {
|
|
|
|
$myout = $csvrow[$mycnt];
|
|
|
|
} else {
|
|
|
|
$myout = $myout . "," . $csvrow[$mycnt];
|
|
|
|
}
|
|
|
|
$mycnt = $mycnt + 1;
|
|
|
|
}
|
|
|
|
print FILE "$myout\n";
|
|
|
|
# clear the output
|
|
|
|
@csvrow = ();
|
|
|
|
}
|
|
|
|
print "\n";
|
|
|
|
}
|
|
|
|
|
2015-11-08 22:34:06 +03:00
|
|
|
foreach $starter (@starters) {
|
2017-01-30 01:12:51 +03:00
|
|
|
print "STARTER: $starter\n";
|
2015-11-12 23:11:17 +03:00
|
|
|
# if we are going to use the dvm, then we
|
2016-10-12 09:24:52 +03:00
|
|
|
if ($starter eq "orterun") {
|
2015-11-12 23:11:17 +03:00
|
|
|
# need to start it
|
|
|
|
if (-e "dvm_uri") {
|
|
|
|
system("rm -f dvm_uri");
|
|
|
|
}
|
|
|
|
$cmd = "orte-dvm --report-uri dvm_uri 2>&1 &";
|
2016-12-03 20:59:18 +03:00
|
|
|
if ($myresults) {
|
|
|
|
print FILE "\n\n$cmd\n";
|
|
|
|
}
|
2015-11-12 23:11:17 +03:00
|
|
|
if (!$SHOWME) {
|
|
|
|
system($cmd);
|
|
|
|
# wait for the rendezvous file to appear
|
|
|
|
while (! -e "dvm_uri") {
|
|
|
|
sleep(1);
|
|
|
|
}
|
|
|
|
$havedvm = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-11-12 00:29:04 +03:00
|
|
|
if ($myresults) {
|
2017-01-30 01:12:51 +03:00
|
|
|
print FILE "$starter $starteroptions[$index]\n\n";
|
2015-11-12 00:29:04 +03:00
|
|
|
}
|
2015-11-08 22:34:06 +03:00
|
|
|
my $testnum = 0;
|
|
|
|
foreach $test (@tests) {
|
|
|
|
$option = $options[$testnum];
|
|
|
|
if (-e $test) {
|
2015-11-12 00:29:04 +03:00
|
|
|
if ($myresults) {
|
2016-12-03 20:59:18 +03:00
|
|
|
print FILE "#nodes,$test,$option\n";
|
2015-11-12 00:29:04 +03:00
|
|
|
}
|
2015-11-08 22:34:06 +03:00
|
|
|
if (!$SHOWME) {
|
|
|
|
# pre-position the executable
|
|
|
|
$cmd = $starter . $starteroptions[$index] . " $test 2>&1";
|
|
|
|
system($cmd);
|
|
|
|
}
|
|
|
|
$n = 1;
|
|
|
|
while ($n <= $num_nodes) {
|
2015-11-12 00:29:04 +03:00
|
|
|
push @csvrow,$n;
|
2017-01-30 01:12:51 +03:00
|
|
|
$cmd = "time " . $starter . " " . $starteroptions[$index] . " $option $test 2>&1";
|
2015-11-08 22:34:06 +03:00
|
|
|
print $cmd . "\n";
|
|
|
|
if (!$SHOWME) {
|
2015-11-12 23:11:17 +03:00
|
|
|
runcmd();
|
2012-05-29 22:21:47 +04:00
|
|
|
}
|
2015-11-08 22:34:06 +03:00
|
|
|
$n = 2 * $n;
|
2012-05-29 19:21:44 +04:00
|
|
|
}
|
2015-11-12 23:11:17 +03:00
|
|
|
if (0 != $num_nodes & $n) {
|
2015-11-08 22:34:06 +03:00
|
|
|
$cmd = "time " . $starter . " " . $starteroptions[$index] . " $option $test 2>&1";
|
|
|
|
print $cmd . "\n";
|
|
|
|
if (!$SHOWME) {
|
2015-11-12 23:11:17 +03:00
|
|
|
runcmd();
|
2012-05-29 22:21:47 +04:00
|
|
|
}
|
2012-05-29 19:21:44 +04:00
|
|
|
}
|
2015-11-08 22:34:06 +03:00
|
|
|
print "\n--------------------------------------------------\n";
|
|
|
|
} else {
|
|
|
|
print "Test " . $test . " was not found - test skipped\n";
|
|
|
|
print "\n--------------------------------------------------\n";
|
2012-05-29 19:21:44 +04:00
|
|
|
}
|
2015-11-08 22:34:06 +03:00
|
|
|
$testnum = $testnum + 1;
|
2012-05-29 19:21:44 +04:00
|
|
|
}
|
2015-11-12 23:11:17 +03:00
|
|
|
if ($havedvm) {
|
|
|
|
if (!$SHOWME) {
|
2016-10-12 09:24:52 +03:00
|
|
|
$cmd = "orterun --hnp file:dvm_uri --terminate";
|
2015-11-12 23:11:17 +03:00
|
|
|
system($cmd);
|
|
|
|
}
|
|
|
|
if (-e "dvm_uri") {
|
|
|
|
system("rm -f dvm_uri");
|
|
|
|
}
|
|
|
|
}
|
2015-11-08 22:34:06 +03:00
|
|
|
$index = $index + 1;
|
2012-05-29 19:21:44 +04:00
|
|
|
}
|
2015-11-08 00:13:36 +03:00
|
|
|
|
2015-11-12 23:11:17 +03:00
|
|
|
if ($myresults) {
|
|
|
|
close(FILE);
|
2015-11-08 00:13:36 +03:00
|
|
|
}
|