Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 # Copyright 2016 The Chromium Authors. All rights reserved. | |
| 2 # Use of this source code is governed by a BSD-style license that can be | |
| 3 # found in the LICENSE file. | |
| 4 """Utility script to run the benchmarks during the profiling step of a PGO | |
|
scottmg
2016/09/27 17:39:30
nit; blank line after copyright before block comme
Sébastien Marchand
2016/09/27 17:59:56
Done.
| |
| 5 build. | |
| 6 """ | |
| 7 | |
| 8 import json | |
| 9 import optparse | |
| 10 import os | |
| 11 import subprocess | |
| 12 import sys | |
| 13 | |
| 14 # Make sure that we're running as admin, this is required to run the Telemetry | |
| 15 # benchmarks. | |
| 16 from win32com.shell import shell | |
| 17 if not shell.IsUserAnAdmin(): | |
| 18 raise Exception('This script has to be run as admin.') | |
| 19 | |
| 20 | |
| 21 _SCRIPT_DIR = os.path.dirname(os.path.realpath(__file__)) | |
| 22 _CHROME_BUILD_DIR = os.path.dirname(_SCRIPT_DIR) | |
| 23 _CHROME_SRC_DIR = os.path.dirname(_CHROME_BUILD_DIR) | |
| 24 | |
| 25 | |
| 26 # List of the benchmark that we run during the profiling step. | |
| 27 _BENCHMARKS_TO_RUN = { | |
| 28 'blink_perf.bindings', | |
| 29 'blink_perf.canvas', | |
| 30 'blink_perf.css', | |
| 31 'blink_perf.dom', | |
| 32 'blink_perf.paint', | |
| 33 'blink_perf.svg', | |
| 34 'blink_style.top_25', | |
| 35 'dromaeo.cssqueryjquery', | |
| 36 'dromaeo.domcoreattr', | |
| 37 'dromaeo.domcoremodify', | |
| 38 'dromaeo.domcorequery', | |
| 39 'dromaeo.domcoretraverse', | |
| 40 'dromaeo.jslibattrprototype', | |
| 41 'dromaeo.jslibeventprototype', | |
| 42 'dromaeo.jslibmodifyprototype', | |
| 43 'dromaeo.jslibstyleprototype', | |
| 44 'dromaeo.jslibtraversejquery', | |
| 45 'dromaeo.jslibtraverseprototype', | |
| 46 'indexeddb_perf', | |
| 47 'media.tough_video_cases', | |
| 48 'octane', | |
| 49 'smoothness.top_25_smooth', | |
| 50 'speedometer', | |
| 51 'sunspider', | |
| 52 } | |
| 53 | |
| 54 | |
| 55 def FindPgosweep(target_bits): | |
| 56 """Find the directory containing pgosweep.exe.""" | |
|
scottmg
2016/09/27 17:39:30
nit; " target_bits should be 32 or 64." since I pr
Sébastien Marchand
2016/09/27 17:59:55
Done, added a check as well.
| |
| 57 win_toolchain_json_file = os.path.join(_CHROME_BUILD_DIR, | |
| 58 'win_toolchain.json') | |
| 59 if not os.path.exists(win_toolchain_json_file): | |
| 60 raise Exception('The toolchain JSON file (%s) is missing.' % | |
| 61 win_toolchain_json_file) | |
| 62 with open(win_toolchain_json_file) as temp_f: | |
| 63 toolchain_data = json.load(temp_f) | |
| 64 if not os.path.isdir(toolchain_data['path']): | |
| 65 raise Exception('The toolchain JSON file is invalid.') | |
|
scottmg
2016/09/27 17:39:30
nit; 'The toolchain JSON file's "path" entry (%s)
Sébastien Marchand
2016/09/27 17:59:56
Done.
| |
| 66 | |
| 67 pgo_sweep_dir = os.path.join(toolchain_data['path'], 'VC', 'bin') | |
| 68 if target_bits == 64: | |
| 69 pgo_sweep_dir = os.path.join(pgo_sweep_dir, 'amd64') | |
| 70 | |
| 71 if not os.path.exists(os.path.join(pgo_sweep_dir, 'pgosweep.exe')): | |
| 72 raise Exception('pgosweep.exe is missing from %s.' % pgo_sweep_dir) | |
| 73 | |
| 74 return pgo_sweep_dir | |
| 75 | |
| 76 | |
| 77 def RunBenchmarks(options): | |
| 78 """Run the benchmarks.""" | |
| 79 # Starts by finding the directory containing pgosweep.exe | |
| 80 pgo_sweep_dir = FindPgosweep(options.target_bits) | |
| 81 if not pgo_sweep_dir: | |
|
scottmg
2016/09/27 17:39:30
I don't think this can return empty/None because t
Sébastien Marchand
2016/09/27 17:59:56
Ha, good point!
| |
| 82 return 1 | |
| 83 | |
| 84 # Find the run_benchmark script. | |
| 85 chrome_run_benchmark_script = os.path.join(_CHROME_SRC_DIR, 'tools', | |
| 86 'perf', 'run_benchmark') | |
| 87 if not os.path.exists(chrome_run_benchmark_script): | |
| 88 raise Exception('Unable to find the run_benchmark script ' | |
| 89 '(%s doesn\'t exist) ' % chrome_run_benchmark_script) | |
| 90 | |
| 91 # Augment the PATH to make sure that the benchmarking script can find | |
| 92 # pgosweep.exe and its runtime libraries. | |
| 93 env = os.environ.copy() | |
| 94 env['PATH'] = str(os.pathsep.join([pgo_sweep_dir, options.build_dir, | |
| 95 os.environ['PATH']])) | |
| 96 env['PogoSafeMode'] = '1' | |
| 97 # Apply a scaling factor of 0.5 to the PGO profiling buffers for the 32-bit | |
| 98 # builds, without this the buffers will be too large and the process will | |
| 99 # fail to start. See crbug.com/632864#c22. | |
| 100 if options.target_bits == 32: | |
| 101 env['VCPROFILE_ALLOC_SCALE'] = '0.5' | |
| 102 | |
| 103 # Run all the benchmarks. | |
| 104 # TODO(sebmarchand): Make this run in parallel. | |
|
scottmg
2016/09/27 17:39:30
[Seems like you wouldn't want to run benchmarks in
Sébastien Marchand
2016/09/27 17:59:56
I don't think that it could cause any issue? When
| |
| 105 for benchmark in _BENCHMARKS_TO_RUN: | |
| 106 try: | |
| 107 benchmark_command = [ | |
| 108 sys.executable, | |
| 109 chrome_run_benchmark_script, | |
| 110 '--browser', options.browser_type, | |
| 111 ] | |
| 112 # Automatically set the arguments to run this script on a local build. | |
| 113 if options.browser_type == 'exact': | |
| 114 benchmark_command += [ | |
| 115 '--browser-executable', os.path.join(options.build_dir, 'chrome.exe') | |
| 116 ] | |
| 117 benchmark_command += [ | |
| 118 '--profiler', 'win_pgo_profiler', | |
| 119 benchmark | |
| 120 ] | |
| 121 subprocess.call(benchmark_command, env=env) | |
|
scottmg
2016/09/27 17:39:30
check_call maybe?
Sébastien Marchand
2016/09/27 17:59:56
Done.
| |
| 122 except: | |
| 123 continue | |
|
scottmg
2016/09/27 17:39:30
log something about exception maybe?
Sébastien Marchand
2016/09/27 17:59:55
Done.
| |
| 124 | |
| 125 return 0 | |
| 126 | |
| 127 | |
| 128 def main(): | |
| 129 parser = optparse.OptionParser(usage='%prog [options]') | |
| 130 parser.add_option( | |
| 131 '--browser-type', help='The browser type (to be passed to Telemetry\'s ' | |
| 132 'benchmark runner).') | |
| 133 # TODO(sebmarchand): Parse the args.gn file to automatically set this value. | |
| 134 parser.add_option('--target-bits', help='The target\'s bitness.', type=int) | |
|
scottmg
2016/09/27 17:39:30
Maybe "target_cpu" and make it a string that's "x8
Sébastien Marchand
2016/09/27 17:59:56
Done.
| |
| 135 parser.add_option('--build-dir', help='Chrome build directory.') | |
| 136 options, _ = parser.parse_args() | |
| 137 | |
| 138 if not options.target_bits: | |
| 139 parser.error('--target-bits is required') | |
| 140 if not options.build_dir: | |
| 141 parser.error('--build-dir is required') | |
| 142 if not options.browser_type: | |
| 143 options.browser_type = 'exact' | |
| 144 | |
| 145 return RunBenchmarks(options) | |
| 146 | |
| 147 | |
| 148 if __name__ == '__main__': | |
| 149 sys.exit(main()) | |
| OLD | NEW |