d423178dba
Bug: v8:7700 Change-Id: Icd9c0ce6fce727759beec246253dbd16756abc09 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3545166 Commit-Queue: Victor Gomes <victorgomes@chromium.org> Auto-Submit: Victor Gomes <victorgomes@chromium.org> Reviewed-by: Leszek Swirski <leszeks@chromium.org> Commit-Queue: Leszek Swirski <leszeks@chromium.org> Cr-Commit-Position: refs/heads/main@{#79567}
160 lines
6.8 KiB
Python
160 lines
6.8 KiB
Python
# Copyright 2016 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.
|
|
|
|
# Use this to run several variants of the tests.
|
|
ALL_VARIANT_FLAGS = {
|
|
"assert_types": [["--assert-types"]],
|
|
"code_serializer": [["--cache=code"]],
|
|
"default": [[]],
|
|
"future": [["--future"]],
|
|
"gc_stats": [["--gc-stats=1"]],
|
|
# Alias of exhaustive variants, but triggering new test framework features.
|
|
"infra_staging": [[]],
|
|
"interpreted_regexp": [["--regexp-interpret-all"]],
|
|
"experimental_regexp": [["--default-to-experimental-regexp-engine"]],
|
|
"jitless": [["--jitless"]],
|
|
"sparkplug": [["--sparkplug"]],
|
|
# TODO(v8:v8:7700): Support concurrent compilation and remove flag.
|
|
"maglev": [["--maglev", "--no-concurrent-recompilation"]],
|
|
"concurrent_sparkplug": [["--concurrent-sparkplug", "--sparkplug"]],
|
|
"always_sparkplug": [["--always-sparkplug", "--sparkplug"]],
|
|
"minor_mc": [["--minor-mc"]],
|
|
"no_lfa": [["--no-lazy-feedback-allocation"]],
|
|
# No optimization means disable all optimizations. OptimizeFunctionOnNextCall
|
|
# would not force optimization too. It turns into a Nop. Please see
|
|
# https://chromium-review.googlesource.com/c/452620/ for more discussion.
|
|
# For WebAssembly, we test "Liftoff-only" in the nooptimization variant and
|
|
# "TurboFan-only" in the stress variant. The WebAssembly configuration is
|
|
# independent of JS optimizations, so we can combine those configs.
|
|
"nooptimization": [["--no-opt", "--liftoff", "--no-wasm-tier-up"]],
|
|
"slow_path": [["--force-slow-path"]],
|
|
"stress": [["--stress-opt", "--no-liftoff", "--stress-lazy-source-positions",
|
|
"--no-wasm-generic-wrapper"]],
|
|
"stress_concurrent_allocation": [["--stress-concurrent-allocation"]],
|
|
"stress_concurrent_inlining": [["--stress-concurrent-inlining"]],
|
|
"stress_js_bg_compile_wasm_code_gc": [["--stress-background-compile",
|
|
"--stress-wasm-code-gc"]],
|
|
"stress_incremental_marking": [["--stress-incremental-marking"]],
|
|
"stress_snapshot": [["--stress-snapshot"]],
|
|
# Trigger stress sampling allocation profiler with sample interval = 2^14
|
|
"stress_sampling": [["--stress-sampling-allocation-profiler=16384"]],
|
|
"no_wasm_traps": [["--no-wasm-trap-handler"]],
|
|
"instruction_scheduling": [["--turbo-instruction-scheduling"]],
|
|
"stress_instruction_scheduling": [["--turbo-stress-instruction-scheduling"]],
|
|
"wasm_write_protect_code": [["--wasm-write-protect-code-memory"]],
|
|
# Google3 variants.
|
|
"google3_icu": [[]],
|
|
"google3_noicu": [[]],
|
|
}
|
|
|
|
# Flags that lead to a contradiction with the flags provided by the respective
|
|
# variant. This depends on the flags specified in ALL_VARIANT_FLAGS and on the
|
|
# implications defined in flag-definitions.h.
|
|
INCOMPATIBLE_FLAGS_PER_VARIANT = {
|
|
"jitless": [
|
|
"--opt", "--always-opt", "--liftoff", "--track-field-types",
|
|
"--validate-asm", "--sparkplug", "--concurrent-sparkplug", "--maglev",
|
|
"--always-sparkplug", "--regexp-tier-up", "--no-regexp-interpret-all",
|
|
"--maglev"
|
|
],
|
|
"nooptimization": ["--always-opt"],
|
|
"slow_path": ["--no-force-slow-path"],
|
|
"stress_concurrent_allocation": ["--single-threaded-gc", "--predictable"],
|
|
"stress_concurrent_inlining": [
|
|
"--single-threaded", "--predictable", "--lazy-feedback-allocation",
|
|
"--assert-types", "--no-concurrent-recompilation"
|
|
],
|
|
# The fast API tests initialize an embedder object that never needs to be
|
|
# serialized to the snapshot, so we don't have a
|
|
# SerializeInternalFieldsCallback for it, so they are incompatible with
|
|
# stress_snapshot.
|
|
"stress_snapshot": ["--expose-fast-api"],
|
|
"stress": [
|
|
"--always-opt", "--no-always-opt", "--max-inlined-bytecode-size=*",
|
|
"--max-inlined-bytecode-size-cumulative=*", "--stress-inline",
|
|
"--liftoff-only", "--wasm-speculative-inlining",
|
|
"--wasm-dynamic-tiering"
|
|
],
|
|
"sparkplug": ["--jitless"],
|
|
"concurrent_sparkplug": ["--jitless"],
|
|
# TODO(v8:v8:7700): Support concurrent compilation and remove incompatible flags.
|
|
"maglev": [
|
|
"--jitless", "--concurrent-recompilation",
|
|
"--stress-concurrent-inlining"
|
|
],
|
|
"always_sparkplug": ["--jitless"],
|
|
"code_serializer": [
|
|
"--cache=after-execute", "--cache=full-code-cache", "--cache=none"
|
|
],
|
|
"experimental_regexp": ["--no-enable-experimental-regexp-engine"],
|
|
# There is a negative implication: --perf-prof disables
|
|
# --wasm-write-protect-code-memory.
|
|
"wasm_write_protect_code": ["--perf-prof"],
|
|
"assert_types": [
|
|
"--concurrent-recompilation", "--stress_concurrent_inlining",
|
|
"--no-assert-types"
|
|
],
|
|
}
|
|
|
|
# Flags that lead to a contradiction under certain build variables.
|
|
# This corresponds to the build variables usable in status files as generated
|
|
# in _get_statusfile_variables in base_runner.py.
|
|
# The conflicts might be directly contradictory flags or be caused by the
|
|
# implications defined in flag-definitions.h.
|
|
INCOMPATIBLE_FLAGS_PER_BUILD_VARIABLE = {
|
|
"lite_mode": ["--no-lazy-feedback-allocation", "--max-semi-space-size=*",
|
|
"--stress-concurrent-inlining"]
|
|
+ INCOMPATIBLE_FLAGS_PER_VARIANT["jitless"],
|
|
"predictable": ["--parallel-compile-tasks-for-eager-toplevel",
|
|
"--parallel-compile-tasks-for-lazy",
|
|
"--concurrent-recompilation",
|
|
"--stress-concurrent-allocation",
|
|
"--stress-concurrent-inlining"],
|
|
"dict_property_const_tracking": [
|
|
"--stress-concurrent-inlining"],
|
|
}
|
|
|
|
# Flags that lead to a contradiction when a certain extra-flag is present.
|
|
# Such extra-flags are defined for example in infra/testing/builders.pyl or in
|
|
# standard_runner.py.
|
|
# The conflicts might be directly contradictory flags or be caused by the
|
|
# implications defined in flag-definitions.h.
|
|
INCOMPATIBLE_FLAGS_PER_EXTRA_FLAG = {
|
|
"--concurrent-recompilation": ["--predictable", "--assert-types"],
|
|
"--parallel-compile-tasks-for-eager-toplevel": ["--predictable"],
|
|
"--parallel-compile-tasks-for-lazy": ["--predictable"],
|
|
"--gc-interval=*": ["--gc-interval=*"],
|
|
"--optimize-for-size": ["--max-semi-space-size=*"],
|
|
"--stress_concurrent_allocation":
|
|
INCOMPATIBLE_FLAGS_PER_VARIANT["stress_concurrent_allocation"],
|
|
"--stress-concurrent-inlining":
|
|
INCOMPATIBLE_FLAGS_PER_VARIANT["stress_concurrent_inlining"],
|
|
}
|
|
|
|
SLOW_VARIANTS = set([
|
|
'stress',
|
|
'stress_snapshot',
|
|
'nooptimization',
|
|
])
|
|
|
|
FAST_VARIANTS = set([
|
|
'default'
|
|
])
|
|
|
|
|
|
def _variant_order_key(v):
|
|
if v in SLOW_VARIANTS:
|
|
return 0
|
|
if v in FAST_VARIANTS:
|
|
return 100
|
|
return 50
|
|
|
|
ALL_VARIANTS = sorted(ALL_VARIANT_FLAGS.keys(),
|
|
key=_variant_order_key)
|
|
|
|
# Check {SLOW,FAST}_VARIANTS entries
|
|
for variants in [SLOW_VARIANTS, FAST_VARIANTS]:
|
|
for v in variants:
|
|
assert v in ALL_VARIANT_FLAGS
|