summaryrefslogtreecommitdiff
path: root/tests/scripts/run-throughput-perf.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/scripts/run-throughput-perf.py')
-rw-r--r--tests/scripts/run-throughput-perf.py23
1 files changed, 18 insertions, 5 deletions
diff --git a/tests/scripts/run-throughput-perf.py b/tests/scripts/run-throughput-perf.py
index 4fa43e9b7d..c0ed43a459 100644
--- a/tests/scripts/run-throughput-perf.py
+++ b/tests/scripts/run-throughput-perf.py
@@ -116,6 +116,7 @@ parser.add_argument('-clr_root', dest='clr_root', default=None)
parser.add_argument('-assembly_root', dest='assembly_root', default=None)
parser.add_argument('-benchview_path', dest='benchview_path', default=None)
parser.add_argument('-iterations', dest='iterations', default=5, type=int)
+parser.add_argument('-opt_level', dest='opt_level', default='full_opt')
##########################################################################
# Helper Functions
@@ -141,6 +142,7 @@ def validate_args(args):
assembly_root = args.assembly_root
benchview_path = args.benchview_path
iterations = args.iterations
+ opt_level = args.opt_level.lower()
def validate_arg(arg, check):
""" Validate an individual arg
@@ -162,6 +164,7 @@ def validate_args(args):
valid_build_types = ['Release']
valid_run_types = ['rolling', 'private']
valid_os = ['Windows_NT', 'Ubuntu14.04']
+ valid_opt_levels = ['full_opt', 'min_opt']
arch = next((a for a in valid_archs if a.lower() == arch.lower()), arch)
build_type = next((b for b in valid_build_types if b.lower() == build_type.lower()), build_type)
@@ -174,6 +177,7 @@ def validate_args(args):
validate_arg(build_type, lambda item: item in valid_build_types)
validate_arg(run_type, lambda item: item in valid_run_types)
validate_arg(iterations, lambda item: item > 0)
+ validate_arg(opt_level, lambda item: item in valid_opt_levels)
if clr_root is None:
raise Exception('--clr_root must be set')
@@ -191,7 +195,7 @@ def validate_args(args):
benchview_path = os.path.normpath(benchview_path)
validate_arg(benchview_path, lambda item: os.path.isdir(benchview_path))
- args = (arch, operating_system, os_group, build_type, run_type, clr_root, assembly_root, benchview_path, iterations)
+ args = (arch, operating_system, os_group, build_type, run_type, clr_root, assembly_root, benchview_path, iterations, opt_level)
# Log configuration
log('Configuration:')
@@ -199,6 +203,7 @@ def validate_args(args):
log(' os: %s' % operating_system)
log(' os_group: %s' % os_group)
log(' build_type: %s' % build_type)
+ log(' opt_level: %s' % opt_level)
log(' run_type: %s' % run_type)
log(' iterations: %d' % iterations)
log(' clr_root: %s' % clr_root)
@@ -256,7 +261,7 @@ def generateCSV(dll_name, dll_runtimes):
return csv_file_name
-def runIterations(dll_name, dll_path, iterations, crossgen_path, jit_path, assemblies_path):
+def runIterations(dll_name, dll_path, iterations, crossgen_path, jit_path, assemblies_path, opt_level):
""" Run throughput testing for a given dll
Args:
dll_name: the name of the dll
@@ -280,13 +285,18 @@ def runIterations(dll_name, dll_path, iterations, crossgen_path, jit_path, assem
dll_path
]
+ my_env = os.environ
+
+ if opt_level == 'min_opt':
+ my_env['COMPlus_JITMinOpts'] = '1'
+
log(" ".join(run_args))
# Time.clock() returns seconds, with a resolution of 0.4 microseconds, so multiply by the multiplier to get milliseconds
multiplier = 1000
for iteration in range(0,iterations + 1):
- proc = subprocess.Popen(run_args, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
+ proc = subprocess.Popen(run_args, stdout=subprocess.PIPE, stderr=subprocess.PIPE, env=my_env)
start_time = timeit.default_timer()
(out, err) = proc.communicate()
@@ -312,7 +322,7 @@ def main(args):
global os_group_list
global python_exe_list
- architecture, operating_system, os_group, build_type, run_type, clr_root, assembly_root, benchview_path, iterations = validate_args(args)
+ architecture, operating_system, os_group, build_type, run_type, clr_root, assembly_root, benchview_path, iterations, opt_level = validate_args(args)
arch = architecture
current_dir = os.getcwd()
@@ -351,7 +361,7 @@ def main(args):
(not dll_file_name in dll_exclude_list["All"])):
dll_name = dll_file_name.replace(".dll", "")
dll_path = os.path.join(assembly_root, dll_file_name)
- dll_elapsed_times = runIterations(dll_file_name, dll_path, iterations, crossgen_path, jit_path, assembly_root)
+ dll_elapsed_times = runIterations(dll_file_name, dll_path, iterations, crossgen_path, jit_path, assembly_root, opt_level)
if len(dll_elapsed_times) != 0:
if not benchview_path is None:
@@ -404,6 +414,9 @@ def main(args):
"--config",
"OS",
operating_system,
+ "--config",
+ "OptLevel",
+ opt_level,
"--arch",
architecture,
"--machinepool",