blob: 8c63930b99c847edeb85c35ea82428c64b447096 [file] [log] [blame]
// Copyright 2018 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.
#ifndef V8_WASM_WASM_FEATURE_FLAGS_H_
#define V8_WASM_WASM_FEATURE_FLAGS_H_
#if !V8_ENABLE_WEBASSEMBLY
#error This header should only be included if WebAssembly is enabled.
#endif // !V8_ENABLE_WEBASSEMBLY
// Each entry in this file generates a V8 command-line flag with the prefix
// "--experimental-wasm-".
//
// For example, to enable "my_feature", pass
// --experimental-wasm-my-feature to d8, or
// --js-flags=--experimental-wasm-my-feature to Chrome.
//
// To disable "my_feature", add the "--no-" prefix:
// --no-experimental-wasm-my-feature.
//
// See https://github.com/WebAssembly/proposals for an overview of current
// WebAssembly proposals.
// Experimental features (disabled by default).
#define FOREACH_WASM_EXPERIMENTAL_FEATURE_FLAG(V) /* (force 80 columns) */ \
/* Type reflection proposal. */ \
/* https://github.com/webassembly/js-types */ \
/* V8 side owner: ahaas */ \
/* Staged in v7.8, unstaged in v13.6 (see https://crbug.com/402340845) */ \
V(type_reflection, "wasm type reflection in JS", false) \
\
/* No official proposal (yet?). */ \
/* V8 side owner: clemensb */ \
V(compilation_hints, "compilation hints section", false) \
\
/* Instruction Tracing tool convention (early prototype, might change) */ \
/* Tool convention: https://github.com/WebAssembly/tool-conventions */ \
/* V8 side owner: jabraham */ \
V(instruction_tracing, "instruction tracing section", false) \
\
/* Stack Switching proposal. */ \
/* https://github.com/WebAssembly/stack-switching */ \
/* V8 side owner: thibaudm, fgm */ \
V(stack_switching, "stack switching", false) \
\
/* Shared-Everything Threads proposal. */ \
/* https://github.com/WebAssembly/shared-everything-threads */ \
/* V8 side owner: manoskouk */ \
V(shared, "shared-everything threads", false) \
\
/* FP16 proposal. */ \
/* https://github.com/WebAssembly/half-precision */ \
/* V8 side owner: irezvov */ \
V(fp16, "fp16", false) \
\
/* V8 side owner: irezvov */ \
V(growable_stacks, "growable stacks for jspi", false) \
/* Memory Control proposal */ \
/* https://github.com/WebAssembly/memory-control */ \
/* V8 side owner: ahaas */ \
V(memory_control, "memory control", false) \
\
/* Core stack switching, main proposal */ \
/* https://github.com/WebAssembly/stack-switching */ \
/* V8 side owner: fgm */ \
V(wasmfx, "core stack switching", false)
// #############################################################################
// Staged features (disabled by default, but enabled via --wasm-staging (also
// exposed as chrome://flags/#enable-experimental-webassembly-features). Staged
// features get limited fuzzer coverage, and should come with their own tests.
// They are not run through all fuzzers though and don't get much exposure in
// the wild. Staged features are not necessarily fully stabilized. They should
// be shipped with enough lead time to the next branch to allow for
// stabilization.
// Consider adding a chromium-side use counter if you want to track usage in the
// wild (also see {V8::UseCounterFeature}).
#define FOREACH_WASM_STAGING_FEATURE_FLAG(V) /* (force 80 columns) */ \
/* Branch Hinting proposal. */ \
/* https://github.com/WebAssembly/branch-hinting */ \
/* V8 side owner: jkummerow */ \
/* Staged in v13.6. */ \
V(branch_hinting, "branch hinting", false) \
\
/* Reference-Typed Strings Proposal. */ \
/* https://github.com/WebAssembly/stringref */ \
/* V8 side owner: jkummerow */ \
V(stringref, "reference-typed strings", false) \
\
/* Imported Strings TextEncoder/TextDecoder post-MVP extension. */ \
/* No upstream repo yet. */ \
/* V8 side owner: jkummerow */ \
V(imported_strings_utf8, "imported strings (utf8 features)", false) \
\
/* Exnref */ \
/* This flag enables the new exception handling proposal */ \
/* V8 side owner: thibaudm */ \
V(exnref, "exnref", false) \
\
/* JavaScript Promise Integration proposal. */ \
/* https://github.com/WebAssembly/js-promise-integration */ \
/* V8 side owner: thibaudm, fgm */ \
V(jspi, "javascript promise integration", false)
// #############################################################################
// Shipped features (enabled by default). Remove the feature flag once they hit
// stable and are expected to stay enabled.
#define FOREACH_WASM_SHIPPED_FEATURE_FLAG(V) /* (force 80 columns) */ \
/* Legacy exception handling proposal. */ \
/* https://github.com/WebAssembly/exception-handling */ \
/* V8 side owner: thibaudm */ \
/* Staged in v8.9 */ \
/* Shipped in v9.5 */ \
V(legacy_eh, "legacy exception handling opcodes", true) \
\
/* Imported Strings Proposal. */ \
/* https://github.com/WebAssembly/js-string-builtins */ \
/* V8 side owner: jkummerow */ \
/* Shipped in v13.0 */ \
V(imported_strings, "imported strings", true)
// Combination of all available wasm feature flags.
#define FOREACH_WASM_FEATURE_FLAG(V) \
FOREACH_WASM_EXPERIMENTAL_FEATURE_FLAG(V) \
FOREACH_WASM_STAGING_FEATURE_FLAG(V) \
FOREACH_WASM_SHIPPED_FEATURE_FLAG(V)
// Consistency check: Experimental and staged features are off by default.
#define CHECK_WASM_FEATURE_OFF_BY_DEFAULT(name, desc, enabled) \
static_assert(enabled == false);
#define CHECK_WASM_FEATURE_ON_BY_DEFAULT(name, desc, enabled) \
static_assert(enabled == true);
FOREACH_WASM_EXPERIMENTAL_FEATURE_FLAG(CHECK_WASM_FEATURE_OFF_BY_DEFAULT)
FOREACH_WASM_STAGING_FEATURE_FLAG(CHECK_WASM_FEATURE_OFF_BY_DEFAULT)
FOREACH_WASM_SHIPPED_FEATURE_FLAG(CHECK_WASM_FEATURE_ON_BY_DEFAULT)
#undef CHECK_WASM_FEATURE_OFF_BY_DEFAULT
#undef CHECK_WASM_FEATURE_ON_BY_DEFAULT
#endif // V8_WASM_WASM_FEATURE_FLAGS_H_