Configure PGO builders

- add new d8_pgo isolate to be used in profile tasks;
 - configure swarming task (test) for PGO instrumentation builder
 - create script for profile only execution (no build) to be used in swarming

Led tested #1 with spike recipe #2. Example swarming task #3.

#1 https://chromium-swarm.appspot.com/task?id=60089d22e809e410
#2 https://chromium-review.googlesource.com/c/chromium/tools/build/+/4162092/11
#3 https://chromium-swarm.appspot.com/task?id=60089fcbafb0a610

Bug: chromium:1382471
Change-Id: I782b7874c8dd77e821715395dd54dbc8990bf2c6
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/4173584
Reviewed-by: Michael Achenbach <machenbach@chromium.org>
Commit-Queue: Liviu Rau <liviurau@google.com>
Cr-Commit-Position: refs/heads/main@{#85521}
This commit is contained in:
Liviu Rau 2023-01-27 14:16:14 +01:00 committed by V8 LUCI CQ
parent b9a0abd23e
commit fec8c611c8
4 changed files with 117 additions and 0 deletions

View File

@ -31,6 +31,10 @@
"label": "//test:v8_d8_default",
"type": "script",
},
"d8_pgo": {
"label": "//test:d8_pgo",
"type": "script",
},
"generate-bytecode-expectations": {
"label": "//test/unittests:generate-bytecode-expectations",
"type": "script",

View File

@ -1289,6 +1289,14 @@
{'name': 'v8testing'},
],
},
'V8 Linux PGO instrumentation - builder' : {
'swarming_dimensions': {
'os': 'Ubuntu-18.04',
},
'tests': [
{'name': 'pgo_instrumentation'}
],
},
'V8 Linux64': {
'swarming_dimensions': {
'cpu': 'x86-64-avx2',
@ -1653,6 +1661,14 @@
},
],
},
'V8 Linux64 PGO instrumentation - builder' : {
'swarming_dimensions' : {
'os': 'Ubuntu-18.04',
},
'tests': [
{'name': 'pgo_instrumentation'}
],
},
'V8 Linux64 TSAN': {
'swarming_dimensions' : {
'os': 'Ubuntu-18.04',

View File

@ -72,6 +72,20 @@ group("v8_perf") {
]
}
group("d8_pgo") {
testonly = true
data_deps = [
"..:d8",
"..:v8_python_base",
]
data = [
"../tools/builtins-pgo/profile_only.py",
"../tools/builtins-pgo/get_hints.py",
]
}
group("v8_bot_default") {
testonly = true

View File

@ -0,0 +1,83 @@
#!/usr/bin/env python3
# Copyright 2023 the V8 project authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can
# be found in the LICENSE file.
from pathlib import Path
import argparse
import subprocess
import sys
def main():
args = parse_arguments()
run_benchmark(args.benchmark_path, args.d8_path, args.output_dir)
run_get_hints(args.output_dir, args.v8_target_cpu)
def parse_arguments():
parser = argparse.ArgumentParser(
description=('Generate builtin PGO profiles. '
'The script is designed to run in swarming context where '
'the isolate aready contains the instrumented binary.'))
parser.add_argument(
'--v8-target-cpu',
help='target cpu to build the profile for: x64 or arm64')
parser.add_argument(
'--benchmark_path',
default=Path('./JetStream2/cli.js'),
help='path to benchmark runner .js file, usually JetStream2\'s `cli.js`',
type=Path)
parser.add_argument(
'--d8-path',
default=Path('./out/build/d8'),
help=('path to the d8 executable, by default `./out/build/d8` in '
'swarming context. Use together with `--profile-only`'),
type=Path)
parser.add_argument('--output-dir', type=Path)
return parser.parse_args()
def run_benchmark(benchmark_path, d8_path, output_dir):
root_dir = tools_pgo_dir().parent.parent
benchmark_dir = (root_dir / benchmark_path).parent.absolute()
assert benchmark_dir.exists(), "Could not find benchmark path!"
benchmark_file = benchmark_path.name
d8_path_abs = (root_dir / d8_path).absolute()
assert d8_path_abs.exists(), "Could not find d8 path!"
log_path = benchmark_log_path(output_dir)
cmd = [d8_path_abs, f"--turbo-profiling-output={log_path}", benchmark_file]
run(cmd, cwd=benchmark_dir)
assert log_path.exists(), "Could not find benchmark logs path!"
def tools_pgo_dir():
return Path(__file__).parent
def benchmark_log_path(output_dir):
return (output_dir / "v8.builtins.pgo").absolute()
def run_get_hints(output_dir, v8_target_cpu):
get_hints_path = (tools_pgo_dir() / "get_hints.py").absolute()
assert get_hints_path.exists(), "Could not find get_hints.py script path!"
profile_path = (output_dir / f"{v8_target_cpu}.profile").absolute()
run([
sys.executable, '-u', get_hints_path,
benchmark_log_path(output_dir), profile_path
])
assert profile_path.exists(), "Could not find profile path!"
def run(cmd, **kwargs):
print(f"# CMD: {cmd} {kwargs}")
subprocess.run(cmd, **kwargs, check=True)
if __name__ == "__main__": # pragma: no cover
sys.exit(main())