From a37f4aed3f2c73fc0fc932ceb8421c7741d85d4f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Dziuba?= Date: Thu, 26 Sep 2024 00:56:25 +0200 Subject: [PATCH] feat: add experimental v8 build script --- .gitignore | 10 +- README.md | 29 +- build.sh | 21 - deps/v8/.clang-tidy | 12 +- deps/v8/.editorconfig | 6 +- deps/v8/.gitignore | 6 +- deps/v8/AUTHORS | 11 +- deps/v8/BUILD.bazel | 155 +- deps/v8/BUILD.gn | 460 ++-- deps/v8/COMMON_OWNERS | 3 +- deps/v8/DEPS | 218 +- deps/v8/WATCHLISTS | 1 - deps/v8/bazel/defs.bzl | 6 +- deps/v8/build_overrides/build.gni | 9 - deps/v8/docs/OWNERS | 3 +- deps/v8/gni/v8.gni | 30 +- deps/v8/include/OWNERS | 1 - deps/v8/include/cppgc/default-platform.h | 5 +- deps/v8/include/cppgc/garbage-collected.h | 8 + deps/v8/include/cppgc/heap-consistency.h | 2 +- .../cppgc/internal/compiler-specific.h | 10 +- deps/v8/include/cppgc/name-provider.h | 3 + deps/v8/include/cppgc/platform.h | 9 + deps/v8/include/js_protocol.pdl | 5 +- deps/v8/include/v8-callbacks.h | 40 +- deps/v8/include/v8-context.h | 2 +- deps/v8/include/v8-debug.h | 5 + deps/v8/include/v8-fast-api-calls.h | 27 - deps/v8/include/v8-function-callback.h | 2 +- deps/v8/include/v8-function.h | 4 + deps/v8/include/v8-handle-base.h | 4 +- deps/v8/include/v8-initialization.h | 10 +- deps/v8/include/v8-internal.h | 293 ++- deps/v8/include/v8-isolate.h | 16 +- deps/v8/include/v8-local-handle.h | 27 +- deps/v8/include/v8-memory-span.h | 172 +- deps/v8/include/v8-metrics.h | 10 + deps/v8/include/v8-object.h | 10 +- deps/v8/include/v8-platform.h | 50 +- deps/v8/include/v8-primitive.h | 24 + deps/v8/include/v8-profiler.h | 6 + deps/v8/include/v8-script.h | 20 +- deps/v8/include/v8-template.h | 15 +- deps/v8/include/v8-traced-handle.h | 33 +- deps/v8/include/v8-unwinder-state.h | 5 +- deps/v8/include/v8-util.h | 2 +- deps/v8/include/v8-value.h | 5 +- deps/v8/include/v8-version.h | 4 +- deps/v8/include/v8config.h | 65 +- deps/v8/infra/mb/gn_isolate_map.pyl | 4 + deps/v8/infra/mb/mb_config.pyl | 135 +- deps/v8/infra/testing/builders.pyl | 16 + deps/v8/samples/OWNERS | 2 +- deps/v8/src/DEPS | 3 + deps/v8/src/api/api-arguments-inl.h | 41 +- deps/v8/src/api/api-inl.h | 85 +- deps/v8/src/api/api-macros.h | 2 +- deps/v8/src/api/api-natives.cc | 14 +- deps/v8/src/api/api.cc | 482 +++-- deps/v8/src/api/api.h | 74 +- deps/v8/src/asmjs/asm-js.cc | 5 +- deps/v8/src/asmjs/asm-parser.cc | 52 +- deps/v8/src/asmjs/asm-scanner.cc | 46 +- deps/v8/src/ast/ast-traversal-visitor.h | 12 + deps/v8/src/ast/ast.cc | 13 + deps/v8/src/ast/ast.h | 188 +- deps/v8/src/ast/prettyprinter.cc | 17 + deps/v8/src/ast/scopes.cc | 112 +- deps/v8/src/ast/scopes.h | 20 +- deps/v8/src/base/bit-field.h | 11 +- deps/v8/src/base/bounded-page-allocator.cc | 4 + deps/v8/src/base/bounded-page-allocator.h | 2 + deps/v8/src/base/build_config.h | 2 +- deps/v8/src/base/compiler-specific.h | 7 +- deps/v8/src/base/cpu.cc | 33 +- deps/v8/src/base/cpu.h | 14 +- deps/v8/src/base/debug/stack_trace.h | 2 +- deps/v8/src/base/ieee754.cc | 2 +- deps/v8/src/base/immediate-crash.h | 2 +- deps/v8/src/base/intrusive-set.h | 1 - deps/v8/src/base/iterator.h | 16 + deps/v8/src/base/logging.h | 1 + deps/v8/src/base/macros.h | 60 +- deps/v8/src/base/optional.h | 29 - deps/v8/src/base/page-allocator.cc | 4 + deps/v8/src/base/page-allocator.h | 2 + deps/v8/src/base/platform/memory.h | 4 +- deps/v8/src/base/platform/mutex.h | 5 +- deps/v8/src/base/platform/platform-cygwin.cc | 15 +- deps/v8/src/base/platform/platform-fuchsia.cc | 10 +- deps/v8/src/base/platform/platform-linux.cc | 8 +- deps/v8/src/base/platform/platform-linux.h | 4 +- deps/v8/src/base/platform/platform-posix.cc | 59 +- .../src/base/platform/platform-starboard.cc | 2 +- deps/v8/src/base/platform/platform-win32.cc | 34 +- deps/v8/src/base/platform/platform.h | 17 +- deps/v8/src/base/platform/time.cc | 5 +- deps/v8/src/base/sys-info.cc | 2 - .../template-meta-programming/algorithm.h | 75 - .../template-meta-programming/functional.h | 5 + .../src/base/template-meta-programming/list.h | 208 +- deps/v8/src/base/template-utils.h | 54 + .../virtual-address-space-page-allocator.cc | 4 + .../virtual-address-space-page-allocator.h | 2 + deps/v8/src/base/virtual-address-space.cc | 6 +- .../src/baseline/baseline-batch-compiler.cc | 4 +- .../v8/src/baseline/baseline-batch-compiler.h | 4 +- deps/v8/src/baseline/baseline-compiler.cc | 26 +- deps/v8/src/baseline/baseline-compiler.h | 2 +- .../src/baseline/bytecode-offset-iterator.h | 4 +- deps/v8/src/builtins/DEPS | 13 +- deps/v8/src/builtins/accessors.cc | 16 +- deps/v8/src/builtins/arm/builtins-arm.cc | 246 ++- deps/v8/src/builtins/arm64/builtins-arm64.cc | 304 ++- deps/v8/src/builtins/array-from-async.tq | 47 +- deps/v8/src/builtins/base.tq | 10 +- deps/v8/src/builtins/builtins-api.cc | 4 +- deps/v8/src/builtins/builtins-array-gen.cc | 22 +- deps/v8/src/builtins/builtins-array-gen.h | 8 +- deps/v8/src/builtins/builtins-array.cc | 12 +- .../builtins-async-disposable-stack.cc | 349 ++- .../builtins/builtins-async-function-gen.cc | 13 +- deps/v8/src/builtins/builtins-async-gen.cc | 81 +- deps/v8/src/builtins/builtins-async-gen.h | 14 +- .../builtins/builtins-async-generator-gen.cc | 54 +- .../builtins/builtins-async-iterator-gen.cc | 39 +- .../builtins-atomics-synchronization.cc | 6 +- deps/v8/src/builtins/builtins-bigint-gen.cc | 4 + deps/v8/src/builtins/builtins-call-gen.cc | 32 +- deps/v8/src/builtins/builtins-call-gen.h | 12 +- .../src/builtins/builtins-collections-gen.cc | 13 +- deps/v8/src/builtins/builtins-console.cc | 11 +- .../src/builtins/builtins-constructor-gen.cc | 52 +- .../src/builtins/builtins-conversion-gen.cc | 4 + deps/v8/src/builtins/builtins-date-gen.cc | 4 + deps/v8/src/builtins/builtins-definitions.h | 199 +- deps/v8/src/builtins/builtins-descriptors.h | 14 +- .../src/builtins/builtins-disposable-stack.cc | 2 + deps/v8/src/builtins/builtins-function.cc | 2 +- .../v8/src/builtins/builtins-generator-gen.cc | 10 +- deps/v8/src/builtins/builtins-global-gen.cc | 4 + deps/v8/src/builtins/builtins-handler-gen.cc | 9 +- deps/v8/src/builtins/builtins-inl.h | 23 + deps/v8/src/builtins/builtins-internal-gen.cc | 50 +- deps/v8/src/builtins/builtins-internal.cc | 6 + deps/v8/src/builtins/builtins-intl-gen.cc | 11 +- deps/v8/src/builtins/builtins-intl.cc | 2 +- deps/v8/src/builtins/builtins-iterator-gen.cc | 12 +- deps/v8/src/builtins/builtins-iterator-gen.h | 10 +- deps/v8/src/builtins/builtins-lazy-gen.cc | 42 +- .../builtins/builtins-microtask-queue-gen.cc | 6 +- deps/v8/src/builtins/builtins-number-gen.cc | 128 +- deps/v8/src/builtins/builtins-object-gen.cc | 132 +- deps/v8/src/builtins/builtins-proxy-gen.cc | 13 +- deps/v8/src/builtins/builtins-regexp-gen.cc | 144 +- deps/v8/src/builtins/builtins-regexp-gen.h | 5 +- .../src/builtins/builtins-shadow-realm-gen.cc | 14 +- deps/v8/src/builtins/builtins-shadow-realm.cc | 26 +- .../builtins-sharedarraybuffer-gen.cc | 4 + .../builtins/builtins-sharedarraybuffer.cc | 4 +- deps/v8/src/builtins/builtins-string-gen.cc | 56 +- deps/v8/src/builtins/builtins-string-gen.h | 2 +- deps/v8/src/builtins/builtins-string-tsa.cc | 213 +- deps/v8/src/builtins/builtins-string.cc | 4 +- deps/v8/src/builtins/builtins-temporal-gen.cc | 4 + .../src/builtins/builtins-typed-array-gen.cc | 10 +- deps/v8/src/builtins/builtins-utils-gen.h | 47 +- deps/v8/src/builtins/builtins-wasm-gen.cc | 36 +- deps/v8/src/builtins/builtins.cc | 24 +- deps/v8/src/builtins/builtins.h | 68 +- deps/v8/src/builtins/collections.tq | 8 +- .../src/builtins/constants-table-builder.cc | 4 +- deps/v8/src/builtins/data-view-ops.h | 10 +- .../generate-bytecodes-builtins-list.cc | 6 +- .../src/builtins/growable-fixed-array-gen.cc | 14 +- deps/v8/src/builtins/ia32/builtins-ia32.cc | 244 ++- deps/v8/src/builtins/js-to-js.tq | 23 +- deps/v8/src/builtins/js-to-wasm.tq | 74 +- .../src/builtins/loong64/builtins-loong64.cc | 1264 ++++++++++- .../v8/src/builtins/mips64/builtins-mips64.cc | 169 +- deps/v8/src/builtins/ppc/builtins-ppc.cc | 189 +- .../builtins/promise-abstract-operations.tq | 49 +- deps/v8/src/builtins/promise-all.tq | 43 +- deps/v8/src/builtins/promise-any.tq | 11 +- deps/v8/src/builtins/promise-finally.tq | 36 +- deps/v8/src/builtins/promise-misc.tq | 7 +- deps/v8/src/builtins/regexp-match.tq | 59 +- deps/v8/src/builtins/regexp.tq | 7 + deps/v8/src/builtins/riscv/builtins-riscv.cc | 324 +-- deps/v8/src/builtins/s390/builtins-s390.cc | 208 +- deps/v8/src/builtins/set-difference.tq | 3 +- deps/v8/src/builtins/set-intersection.tq | 3 +- deps/v8/src/builtins/set-is-disjoint-from.tq | 3 +- deps/v8/src/builtins/set-is-subset-of.tq | 3 +- deps/v8/src/builtins/set-is-superset-of.tq | 3 +- .../src/builtins/setup-builtins-internal.cc | 87 +- deps/v8/src/builtins/string-trim.tq | 2 +- deps/v8/src/builtins/suppressed-error.tq | 14 +- deps/v8/src/builtins/typed-array-from.tq | 6 +- deps/v8/src/builtins/wasm-to-js.tq | 39 +- deps/v8/src/builtins/wasm.tq | 76 +- deps/v8/src/builtins/x64/builtins-x64.cc | 269 ++- deps/v8/src/codegen/DEPS | 5 +- deps/v8/src/codegen/OWNERS | 3 +- deps/v8/src/codegen/arm/assembler-arm-inl.h | 12 + deps/v8/src/codegen/arm/assembler-arm.cc | 23 +- deps/v8/src/codegen/arm/assembler-arm.h | 1 + .../v8/src/codegen/arm/macro-assembler-arm.cc | 35 +- deps/v8/src/codegen/arm/macro-assembler-arm.h | 18 +- deps/v8/src/codegen/arm/register-arm.h | 2 +- .../src/codegen/arm64/assembler-arm64-inl.h | 18 +- deps/v8/src/codegen/arm64/assembler-arm64.cc | 12 +- deps/v8/src/codegen/arm64/assembler-arm64.h | 4 +- deps/v8/src/codegen/arm64/cpu-arm64.cc | 4 + .../codegen/arm64/macro-assembler-arm64-inl.h | 5 + .../codegen/arm64/macro-assembler-arm64.cc | 346 ++- .../src/codegen/arm64/macro-assembler-arm64.h | 67 +- deps/v8/src/codegen/arm64/register-arm64.h | 9 +- deps/v8/src/codegen/assembler-arch.h | 4 +- deps/v8/src/codegen/assembler-inl.h | 4 +- deps/v8/src/codegen/assembler.h | 10 +- deps/v8/src/codegen/background-merge-task.h | 2 + deps/v8/src/codegen/code-desc.cc | 14 +- deps/v8/src/codegen/code-desc.h | 10 +- deps/v8/src/codegen/code-stub-assembler-inl.h | 5 + deps/v8/src/codegen/code-stub-assembler.cc | 1093 ++++++---- deps/v8/src/codegen/code-stub-assembler.h | 314 ++- deps/v8/src/codegen/compilation-cache.cc | 29 +- deps/v8/src/codegen/compilation-cache.h | 14 +- deps/v8/src/codegen/compiler.cc | 422 +++- deps/v8/src/codegen/compiler.h | 15 +- deps/v8/src/codegen/constant-pool.cc | 4 +- deps/v8/src/codegen/constant-pool.h | 6 +- deps/v8/src/codegen/constants-arch.h | 4 +- deps/v8/src/codegen/cpu-features.h | 6 +- .../src/codegen/external-reference-table.cc | 75 +- .../v8/src/codegen/external-reference-table.h | 32 +- deps/v8/src/codegen/external-reference.cc | 61 +- deps/v8/src/codegen/external-reference.h | 39 +- deps/v8/src/codegen/heap-object-list.h | 79 +- deps/v8/src/codegen/ia32/assembler-ia32-inl.h | 14 + deps/v8/src/codegen/ia32/assembler-ia32.cc | 9 +- .../src/codegen/ia32/macro-assembler-ia32.cc | 2 +- deps/v8/src/codegen/ia32/register-ia32.h | 2 +- .../src/codegen/interface-descriptors-inl.h | 28 +- deps/v8/src/codegen/interface-descriptors.h | 28 +- .../codegen/loong64/assembler-loong64-inl.h | 19 +- .../src/codegen/loong64/assembler-loong64.cc | 9 +- .../loong64/macro-assembler-loong64.cc | 107 +- .../codegen/loong64/macro-assembler-loong64.h | 17 +- .../v8/src/codegen/loong64/register-loong64.h | 9 +- deps/v8/src/codegen/macro-assembler.h | 7 +- .../src/codegen/mips64/assembler-mips64-inl.h | 12 + .../v8/src/codegen/mips64/assembler-mips64.cc | 11 +- .../codegen/mips64/macro-assembler-mips64.cc | 79 +- .../codegen/mips64/macro-assembler-mips64.h | 12 +- deps/v8/src/codegen/mips64/register-mips64.h | 2 +- .../src/codegen/optimized-compilation-info.cc | 7 +- .../src/codegen/optimized-compilation-info.h | 43 +- deps/v8/src/codegen/ppc/assembler-ppc-inl.h | 59 +- deps/v8/src/codegen/ppc/assembler-ppc.cc | 99 +- deps/v8/src/codegen/ppc/assembler-ppc.h | 37 - deps/v8/src/codegen/ppc/constants-ppc.cc | 4 +- deps/v8/src/codegen/ppc/constants-ppc.h | 16 +- deps/v8/src/codegen/ppc/cpu-ppc.cc | 40 +- .../ppc/interface-descriptors-ppc-inl.h | 4 +- .../v8/src/codegen/ppc/macro-assembler-ppc.cc | 505 +---- deps/v8/src/codegen/ppc/macro-assembler-ppc.h | 64 +- deps/v8/src/codegen/ppc/register-ppc.h | 2 +- deps/v8/src/codegen/register-arch.h | 4 +- deps/v8/src/codegen/register-configuration.cc | 4 +- deps/v8/src/codegen/reglist.h | 4 +- deps/v8/src/codegen/reloc-info-inl.h | 2 +- deps/v8/src/codegen/reloc-info.cc | 24 +- deps/v8/src/codegen/reloc-info.h | 19 +- .../src/codegen/riscv/assembler-riscv-inl.h | 23 +- deps/v8/src/codegen/riscv/assembler-riscv.cc | 188 +- deps/v8/src/codegen/riscv/assembler-riscv.h | 120 +- .../src/codegen/riscv/base-constants-riscv.h | 10 + .../codegen/riscv/macro-assembler-riscv.cc | 376 +++- .../src/codegen/riscv/macro-assembler-riscv.h | 30 +- deps/v8/src/codegen/riscv/register-riscv.h | 2 +- deps/v8/src/codegen/s390/assembler-s390-inl.h | 35 +- deps/v8/src/codegen/s390/assembler-s390.cc | 43 +- deps/v8/src/codegen/s390/assembler-s390.h | 10 +- deps/v8/src/codegen/s390/constants-s390.cc | 4 +- deps/v8/src/codegen/s390/constants-s390.h | 7 - deps/v8/src/codegen/s390/cpu-s390.cc | 4 +- .../s390/interface-descriptors-s390-inl.h | 4 +- .../src/codegen/s390/macro-assembler-s390.cc | 240 +-- .../src/codegen/s390/macro-assembler-s390.h | 39 +- deps/v8/src/codegen/s390/register-s390.h | 25 +- .../macro-assembler-shared-ia32-x64.cc | 82 +- .../macro-assembler-shared-ia32-x64.h | 113 +- deps/v8/src/codegen/signature.h | 29 +- deps/v8/src/codegen/source-position.h | 4 - deps/v8/src/codegen/tnode.h | 10 + .../turboshaft-builtins-assembler-inl.h | 593 +++++- deps/v8/src/codegen/x64/assembler-x64-inl.h | 20 +- deps/v8/src/codegen/x64/assembler-x64.cc | 48 +- deps/v8/src/codegen/x64/assembler-x64.h | 20 +- .../v8/src/codegen/x64/macro-assembler-x64.cc | 486 ++++- deps/v8/src/codegen/x64/macro-assembler-x64.h | 77 +- deps/v8/src/codegen/x64/register-x64.h | 10 +- deps/v8/src/common/assert-scope.h | 9 +- deps/v8/src/common/code-memory-access-inl.h | 5 +- deps/v8/src/common/code-memory-access.cc | 16 +- deps/v8/src/common/code-memory-access.h | 22 +- deps/v8/src/common/globals.h | 87 +- deps/v8/src/common/message-template.h | 10 +- deps/v8/src/common/ptr-compr-inl.h | 14 +- deps/v8/src/common/ptr-compr.h | 7 +- .../lazy-compile-dispatcher.cc | 9 +- .../optimizing-compile-dispatcher.cc | 17 +- .../optimizing-compile-dispatcher.h | 5 +- deps/v8/src/compiler/OWNERS | 7 +- deps/v8/src/compiler/access-builder.cc | 108 +- deps/v8/src/compiler/access-builder.h | 17 +- deps/v8/src/compiler/access-info.cc | 13 +- deps/v8/src/compiler/access-info.h | 6 +- deps/v8/src/compiler/allocation-builder.h | 7 +- deps/v8/src/compiler/backend/OWNERS | 1 + .../backend/arm/code-generator-arm.cc | 81 +- .../backend/arm/instruction-selector-arm.cc | 102 +- .../backend/arm64/code-generator-arm64.cc | 257 ++- .../backend/arm64/instruction-codes-arm64.h | 23 + .../arm64/instruction-scheduler-arm64.cc | 23 + .../arm64/instruction-selector-arm64.cc | 473 ++-- .../v8/src/compiler/backend/code-generator.cc | 67 +- deps/v8/src/compiler/backend/code-generator.h | 16 +- .../backend/ia32/code-generator-ia32.cc | 94 +- .../backend/ia32/instruction-selector-ia32.cc | 113 +- .../src/compiler/backend/instruction-codes.h | 4 +- .../compiler/backend/instruction-scheduler.cc | 5 +- .../compiler/backend/instruction-scheduler.h | 5 +- .../backend/instruction-selector-adapter.h | 67 +- .../backend/instruction-selector-impl.h | 11 +- .../compiler/backend/instruction-selector.cc | 247 ++- .../compiler/backend/instruction-selector.h | 49 +- deps/v8/src/compiler/backend/instruction.cc | 3 +- deps/v8/src/compiler/backend/instruction.h | 5 +- .../v8/src/compiler/backend/jump-threading.cc | 9 +- .../backend/loong64/code-generator-loong64.cc | 42 +- .../loong64/instruction-selector-loong64.cc | 502 +++-- .../backend/mips64/code-generator-mips64.cc | 36 +- .../mips64/instruction-selector-mips64.cc | 91 +- .../backend/ppc/code-generator-ppc.cc | 283 +-- .../backend/ppc/instruction-selector-ppc.cc | 544 +++-- .../backend/register-allocator-verifier.cc | 17 +- .../backend/register-allocator-verifier.h | 4 +- .../compiler/backend/register-allocator.cc | 5 +- .../src/compiler/backend/register-allocator.h | 2 +- .../backend/riscv/code-generator-riscv.cc | 41 +- .../riscv/instruction-scheduler-riscv.cc | 110 +- .../riscv/instruction-selector-riscv.h | 623 +++--- .../riscv/instruction-selector-riscv32.cc | 202 +- .../riscv/instruction-selector-riscv64.cc | 516 +++-- .../backend/s390/code-generator-s390.cc | 61 +- .../backend/s390/instruction-selector-s390.cc | 419 +++- .../compiler/backend/unwinding-info-writer.h | 2 +- .../backend/x64/code-generator-x64.cc | 491 ++++- .../backend/x64/instruction-codes-x64.h | 47 +- .../backend/x64/instruction-scheduler-x64.cc | 13 + .../backend/x64/instruction-selector-x64.cc | 586 +++-- .../src/compiler/basic-block-instrumentor.cc | 2 +- deps/v8/src/compiler/bytecode-analysis.cc | 318 +-- deps/v8/src/compiler/bytecode-analysis.h | 35 +- .../v8/src/compiler/bytecode-graph-builder.cc | 25 +- deps/v8/src/compiler/c-linkage.cc | 4 +- deps/v8/src/compiler/code-assembler.cc | 51 +- deps/v8/src/compiler/code-assembler.h | 44 +- .../src/compiler/common-operator-reducer.cc | 3 +- deps/v8/src/compiler/common-operator.cc | 16 +- deps/v8/src/compiler/common-operator.h | 11 +- .../src/compiler/compilation-dependencies.cc | 12 +- .../src/compiler/escape-analysis-reducer.cc | 11 - deps/v8/src/compiler/fast-api-calls.cc | 50 +- deps/v8/src/compiler/frame-states.cc | 4 +- deps/v8/src/compiler/graph-assembler.cc | 26 +- deps/v8/src/compiler/graph-assembler.h | 8 +- deps/v8/src/compiler/graph-visualizer.cc | 7 +- deps/v8/src/compiler/graph-visualizer.h | 6 +- deps/v8/src/compiler/heap-refs.cc | 99 +- deps/v8/src/compiler/heap-refs.h | 40 +- deps/v8/src/compiler/js-call-reducer.cc | 195 +- deps/v8/src/compiler/js-call-reducer.h | 19 +- deps/v8/src/compiler/js-create-lowering.cc | 43 +- deps/v8/src/compiler/js-create-lowering.h | 14 +- deps/v8/src/compiler/js-graph.cc | 8 + deps/v8/src/compiler/js-graph.h | 5 + deps/v8/src/compiler/js-heap-broker.cc | 8 +- deps/v8/src/compiler/js-heap-broker.h | 13 +- deps/v8/src/compiler/js-inlining-heuristic.h | 10 +- deps/v8/src/compiler/js-inlining.cc | 37 +- deps/v8/src/compiler/js-inlining.h | 19 + .../js-native-context-specialization.cc | 112 +- .../js-native-context-specialization.h | 11 +- deps/v8/src/compiler/js-typed-lowering.cc | 4 +- deps/v8/src/compiler/late-escape-analysis.cc | 6 +- deps/v8/src/compiler/linkage.cc | 118 +- deps/v8/src/compiler/linkage.h | 17 +- deps/v8/src/compiler/load-elimination.cc | 4 +- deps/v8/src/compiler/machine-graph.h | 4 +- .../src/compiler/machine-operator-reducer.cc | 23 +- .../src/compiler/machine-operator-reducer.h | 6 +- deps/v8/src/compiler/machine-operator.cc | 37 +- deps/v8/src/compiler/machine-operator.h | 44 +- deps/v8/src/compiler/memory-lowering.cc | 2 +- deps/v8/src/compiler/node-properties.cc | 6 +- deps/v8/src/compiler/node.h | 2 +- deps/v8/src/compiler/opcodes.h | 42 +- deps/v8/src/compiler/operation-typer.cc | 1 + .../src/compiler/pair-load-store-reducer.cc | 4 +- deps/v8/src/compiler/pipeline-data-inl.h | 50 +- deps/v8/src/compiler/pipeline.cc | 210 +- deps/v8/src/compiler/pipeline.h | 7 +- .../src/compiler/property-access-builder.cc | 7 +- .../v8/src/compiler/property-access-builder.h | 5 +- deps/v8/src/compiler/raw-machine-assembler.cc | 10 +- deps/v8/src/compiler/raw-machine-assembler.h | 5 +- deps/v8/src/compiler/scheduler.cc | 9 +- deps/v8/src/compiler/scheduler.h | 4 +- .../compiler/simplified-lowering-verifier.cc | 1 + .../compiler/simplified-lowering-verifier.h | 8 +- deps/v8/src/compiler/simplified-lowering.cc | 10 +- .../compiler/simplified-operator-reducer.cc | 4 +- .../src/compiler/string-builder-optimizer.cc | 46 +- .../src/compiler/string-builder-optimizer.h | 8 +- .../src/compiler/turboshaft/access-builder.h | 12 + deps/v8/src/compiler/turboshaft/assembler.h | 829 +++++-- .../turboshaft/assert-types-reducer.h | 16 +- .../turboshaft/branch-elimination-reducer.h | 9 +- .../compiler/turboshaft/build-graph-phase.cc | 15 +- .../compiler/turboshaft/build-graph-phase.h | 8 +- .../turboshaft/builtin-call-descriptors.h | 22 + .../src/compiler/turboshaft/copying-phase.h | 3 +- .../dead-code-elimination-reducer.h | 3 +- .../debug-feature-lowering-reducer.h | 3 + .../turboshaft/define-assembler-macros.inc | 37 +- .../fast-api-call-lowering-reducer.h | 21 +- .../src/compiler/turboshaft/graph-builder.cc | 117 +- .../src/compiler/turboshaft/graph-builder.h | 8 +- .../compiler/turboshaft/graph-visualizer.h | 3 +- deps/v8/src/compiler/turboshaft/graph.h | 3 + deps/v8/src/compiler/turboshaft/index.h | 19 +- .../turboshaft/instruction-selection-phase.cc | 8 +- .../turboshaft/instruction-selection-phase.h | 8 +- .../turboshaft/int64-lowering-reducer.h | 7 +- .../late-load-elimination-reducer.h | 4 +- .../compiler/turboshaft/layered-hash-map.h | 8 +- .../turboshaft/loop-unrolling-reducer.cc | 33 +- .../turboshaft/loop-unrolling-reducer.h | 4 +- .../turboshaft/machine-lowering-reducer-inl.h | 364 ++-- .../turboshaft/machine-optimization-reducer.h | 704 +++--- .../maglev-early-lowering-reducer-inl.h | 117 +- .../turboshaft/maglev-graph-building-phase.cc | 1037 ++++++++- .../turboshaft/maglev-graph-building-phase.h | 4 +- .../turboshaft/memory-optimization-reducer.cc | 14 +- .../turboshaft/memory-optimization-reducer.h | 20 +- .../compiler/turboshaft/operation-matcher.h | 54 +- deps/v8/src/compiler/turboshaft/operations.cc | 70 +- deps/v8/src/compiler/turboshaft/operations.h | 349 ++- deps/v8/src/compiler/turboshaft/opmasks.h | 34 +- deps/v8/src/compiler/turboshaft/phase.h | 53 +- deps/v8/src/compiler/turboshaft/pipelines.cc | 5 + deps/v8/src/compiler/turboshaft/pipelines.h | 23 +- .../pretenuring-propagation-reducer.h | 6 +- .../compiler/turboshaft/recreate-schedule.cc | 37 +- .../src/compiler/turboshaft/reducer-traits.h | 85 +- .../compiler/turboshaft/representations.cc | 4 + .../src/compiler/turboshaft/representations.h | 23 +- .../turboshaft/runtime-call-descriptors.h | 60 +- .../turboshaft/simplified-lowering-phase.cc | 16 - .../turboshaft/simplified-lowering-phase.h | 20 - .../turboshaft/simplified-lowering-reducer.h | 102 - .../turboshaft/snapshot-table-opindex.h | 6 +- .../turboshaft/stack-check-lowering-reducer.h | 116 +- .../store-store-elimination-reducer-inl.h | 11 +- .../turboshaft/type-inference-analysis.h | 9 +- .../turboshaft/type-inference-reducer.h | 11 +- .../v8/src/compiler/turboshaft/type-parser.cc | 6 +- deps/v8/src/compiler/turboshaft/type-parser.h | 40 +- deps/v8/src/compiler/turboshaft/typer.h | 14 +- deps/v8/src/compiler/turboshaft/types.cc | 5 +- deps/v8/src/compiler/turboshaft/types.h | 13 +- .../turboshaft/undef-assembler-macros.inc | 6 +- .../compiler/turboshaft/variable-reducer.h | 12 +- .../wasm-gc-typed-optimization-reducer.cc | 2 +- .../wasm-load-elimination-reducer.h | 4 +- .../turboshaft/wasm-lowering-reducer.h | 58 +- .../compiler/turboshaft/wasm-revec-reducer.cc | 49 +- .../compiler/turboshaft/wasm-revec-reducer.h | 164 +- .../src/compiler/turboshaft/zone-with-name.h | 17 + deps/v8/src/compiler/type-cache.h | 6 +- deps/v8/src/compiler/typed-optimization.cc | 7 +- deps/v8/src/compiler/typer.cc | 6 +- deps/v8/src/compiler/types.cc | 3 + deps/v8/src/compiler/types.h | 2 +- deps/v8/src/compiler/use-info.h | 8 +- deps/v8/src/compiler/verifier.cc | 1 + deps/v8/src/compiler/wasm-call-descriptors.cc | 35 +- deps/v8/src/compiler/wasm-call-descriptors.h | 15 +- .../src/compiler/wasm-compiler-definitions.cc | 4 +- deps/v8/src/compiler/wasm-compiler.cc | 615 ++---- deps/v8/src/compiler/wasm-compiler.h | 32 +- .../src/compiler/wasm-gc-operator-reducer.cc | 6 +- deps/v8/src/compiler/wasm-graph-assembler.cc | 42 +- deps/v8/src/compiler/wasm-graph-assembler.h | 7 +- deps/v8/src/compiler/wasm-inlining-into-js.cc | 4 +- deps/v8/src/compiler/wasm-inlining.cc | 7 +- deps/v8/src/d8/d8-platforms.cc | 10 +- deps/v8/src/d8/d8-test.cc | 54 +- deps/v8/src/d8/d8.cc | 288 ++- deps/v8/src/d8/d8.h | 13 +- deps/v8/src/debug/debug-coverage.cc | 2 +- deps/v8/src/debug/debug-evaluate.cc | 23 +- deps/v8/src/debug/debug-frames.cc | 15 + deps/v8/src/debug/debug-frames.h | 3 + deps/v8/src/debug/debug-interface.cc | 86 +- deps/v8/src/debug/debug-interface.h | 10 +- deps/v8/src/debug/debug-scopes.cc | 6 +- .../src/debug/debug-stack-trace-iterator.cc | 22 +- deps/v8/src/debug/debug-wasm-objects.cc | 121 +- deps/v8/src/debug/debug-wasm-objects.h | 8 + deps/v8/src/debug/debug.cc | 98 +- deps/v8/src/debug/debug.h | 15 +- deps/v8/src/debug/liveedit-diff.cc | 30 +- deps/v8/src/debug/liveedit.cc | 20 +- .../wasm/gdb-server/wasm-module-debug.cc | 4 + .../v8/src/deoptimizer/arm/deoptimizer-arm.cc | 9 +- .../deoptimizer/arm64/deoptimizer-arm64.cc | 9 +- deps/v8/src/deoptimizer/deoptimizer.cc | 233 +- deps/v8/src/deoptimizer/deoptimizer.h | 25 +- deps/v8/src/deoptimizer/frame-description.h | 2 +- .../deoptimizer/frame-translation-builder.cc | 4 +- .../deoptimizer/frame-translation-builder.h | 4 +- .../src/deoptimizer/ia32/deoptimizer-ia32.cc | 9 +- .../loong64/deoptimizer-loong64.cc | 9 +- .../deoptimizer/mips64/deoptimizer-mips64.cc | 9 +- .../v8/src/deoptimizer/ppc/deoptimizer-ppc.cc | 9 +- .../deoptimizer/riscv/deoptimizer-riscv.cc | 9 +- .../src/deoptimizer/s390/deoptimizer-s390.cc | 9 +- deps/v8/src/deoptimizer/translated-state.cc | 42 +- deps/v8/src/deoptimizer/translated-state.h | 7 +- .../v8/src/deoptimizer/x64/deoptimizer-x64.cc | 27 +- deps/v8/src/diagnostics/code-tracer.h | 7 +- deps/v8/src/diagnostics/disassembler.cc | 40 +- deps/v8/src/diagnostics/etw-jit-win.cc | 10 +- deps/v8/src/diagnostics/gdb-jit.cc | 16 +- deps/v8/src/diagnostics/objects-debug.cc | 415 ++-- deps/v8/src/diagnostics/objects-printer.cc | 212 +- deps/v8/src/diagnostics/ppc/disasm-ppc.cc | 42 +- deps/v8/src/diagnostics/riscv/disasm-riscv.cc | 6 + deps/v8/src/diagnostics/s390/disasm-s390.cc | 4 +- deps/v8/src/diagnostics/x64/disasm-x64.cc | 5 + deps/v8/src/execution/OWNERS | 1 + .../src/execution/arm/frame-constants-arm.h | 2 +- deps/v8/src/execution/arm/simulator-arm.h | 2 +- .../execution/arm64/frame-constants-arm64.h | 2 +- .../arm64/pointer-authentication-arm64.h | 65 +- .../v8/src/execution/arm64/simulator-arm64.cc | 20 +- deps/v8/src/execution/execution.cc | 4 +- deps/v8/src/execution/execution.h | 2 +- deps/v8/src/execution/frame-constants.h | 92 +- deps/v8/src/execution/frames-inl.h | 28 +- deps/v8/src/execution/frames.cc | 633 +++++- deps/v8/src/execution/frames.h | 168 +- deps/v8/src/execution/futex-emulation.cc | 12 +- .../src/execution/ia32/frame-constants-ia32.h | 2 +- deps/v8/src/execution/isolate-data.h | 60 +- deps/v8/src/execution/isolate-utils-inl.h | 16 - deps/v8/src/execution/isolate.cc | 559 +++-- deps/v8/src/execution/isolate.h | 122 +- deps/v8/src/execution/local-isolate.h | 6 +- .../loong64/frame-constants-loong64.h | 2 +- .../execution/loong64/simulator-loong64.cc | 10 +- deps/v8/src/execution/messages.cc | 85 +- deps/v8/src/execution/messages.h | 4 + deps/v8/src/execution/microtask-queue.cc | 4 +- .../execution/mips64/frame-constants-mips64.h | 2 +- .../execution/pointer-authentication-dummy.h | 13 + .../v8/src/execution/pointer-authentication.h | 7 + .../src/execution/ppc/frame-constants-ppc.cc | 4 +- .../src/execution/ppc/frame-constants-ppc.h | 2 +- deps/v8/src/execution/ppc/simulator-ppc.cc | 51 - deps/v8/src/execution/ppc/simulator-ppc.h | 4 - .../execution/riscv/frame-constants-riscv.h | 2 +- .../v8/src/execution/riscv/simulator-riscv.cc | 26 +- deps/v8/src/execution/riscv/simulator-riscv.h | 2 +- .../execution/s390/frame-constants-s390.cc | 4 +- .../src/execution/s390/frame-constants-s390.h | 6 +- deps/v8/src/execution/s390/simulator-s390.cc | 116 - deps/v8/src/execution/s390/simulator-s390.h | 4 - deps/v8/src/execution/simulator-base.h | 3 +- deps/v8/src/execution/simulator.h | 4 +- deps/v8/src/execution/tiering-manager.cc | 80 +- deps/v8/src/execution/tiering-manager.h | 4 +- deps/v8/src/execution/vm-state-inl.h | 14 +- deps/v8/src/execution/vm-state.h | 6 +- .../src/execution/x64/frame-constants-x64.h | 2 +- .../externalize-string-extension.cc | 3 +- deps/v8/src/flags/flag-definitions.h | 319 ++- deps/v8/src/flags/flags-impl.h | 12 +- deps/v8/src/flags/flags.cc | 7 +- deps/v8/src/flags/flags.h | 7 +- deps/v8/src/handles/global-handles.cc | 13 +- deps/v8/src/handles/handles.cc | 9 +- deps/v8/src/handles/handles.h | 9 +- deps/v8/src/handles/traced-handles-inl.h | 7 +- deps/v8/src/handles/traced-handles.cc | 15 +- deps/v8/src/handles/traced-handles.h | 2 +- deps/v8/src/heap/allocation-observer.cc | 2 + deps/v8/src/heap/array-buffer-sweeper.cc | 7 +- .../heap/base/incremental-marking-schedule.cc | 5 +- .../heap/base/incremental-marking-schedule.h | 4 +- deps/v8/src/heap/base/stack.h | 6 - deps/v8/src/heap/code-range.cc | 22 +- deps/v8/src/heap/code-range.h | 10 +- deps/v8/src/heap/collection-barrier.cc | 2 + deps/v8/src/heap/combined-heap.h | 7 - deps/v8/src/heap/concurrent-marking.cc | 12 +- .../v8/src/heap/conservative-stack-visitor.cc | 41 +- deps/v8/src/heap/conservative-stack-visitor.h | 15 +- deps/v8/src/heap/cppgc-js/cpp-heap.cc | 14 +- deps/v8/src/heap/cppgc-js/cpp-snapshot.cc | 3 + .../cppgc-js/unified-heap-marking-state-inl.h | 3 +- .../cppgc-js/unified-heap-marking-verifier.cc | 13 +- .../cppgc-js/unified-heap-marking-visitor.cc | 3 - deps/v8/src/heap/cppgc/compactor.cc | 11 +- deps/v8/src/heap/cppgc/heap-base.h | 9 + deps/v8/src/heap/cppgc/heap-config.h | 6 - deps/v8/src/heap/cppgc/heap-page.cc | 4 - deps/v8/src/heap/cppgc/heap-page.h | 4 +- deps/v8/src/heap/cppgc/marker.cc | 17 +- deps/v8/src/heap/cppgc/memory.cc | 71 + deps/v8/src/heap/cppgc/memory.h | 94 +- deps/v8/src/heap/cppgc/object-start-bitmap.h | 2 +- deps/v8/src/heap/cppgc/pointer-policies.cc | 7 + deps/v8/src/heap/cppgc/stats-collector.cc | 2 +- deps/v8/src/heap/cppgc/stats-collector.h | 7 +- deps/v8/src/heap/cppgc/sweeper.cc | 56 +- deps/v8/src/heap/cppgc/visitor.cc | 7 +- deps/v8/src/heap/ephemeron-remembered-set.cc | 4 +- deps/v8/src/heap/evacuation-allocator-inl.h | 1 + deps/v8/src/heap/evacuation-allocator.cc | 13 +- deps/v8/src/heap/evacuation-verifier-inl.h | 5 +- deps/v8/src/heap/evacuation-verifier.cc | 2 +- deps/v8/src/heap/factory-base.cc | 137 +- deps/v8/src/heap/factory-base.h | 23 +- deps/v8/src/heap/factory.cc | 427 +++- deps/v8/src/heap/factory.h | 85 +- deps/v8/src/heap/free-list.cc | 36 +- deps/v8/src/heap/free-list.h | 7 +- deps/v8/src/heap/gc-tracer.cc | 61 +- deps/v8/src/heap/gc-tracer.h | 18 +- deps/v8/src/heap/heap-allocator-inl.h | 87 +- deps/v8/src/heap/heap-allocator.cc | 21 + deps/v8/src/heap/heap-allocator.h | 11 +- deps/v8/src/heap/heap-controller.cc | 66 +- deps/v8/src/heap/heap-controller.h | 12 +- deps/v8/src/heap/heap-inl.h | 125 +- deps/v8/src/heap/heap-verifier.cc | 73 +- deps/v8/src/heap/heap-write-barrier-inl.h | 378 ++-- deps/v8/src/heap/heap-write-barrier.cc | 332 ++- deps/v8/src/heap/heap-write-barrier.h | 177 +- deps/v8/src/heap/heap.cc | 829 +++---- deps/v8/src/heap/heap.h | 192 +- deps/v8/src/heap/incremental-marking-inl.h | 2 + deps/v8/src/heap/incremental-marking-job.cc | 77 +- deps/v8/src/heap/incremental-marking-job.h | 23 +- deps/v8/src/heap/incremental-marking.cc | 150 +- deps/v8/src/heap/incremental-marking.h | 3 +- deps/v8/src/heap/index-generator.cc | 2 +- deps/v8/src/heap/large-page-metadata-inl.h | 1 - deps/v8/src/heap/large-spaces.cc | 9 +- deps/v8/src/heap/local-heap-inl.h | 1 - deps/v8/src/heap/local-heap.cc | 11 + deps/v8/src/heap/local-heap.h | 5 + deps/v8/src/heap/main-allocator-inl.h | 3 +- deps/v8/src/heap/main-allocator.cc | 71 +- deps/v8/src/heap/main-allocator.h | 7 +- deps/v8/src/heap/mark-compact-inl.h | 2 +- deps/v8/src/heap/mark-compact.cc | 788 ++++--- deps/v8/src/heap/mark-compact.h | 2 + deps/v8/src/heap/mark-sweep-utilities.cc | 4 +- deps/v8/src/heap/marking-barrier-inl.h | 27 +- deps/v8/src/heap/marking-barrier.cc | 70 +- deps/v8/src/heap/marking-inl.h | 121 +- deps/v8/src/heap/marking-visitor-inl.h | 131 +- deps/v8/src/heap/marking-visitor.h | 5 +- deps/v8/src/heap/marking.cc | 2 + deps/v8/src/heap/marking.h | 62 +- deps/v8/src/heap/memory-allocator.cc | 16 + deps/v8/src/heap/memory-chunk-metadata-inl.h | 3 - deps/v8/src/heap/memory-chunk.cc | 18 +- deps/v8/src/heap/memory-chunk.h | 37 +- deps/v8/src/heap/memory-measurement.cc | 15 +- deps/v8/src/heap/memory-measurement.h | 1 - deps/v8/src/heap/memory-reducer.cc | 5 +- deps/v8/src/heap/minor-mark-sweep.cc | 10 +- deps/v8/src/heap/mutable-page-metadata-inl.h | 4 - deps/v8/src/heap/mutable-page-metadata.cc | 1 + deps/v8/src/heap/new-spaces.cc | 90 +- deps/v8/src/heap/new-spaces.h | 14 +- deps/v8/src/heap/object-stats.cc | 7 +- deps/v8/src/heap/objects-visiting-inl.h | 5 +- deps/v8/src/heap/objects-visiting.h | 10 +- deps/v8/src/heap/page-metadata-inl.h | 3 - deps/v8/src/heap/page-metadata.cc | 2 + deps/v8/src/heap/paged-spaces-inl.h | 3 - deps/v8/src/heap/paged-spaces.cc | 68 +- deps/v8/src/heap/paged-spaces.h | 28 +- deps/v8/src/heap/pretenuring-handler-inl.h | 23 +- deps/v8/src/heap/pretenuring-handler.cc | 15 +- deps/v8/src/heap/pretenuring-handler.h | 8 +- deps/v8/src/heap/read-only-heap-inl.h | 12 +- deps/v8/src/heap/read-only-heap.cc | 154 +- deps/v8/src/heap/read-only-heap.h | 55 +- deps/v8/src/heap/read-only-promotion.cc | 98 +- deps/v8/src/heap/read-only-spaces.cc | 294 +-- deps/v8/src/heap/read-only-spaces.h | 81 +- deps/v8/src/heap/safepoint.cc | 9 + deps/v8/src/heap/safepoint.h | 7 + deps/v8/src/heap/scavenger-inl.h | 47 +- deps/v8/src/heap/scavenger.cc | 237 ++- deps/v8/src/heap/scavenger.h | 46 +- deps/v8/src/heap/setup-heap-internal.cc | 114 +- deps/v8/src/heap/spaces-inl.h | 4 +- deps/v8/src/heap/sweeper.cc | 13 +- deps/v8/src/heap/third-party/heap-api-stub.cc | 75 - deps/v8/src/heap/third-party/heap-api.h | 66 - .../heap/traced-handles-marking-visitor.cc | 3 + .../src/heap/traced-handles-marking-visitor.h | 4 +- .../young-generation-marking-visitor-inl.h | 6 +- deps/v8/src/ic/OWNERS | 1 + deps/v8/src/ic/accessor-assembler.cc | 68 +- deps/v8/src/ic/accessor-assembler.h | 37 +- deps/v8/src/ic/binary-op-assembler.cc | 35 +- deps/v8/src/ic/call-optimization.cc | 7 +- deps/v8/src/ic/call-optimization.h | 4 +- deps/v8/src/ic/handler-configuration.h | 2 +- deps/v8/src/ic/ic.cc | 364 ++-- deps/v8/src/ic/ic.h | 6 +- deps/v8/src/ic/keyed-store-generic.cc | 12 +- deps/v8/src/ic/unary-op-assembler.cc | 79 +- deps/v8/src/init/bootstrapper.cc | 1675 ++++++++------- deps/v8/src/init/heap-symbols.h | 6 +- deps/v8/src/init/isolate-group.cc | 45 +- deps/v8/src/init/isolate-group.h | 60 +- deps/v8/src/init/v8.cc | 7 +- deps/v8/src/inspector/DEPS | 1 - deps/v8/src/inspector/custom-preview.cc | 3 +- .../src/inspector/v8-debugger-agent-impl.cc | 46 +- deps/v8/src/inspector/v8-debugger-script.cc | 15 +- deps/v8/src/inspector/v8-debugger-script.h | 5 +- .../inspector/v8-heap-profiler-agent-impl.cc | 1 - deps/v8/src/inspector/value-mirror.cc | 2 +- .../src/interpreter/bytecode-array-builder.cc | 6 +- .../src/interpreter/bytecode-array-builder.h | 8 +- deps/v8/src/interpreter/bytecode-generator.cc | 648 ++++-- deps/v8/src/interpreter/bytecode-generator.h | 13 +- deps/v8/src/interpreter/bytecode-node.h | 2 +- deps/v8/src/interpreter/bytecode-register.h | 5 +- deps/v8/src/interpreter/bytecodes.cc | 28 +- deps/v8/src/interpreter/bytecodes.h | 28 +- .../src/interpreter/interpreter-assembler.cc | 16 +- .../src/interpreter/interpreter-generator.cc | 114 +- .../interpreter-intrinsics-generator.cc | 4 + deps/v8/src/interpreter/interpreter.cc | 5 +- deps/v8/src/json/json-parser.cc | 73 +- deps/v8/src/json/json-parser.h | 27 +- deps/v8/src/json/json-stringifier.cc | 83 +- deps/v8/src/libplatform/default-platform.cc | 2 +- deps/v8/src/libplatform/default-platform.h | 2 +- .../src/libplatform/tracing/trace-writer.cc | 2 +- deps/v8/src/libsampler/sampler.cc | 16 +- deps/v8/src/logging/counters-definitions.h | 18 +- deps/v8/src/logging/counters.cc | 7 + deps/v8/src/logging/counters.h | 14 +- deps/v8/src/logging/log-file.cc | 3 +- deps/v8/src/logging/log-file.h | 4 +- deps/v8/src/logging/log.cc | 31 +- deps/v8/src/logging/runtime-call-stats.h | 6 +- .../src/maglev/arm/maglev-assembler-arm-inl.h | 360 ++-- .../v8/src/maglev/arm/maglev-assembler-arm.cc | 34 +- deps/v8/src/maglev/arm/maglev-ir-arm.cc | 81 +- .../maglev/arm64/maglev-assembler-arm64-inl.h | 409 ++-- .../maglev/arm64/maglev-assembler-arm64.cc | 112 +- deps/v8/src/maglev/arm64/maglev-ir-arm64.cc | 52 +- deps/v8/src/maglev/maglev-assembler-inl.h | 105 +- deps/v8/src/maglev/maglev-assembler.cc | 186 +- deps/v8/src/maglev/maglev-assembler.h | 201 +- deps/v8/src/maglev/maglev-basic-block.h | 9 +- deps/v8/src/maglev/maglev-code-generator.cc | 49 +- deps/v8/src/maglev/maglev-code-generator.h | 1 + deps/v8/src/maglev/maglev-compilation-info.cc | 11 +- deps/v8/src/maglev/maglev-compilation-info.h | 6 +- deps/v8/src/maglev/maglev-compiler.cc | 19 +- deps/v8/src/maglev/maglev-graph-builder.cc | 1710 ++++++++++----- deps/v8/src/maglev/maglev-graph-builder.h | 335 ++- deps/v8/src/maglev/maglev-graph-printer.cc | 30 +- deps/v8/src/maglev/maglev-graph-printer.h | 8 +- deps/v8/src/maglev/maglev-graph-processor.h | 163 +- deps/v8/src/maglev/maglev-graph-verifier.h | 8 +- deps/v8/src/maglev/maglev-graph.h | 36 +- .../maglev/maglev-interpreter-frame-state.cc | 234 +- .../maglev/maglev-interpreter-frame-state.h | 90 +- deps/v8/src/maglev/maglev-ir-inl.h | 16 +- deps/v8/src/maglev/maglev-ir.cc | 664 +++--- deps/v8/src/maglev/maglev-ir.h | 457 +++- .../maglev-phi-representation-selector.cc | 17 +- .../maglev-phi-representation-selector.h | 11 +- ...maglev-post-hoc-optimizations-processors.h | 176 +- .../maglev-pre-regalloc-codegen-processors.h | 22 +- deps/v8/src/maglev/maglev-regalloc.cc | 5 + .../maglev/s390/maglev-assembler-s390-inl.h | 360 ++-- .../src/maglev/s390/maglev-assembler-s390.cc | 45 +- deps/v8/src/maglev/s390/maglev-ir-s390.cc | 50 +- .../src/maglev/x64/maglev-assembler-x64-inl.h | 270 ++- .../v8/src/maglev/x64/maglev-assembler-x64.cc | 56 +- deps/v8/src/maglev/x64/maglev-ir-x64.cc | 8 +- deps/v8/src/numbers/conversions.cc | 439 ++-- deps/v8/src/numbers/conversions.h | 61 +- deps/v8/src/numbers/integer-literal.h | 7 +- deps/v8/src/objects/backing-store.cc | 13 +- deps/v8/src/objects/backing-store.h | 14 +- deps/v8/src/objects/bytecode-array-inl.h | 5 - deps/v8/src/objects/bytecode-array.cc | 6 +- deps/v8/src/objects/bytecode-array.h | 8 - deps/v8/src/objects/bytecode-array.tq | 5 +- deps/v8/src/objects/call-site-info-inl.h | 6 +- deps/v8/src/objects/call-site-info.cc | 39 +- deps/v8/src/objects/call-site-info.h | 17 +- deps/v8/src/objects/call-site-info.tq | 4 +- deps/v8/src/objects/code-inl.h | 51 +- deps/v8/src/objects/code.cc | 12 +- deps/v8/src/objects/code.h | 20 +- .../src/objects/compilation-cache-table-inl.h | 46 +- .../v8/src/objects/compilation-cache-table.cc | 25 +- deps/v8/src/objects/compilation-cache-table.h | 4 +- deps/v8/src/objects/contexts.cc | 10 +- deps/v8/src/objects/contexts.h | 7 + deps/v8/src/objects/debug-objects-inl.h | 3 + deps/v8/src/objects/debug-objects.h | 14 + deps/v8/src/objects/debug-objects.tq | 18 +- deps/v8/src/objects/deoptimization-data-inl.h | 11 +- deps/v8/src/objects/deoptimization-data.cc | 4 + deps/v8/src/objects/deoptimization-data.h | 9 + deps/v8/src/objects/dependent-code-inl.h | 7 +- deps/v8/src/objects/descriptor-array-inl.h | 1 + deps/v8/src/objects/dictionary-inl.h | 11 +- deps/v8/src/objects/dictionary.h | 13 +- deps/v8/src/objects/elements.cc | 56 +- deps/v8/src/objects/elements.h | 6 +- deps/v8/src/objects/feedback-cell-inl.h | 30 +- deps/v8/src/objects/feedback-cell.h | 22 +- deps/v8/src/objects/feedback-cell.tq | 2 +- deps/v8/src/objects/feedback-vector-inl.h | 68 +- deps/v8/src/objects/feedback-vector.cc | 72 +- deps/v8/src/objects/feedback-vector.h | 90 +- deps/v8/src/objects/fixed-array-inl.h | 67 +- deps/v8/src/objects/fixed-array.h | 72 +- deps/v8/src/objects/fixed-array.tq | 5 - deps/v8/src/objects/hash-table.h | 5 - deps/v8/src/objects/heap-object.h | 90 +- deps/v8/src/objects/instance-type-checker.h | 14 +- deps/v8/src/objects/instance-type-inl.h | 173 +- deps/v8/src/objects/instruction-stream-inl.h | 21 +- deps/v8/src/objects/instruction-stream.cc | 6 +- deps/v8/src/objects/intl-objects.cc | 40 +- deps/v8/src/objects/intl-objects.h | 28 +- deps/v8/src/objects/js-array-buffer-inl.h | 2 +- .../src/objects/js-atomics-synchronization.cc | 20 +- .../src/objects/js-atomics-synchronization.h | 2 +- deps/v8/src/objects/js-break-iterator.cc | 92 +- deps/v8/src/objects/js-collection.h | 8 +- deps/v8/src/objects/js-date-time-format.cc | 68 +- deps/v8/src/objects/js-date-time-format.h | 34 +- deps/v8/src/objects/js-display-names-inl.h | 6 +- deps/v8/src/objects/js-display-names.h | 14 +- deps/v8/src/objects/js-disposable-stack-inl.h | 66 +- deps/v8/src/objects/js-disposable-stack.cc | 291 ++- deps/v8/src/objects/js-disposable-stack.h | 19 +- deps/v8/src/objects/js-disposable-stack.tq | 5 +- deps/v8/src/objects/js-duration-format-inl.h | 2 +- deps/v8/src/objects/js-duration-format.cc | 2 +- deps/v8/src/objects/js-function-inl.h | 153 +- deps/v8/src/objects/js-function.cc | 75 +- deps/v8/src/objects/js-function.h | 59 +- deps/v8/src/objects/js-function.tq | 7 +- deps/v8/src/objects/js-list-format-inl.h | 4 +- deps/v8/src/objects/js-list-format.cc | 2 +- deps/v8/src/objects/js-list-format.h | 12 +- deps/v8/src/objects/js-locale.cc | 2 +- deps/v8/src/objects/js-number-format.cc | 13 +- deps/v8/src/objects/js-objects-inl.h | 49 +- deps/v8/src/objects/js-objects.cc | 182 +- deps/v8/src/objects/js-objects.h | 56 +- deps/v8/src/objects/js-plural-rules-inl.h | 2 +- deps/v8/src/objects/js-plural-rules.h | 4 +- deps/v8/src/objects/js-promise-inl.h | 21 + deps/v8/src/objects/js-promise.h | 10 +- deps/v8/src/objects/js-promise.tq | 2 +- deps/v8/src/objects/js-proxy.h | 2 +- deps/v8/src/objects/js-regexp-inl.h | 159 +- deps/v8/src/objects/js-regexp.cc | 177 +- deps/v8/src/objects/js-regexp.h | 299 +-- deps/v8/src/objects/js-regexp.tq | 35 +- .../src/objects/js-relative-time-format-inl.h | 2 +- .../v8/src/objects/js-relative-time-format.cc | 13 +- deps/v8/src/objects/js-relative-time-format.h | 5 +- deps/v8/src/objects/js-segment-iterator-inl.h | 2 +- deps/v8/src/objects/js-segment-iterator.cc | 4 +- deps/v8/src/objects/js-segment-iterator.h | 6 +- deps/v8/src/objects/js-segmenter-inl.h | 2 +- deps/v8/src/objects/js-segmenter.cc | 2 +- deps/v8/src/objects/js-segmenter.h | 6 +- deps/v8/src/objects/js-segments-inl.h | 2 +- deps/v8/src/objects/js-segments.h | 6 +- deps/v8/src/objects/js-struct.cc | 5 +- deps/v8/src/objects/js-temporal-objects.cc | 108 +- deps/v8/src/objects/js-temporal-objects.h | 6 +- deps/v8/src/objects/js-weak-refs-inl.h | 3 +- deps/v8/src/objects/keys.cc | 32 +- deps/v8/src/objects/keys.h | 12 +- deps/v8/src/objects/literal-objects-inl.h | 17 +- deps/v8/src/objects/literal-objects.cc | 132 +- deps/v8/src/objects/literal-objects.h | 29 +- deps/v8/src/objects/literal-objects.tq | 3 +- deps/v8/src/objects/lookup.cc | 22 +- deps/v8/src/objects/lookup.h | 12 +- deps/v8/src/objects/map-inl.h | 34 +- deps/v8/src/objects/map-updater.cc | 68 +- deps/v8/src/objects/map-updater.h | 10 +- deps/v8/src/objects/map.cc | 91 +- deps/v8/src/objects/map.h | 36 +- deps/v8/src/objects/module-inl.h | 2 +- deps/v8/src/objects/module.cc | 24 +- deps/v8/src/objects/module.h | 6 +- deps/v8/src/objects/object-list-macros.h | 52 +- deps/v8/src/objects/object-macros.h | 116 +- .../objects/objects-body-descriptors-inl.h | 245 ++- .../v8/src/objects/objects-body-descriptors.h | 5 + deps/v8/src/objects/objects-definitions.h | 98 +- deps/v8/src/objects/objects-inl.h | 142 +- deps/v8/src/objects/objects.cc | 111 +- deps/v8/src/objects/objects.h | 12 +- deps/v8/src/objects/ordered-hash-table.cc | 11 +- deps/v8/src/objects/ordered-hash-table.h | 11 +- deps/v8/src/objects/regexp-match-info.cc | 10 +- deps/v8/src/objects/scope-info.cc | 68 +- deps/v8/src/objects/scope-info.h | 25 +- deps/v8/src/objects/scope-info.tq | 8 +- deps/v8/src/objects/script-inl.h | 12 + deps/v8/src/objects/script.h | 6 +- .../v8/src/objects/shared-function-info-inl.h | 377 ++-- deps/v8/src/objects/shared-function-info.cc | 181 +- deps/v8/src/objects/shared-function-info.h | 150 +- deps/v8/src/objects/shared-function-info.tq | 55 +- deps/v8/src/objects/simd.cc | 28 +- deps/v8/src/objects/slots-inl.h | 6 +- deps/v8/src/objects/smi.h | 12 +- deps/v8/src/objects/source-text-module.cc | 174 +- deps/v8/src/objects/source-text-module.h | 3 +- .../v8/src/objects/string-forwarding-table.cc | 9 +- deps/v8/src/objects/string-inl.h | 21 +- deps/v8/src/objects/string-table.cc | 4 +- deps/v8/src/objects/string.cc | 102 +- deps/v8/src/objects/string.h | 14 +- .../src/objects/swiss-name-dictionary-inl.h | 10 +- deps/v8/src/objects/swiss-name-dictionary.h | 10 +- deps/v8/src/objects/tagged-field-inl.h | 3 +- deps/v8/src/objects/tagged-field.h | 29 +- deps/v8/src/objects/tagged-impl.cc | 6 +- deps/v8/src/objects/tagged-impl.h | 11 + deps/v8/src/objects/templates.cc | 26 +- deps/v8/src/objects/templates.h | 8 +- deps/v8/src/objects/templates.tq | 12 + deps/v8/src/objects/transitions-inl.h | 177 +- deps/v8/src/objects/transitions.cc | 130 +- deps/v8/src/objects/transitions.h | 161 +- deps/v8/src/objects/trusted-object-inl.h | 6 +- deps/v8/src/objects/trusted-object.h | 4 +- deps/v8/src/objects/trusted-object.tq | 2 +- deps/v8/src/objects/value-serializer.cc | 115 +- deps/v8/src/objects/value-serializer.h | 6 +- deps/v8/src/objects/visitors-inl.h | 33 +- deps/v8/src/objects/visitors.h | 26 +- deps/v8/src/parsing/func-name-inferrer.h | 5 +- deps/v8/src/parsing/parse-info.cc | 3 +- deps/v8/src/parsing/parse-info.h | 4 + deps/v8/src/parsing/parser-base.h | 266 ++- deps/v8/src/parsing/parser.cc | 441 ++-- deps/v8/src/parsing/parser.h | 66 +- deps/v8/src/parsing/parsing.cc | 17 +- deps/v8/src/parsing/parsing.h | 6 +- deps/v8/src/parsing/preparser.h | 76 +- deps/v8/src/parsing/rewriter.cc | 30 +- deps/v8/src/parsing/rewriter.h | 14 +- .../src/parsing/scanner-character-streams.cc | 10 +- deps/v8/src/parsing/scanner.cc | 37 +- deps/v8/src/parsing/scanner.h | 32 +- deps/v8/src/profiler/allocation-tracker.cc | 2 +- deps/v8/src/profiler/cpu-profiler.h | 2 +- deps/v8/src/profiler/heap-profiler.cc | 38 +- deps/v8/src/profiler/heap-profiler.h | 2 + .../src/profiler/heap-snapshot-generator.cc | 55 +- .../v8/src/profiler/heap-snapshot-generator.h | 12 +- deps/v8/src/profiler/profile-generator.h | 2 +- .../v8/src/profiler/sampling-heap-profiler.cc | 13 +- deps/v8/src/profiler/tick-sample.cc | 6 +- .../regexp/arm/regexp-macro-assembler-arm.cc | 13 + .../regexp/arm/regexp-macro-assembler-arm.h | 3 + .../arm64/regexp-macro-assembler-arm64.cc | 132 +- .../arm64/regexp-macro-assembler-arm64.h | 6 +- .../experimental/experimental-interpreter.cc | 17 +- .../experimental/experimental-interpreter.h | 4 +- .../src/regexp/experimental/experimental.cc | 133 +- .../v8/src/regexp/experimental/experimental.h | 23 +- .../ia32/regexp-macro-assembler-ia32.cc | 13 + .../regexp/ia32/regexp-macro-assembler-ia32.h | 3 + .../loong64/regexp-macro-assembler-loong64.cc | 13 + .../loong64/regexp-macro-assembler-loong64.h | 3 + .../mips64/regexp-macro-assembler-mips64.cc | 13 + .../mips64/regexp-macro-assembler-mips64.h | 3 + .../regexp/ppc/regexp-macro-assembler-ppc.cc | 17 +- .../regexp/ppc/regexp-macro-assembler-ppc.h | 3 + deps/v8/src/regexp/regexp-ast.h | 11 +- .../src/regexp/regexp-bytecode-generator.cc | 28 +- .../v8/src/regexp/regexp-bytecode-generator.h | 4 + .../v8/src/regexp/regexp-bytecode-peephole.cc | 5 +- deps/v8/src/regexp/regexp-bytecode-peephole.h | 4 +- deps/v8/src/regexp/regexp-compiler-tonode.cc | 22 +- deps/v8/src/regexp/regexp-compiler.cc | 126 +- deps/v8/src/regexp/regexp-compiler.h | 6 +- deps/v8/src/regexp/regexp-dotprinter.cc | 1 + deps/v8/src/regexp/regexp-error.h | 1 - deps/v8/src/regexp/regexp-flags.h | 13 +- deps/v8/src/regexp/regexp-interpreter.cc | 50 +- deps/v8/src/regexp/regexp-interpreter.h | 11 +- .../src/regexp/regexp-macro-assembler-arch.h | 4 +- .../regexp/regexp-macro-assembler-tracer.cc | 33 + .../regexp/regexp-macro-assembler-tracer.h | 3 + deps/v8/src/regexp/regexp-macro-assembler.cc | 23 +- deps/v8/src/regexp/regexp-macro-assembler.h | 14 +- deps/v8/src/regexp/regexp-nodes.h | 43 +- deps/v8/src/regexp/regexp-parser.cc | 2 +- deps/v8/src/regexp/regexp.cc | 430 ++-- deps/v8/src/regexp/regexp.h | 58 +- .../riscv/regexp-macro-assembler-riscv.cc | 13 + .../riscv/regexp-macro-assembler-riscv.h | 3 + .../s390/regexp-macro-assembler-s390.cc | 22 +- .../regexp/s390/regexp-macro-assembler-s390.h | 3 + .../regexp/x64/regexp-macro-assembler-x64.cc | 139 +- .../regexp/x64/regexp-macro-assembler-x64.h | 13 + deps/v8/src/roots/OWNERS | 8 +- deps/v8/src/roots/roots.h | 130 +- deps/v8/src/roots/static-roots.h | 1421 ++++++------ deps/v8/src/runtime/runtime-array.cc | 2 +- deps/v8/src/runtime/runtime-atomics.cc | 12 +- deps/v8/src/runtime/runtime-bigint.cc | 4 +- deps/v8/src/runtime/runtime-classes.cc | 2 +- deps/v8/src/runtime/runtime-compiler.cc | 66 +- deps/v8/src/runtime/runtime-debug.cc | 14 +- deps/v8/src/runtime/runtime-internal.cc | 43 +- deps/v8/src/runtime/runtime-literals.cc | 3 +- deps/v8/src/runtime/runtime-module.cc | 17 +- deps/v8/src/runtime/runtime-object.cc | 12 +- deps/v8/src/runtime/runtime-promise.cc | 23 +- deps/v8/src/runtime/runtime-regexp.cc | 365 +++- deps/v8/src/runtime/runtime-scopes.cc | 54 +- deps/v8/src/runtime/runtime-shadow-realm.cc | 5 +- deps/v8/src/runtime/runtime-strings.cc | 42 +- deps/v8/src/runtime/runtime-test-wasm.cc | 407 +++- deps/v8/src/runtime/runtime-test.cc | 429 ++-- deps/v8/src/runtime/runtime-utils.h | 14 + deps/v8/src/runtime/runtime-wasm.cc | 307 +-- deps/v8/src/runtime/runtime.cc | 158 +- deps/v8/src/runtime/runtime.h | 181 +- deps/v8/src/sandbox/check.h | 2 +- deps/v8/src/sandbox/code-pointer-table-inl.h | 4 + deps/v8/src/sandbox/code-pointer-table.cc | 8 - deps/v8/src/sandbox/code-pointer-table.h | 13 +- .../compactible-external-entity-table.h | 4 +- .../src/sandbox/external-entity-table-inl.h | 202 +- deps/v8/src/sandbox/external-entity-table.h | 174 +- .../src/sandbox/external-pointer-table-inl.h | 2 + deps/v8/src/sandbox/external-pointer-table.cc | 45 +- deps/v8/src/sandbox/external-pointer-table.h | 7 +- deps/v8/src/sandbox/indirect-pointer-inl.h | 22 +- deps/v8/src/sandbox/indirect-pointer-tag.h | 122 +- deps/v8/src/sandbox/indirect-pointer.h | 6 +- deps/v8/src/sandbox/isolate-inl.h | 46 +- deps/v8/src/sandbox/isolate.h | 6 +- deps/v8/src/sandbox/js-dispatch-table-inl.h | 144 +- deps/v8/src/sandbox/js-dispatch-table.cc | 80 +- deps/v8/src/sandbox/js-dispatch-table.h | 114 +- deps/v8/src/sandbox/sandbox.cc | 2 +- deps/v8/src/sandbox/testing.cc | 118 +- deps/v8/src/sandbox/testing.h | 6 + .../src/sandbox/trusted-pointer-table-inl.h | 10 + deps/v8/src/sandbox/trusted-pointer-table.h | 16 +- deps/v8/src/snapshot/OWNERS | 1 + deps/v8/src/snapshot/code-serializer.cc | 32 +- deps/v8/src/snapshot/context-serializer.cc | 2 +- deps/v8/src/snapshot/deserializer.cc | 375 +++- deps/v8/src/snapshot/deserializer.h | 30 +- .../v8/src/snapshot/embedded/embedded-data.cc | 6 +- .../src/snapshot/embedded/embedded-empty.cc | 10 + .../platform-embedded-file-writer-base.h | 14 + .../platform-embedded-file-writer-generic.cc | 6 +- .../platform-embedded-file-writer-win.cc | 6 +- deps/v8/src/snapshot/mksnapshot.cc | 17 +- .../read-only-serializer-deserializer.h | 15 +- deps/v8/src/snapshot/read-only-serializer.cc | 10 +- .../v8/src/snapshot/serializer-deserializer.h | 40 +- deps/v8/src/snapshot/serializer-inl.h | 2 +- deps/v8/src/snapshot/serializer.cc | 66 +- deps/v8/src/snapshot/serializer.h | 4 +- deps/v8/src/snapshot/snapshot.cc | 19 +- deps/v8/src/snapshot/startup-serializer.cc | 2 +- deps/v8/src/snapshot/static-roots-gen.cc | 2 + deps/v8/src/strings/string-builder.h | 3 + deps/v8/src/temporal/temporal-parser.cc | 43 +- deps/v8/src/temporal/temporal-parser.h | 13 +- deps/v8/src/torque/ast.h | 83 +- deps/v8/src/torque/cc-generator.cc | 16 +- deps/v8/src/torque/cc-generator.h | 12 +- deps/v8/src/torque/cfg.cc | 22 +- deps/v8/src/torque/cfg.h | 36 +- .../torque/class-debug-reader-generator.cc | 21 +- deps/v8/src/torque/constants.h | 4 +- deps/v8/src/torque/csa-generator.cc | 25 +- deps/v8/src/torque/csa-generator.h | 22 +- deps/v8/src/torque/declarable.cc | 23 +- deps/v8/src/torque/declarable.h | 51 +- deps/v8/src/torque/declaration-visitor.cc | 26 +- deps/v8/src/torque/declaration-visitor.h | 15 +- deps/v8/src/torque/declarations.cc | 42 +- deps/v8/src/torque/declarations.h | 32 +- deps/v8/src/torque/earley-parser.cc | 18 +- deps/v8/src/torque/earley-parser.h | 51 +- deps/v8/src/torque/global-context.cc | 3 +- deps/v8/src/torque/global-context.h | 4 +- deps/v8/src/torque/implementation-visitor.cc | 130 +- deps/v8/src/torque/implementation-visitor.h | 72 +- deps/v8/src/torque/instance-type-generator.cc | 12 +- deps/v8/src/torque/instructions.cc | 31 +- deps/v8/src/torque/instructions.h | 45 +- deps/v8/src/torque/ls/json-parser.cc | 28 +- deps/v8/src/torque/ls/json-parser.h | 15 +- deps/v8/src/torque/parameter-difference.h | 19 +- deps/v8/src/torque/server-data.cc | 18 +- deps/v8/src/torque/server-data.h | 12 +- deps/v8/src/torque/torque-compiler.cc | 14 +- deps/v8/src/torque/torque-compiler.h | 12 +- deps/v8/src/torque/torque-parser.cc | 357 ++-- deps/v8/src/torque/type-inference.cc | 16 +- deps/v8/src/torque/type-inference.h | 16 +- deps/v8/src/torque/type-oracle.cc | 16 +- deps/v8/src/torque/type-oracle.h | 23 +- deps/v8/src/torque/type-visitor.cc | 22 +- deps/v8/src/torque/type-visitor.h | 12 +- deps/v8/src/torque/types.cc | 78 +- deps/v8/src/torque/types.h | 72 +- deps/v8/src/torque/utils.cc | 22 +- deps/v8/src/torque/utils.h | 18 +- deps/v8/src/trap-handler/handler-inside.cc | 11 + deps/v8/src/trap-handler/handler-outside.cc | 6 +- deps/v8/src/trap-handler/trap-handler.h | 3 +- deps/v8/src/utils/hex-format.cc | 3 +- deps/v8/src/utils/utils.h | 9 + .../baseline/arm/liftoff-assembler-arm-inl.h | 239 ++- .../arm64/liftoff-assembler-arm64-inl.h | 452 +++- .../ia32/liftoff-assembler-ia32-inl.h | 272 ++- .../wasm/baseline/liftoff-assembler-defs.h | 2 +- .../src/wasm/baseline/liftoff-assembler-inl.h | 4 +- .../v8/src/wasm/baseline/liftoff-assembler.cc | 59 +- deps/v8/src/wasm/baseline/liftoff-assembler.h | 75 +- deps/v8/src/wasm/baseline/liftoff-compiler.cc | 425 ++-- .../loong64/liftoff-assembler-loong64-inl.h | 192 +- .../mips64/liftoff-assembler-mips64-inl.h | 192 +- deps/v8/src/wasm/baseline/parallel-move.cc | 23 +- .../baseline/ppc/liftoff-assembler-ppc-inl.h | 114 +- .../riscv/liftoff-assembler-riscv-inl.h | 146 +- .../riscv/liftoff-assembler-riscv32-inl.h | 10 +- .../riscv/liftoff-assembler-riscv64-inl.h | 10 +- .../s390/liftoff-assembler-s390-inl.h | 120 +- .../baseline/x64/liftoff-assembler-x64-inl.h | 531 ++++- deps/v8/src/wasm/c-api.cc | 40 +- deps/v8/src/wasm/canonical-types.cc | 88 +- deps/v8/src/wasm/canonical-types.h | 9 + deps/v8/src/wasm/compilation-environment.h | 25 +- deps/v8/src/wasm/decoder.h | 38 +- deps/v8/src/wasm/function-body-decoder-impl.h | 92 +- deps/v8/src/wasm/function-body-decoder.cc | 2 +- deps/v8/src/wasm/function-compiler.cc | 67 +- deps/v8/src/wasm/function-compiler.h | 8 +- .../wasm/fuzzing/random-module-generation.cc | 94 +- .../wasm/fuzzing/random-module-generation.h | 2 +- deps/v8/src/wasm/graph-builder-interface.cc | 41 +- deps/v8/src/wasm/inlining-tree.h | 6 + deps/v8/src/wasm/jump-table-assembler.cc | 4 +- deps/v8/src/wasm/memory-tracing.cc | 60 - deps/v8/src/wasm/memory-tracing.h | 16 +- deps/v8/src/wasm/module-compiler.cc | 1165 ++++------ deps/v8/src/wasm/module-compiler.h | 64 +- deps/v8/src/wasm/module-decoder-impl.h | 59 +- deps/v8/src/wasm/module-decoder.cc | 87 +- deps/v8/src/wasm/module-decoder.h | 20 +- deps/v8/src/wasm/module-instantiate.cc | 442 ++-- deps/v8/src/wasm/module-instantiate.h | 13 +- deps/v8/src/wasm/names-provider.cc | 13 +- deps/v8/src/wasm/names-provider.h | 2 +- deps/v8/src/wasm/object-access.h | 5 - deps/v8/src/wasm/simd-shuffle.cc | 126 ++ deps/v8/src/wasm/simd-shuffle.h | 36 + deps/v8/src/wasm/stacks.cc | 98 +- deps/v8/src/wasm/stacks.h | 83 +- deps/v8/src/wasm/streaming-decoder.cc | 32 +- deps/v8/src/wasm/streaming-decoder.h | 9 +- .../v8/src/wasm/turboshaft-graph-interface.cc | 1006 ++++----- deps/v8/src/wasm/turboshaft-graph-interface.h | 22 +- deps/v8/src/wasm/value-type.cc | 50 +- deps/v8/src/wasm/value-type.h | 12 +- deps/v8/src/wasm/wasm-builtin-list.h | 3 +- deps/v8/src/wasm/wasm-code-manager.cc | 414 +++- deps/v8/src/wasm/wasm-code-manager.h | 106 +- deps/v8/src/wasm/wasm-debug.cc | 31 +- deps/v8/src/wasm/wasm-debug.h | 1 + deps/v8/src/wasm/wasm-disassembler.cc | 17 +- deps/v8/src/wasm/wasm-engine.cc | 414 ++-- deps/v8/src/wasm/wasm-engine.h | 41 +- deps/v8/src/wasm/wasm-external-refs.cc | 414 +++- deps/v8/src/wasm/wasm-external-refs.h | 66 +- deps/v8/src/wasm/wasm-feature-flags.h | 23 +- deps/v8/src/wasm/wasm-features.cc | 36 +- deps/v8/src/wasm/wasm-features.h | 4 + deps/v8/src/wasm/wasm-import-wrapper-cache.cc | 224 +- deps/v8/src/wasm/wasm-import-wrapper-cache.h | 48 +- deps/v8/src/wasm/wasm-js.cc | 447 ++-- deps/v8/src/wasm/wasm-js.h | 2 + deps/v8/src/wasm/wasm-linkage.h | 24 +- deps/v8/src/wasm/wasm-module-builder.cc | 15 +- deps/v8/src/wasm/wasm-module-builder.h | 22 +- deps/v8/src/wasm/wasm-module.cc | 71 +- deps/v8/src/wasm/wasm-module.h | 59 +- deps/v8/src/wasm/wasm-objects-inl.h | 72 +- deps/v8/src/wasm/wasm-objects.cc | 919 +++++--- deps/v8/src/wasm/wasm-objects.h | 277 ++- deps/v8/src/wasm/wasm-objects.tq | 105 +- deps/v8/src/wasm/wasm-opcodes-inl.h | 2 +- deps/v8/src/wasm/wasm-opcodes.h | 32 +- deps/v8/src/wasm/wasm-serialization.cc | 95 +- deps/v8/src/wasm/wasm-subtyping.cc | 2 +- deps/v8/src/wasm/wasm-tier.h | 7 + deps/v8/src/wasm/well-known-imports.cc | 43 +- deps/v8/src/wasm/well-known-imports.h | 17 +- deps/v8/src/wasm/wrappers.cc | 421 ++-- deps/v8/src/zone/accounting-allocator.cc | 6 +- deps/v8/src/zone/accounting-allocator.h | 3 - deps/v8/src/zone/zone-compact-set.h | 9 + deps/v8/test/benchmarks/benchmarks.status | 2 + deps/v8/test/cctest/BUILD.gn | 9 +- deps/v8/test/cctest/cctest-utils.h | 6 - deps/v8/test/cctest/cctest.cc | 7 +- deps/v8/test/cctest/cctest.h | 19 +- deps/v8/test/cctest/cctest.status | 404 +--- .../test/cctest/compiler/function-tester.cc | 2 +- .../v8/test/cctest/compiler/function-tester.h | 6 +- .../cctest/compiler/test-code-generator.cc | 43 +- .../test-concurrent-shared-function-info.cc | 4 +- .../cctest/compiler/test-multiple-return.cc | 24 +- .../cctest/compiler/test-run-load-store.cc | 2 +- .../test/cctest/compiler/test-run-machops.cc | 4 +- .../cctest/compiler/test-run-native-calls.cc | 14 +- .../cctest/compiler/test-run-variables.cc | 6 +- .../cctest/compiler/test-select-combine.cc | 2 +- deps/v8/test/cctest/heap/heap-utils.cc | 9 +- deps/v8/test/cctest/heap/test-compaction.cc | 24 +- .../cctest/heap/test-concurrent-allocation.cc | 16 +- deps/v8/test/cctest/heap/test-heap.cc | 177 +- .../cctest/heap/test-incremental-marking.cc | 2 +- deps/v8/test/cctest/heap/test-mark-compact.cc | 1 + .../cctest/heap/test-memory-measurement.cc | 9 +- deps/v8/test/cctest/heap/test-spaces.cc | 3 +- .../test/cctest/heap/test-weak-references.cc | 6 +- .../v8/test/cctest/heap/test-write-barrier.cc | 6 +- .../v8/test/cctest/test-accessor-assembler.cc | 4 + deps/v8/test/cctest/test-api-incumbent.cc | 5 +- deps/v8/test/cctest/test-api.cc | 241 ++- deps/v8/test/cctest/test-assembler-mips64.cc | 4 +- deps/v8/test/cctest/test-assembler-riscv64.cc | 63 + .../test/cctest/test-code-stub-assembler.cc | 140 +- deps/v8/test/cctest/test-constantpool.cc | 4 +- deps/v8/test/cctest/test-cpu-profiler.cc | 4 +- deps/v8/test/cctest/test-debug.cc | 315 ++- deps/v8/test/cctest/test-descriptor-array.cc | 4 + .../test/cctest/test-field-type-tracking.cc | 16 +- .../test/cctest/test-func-name-inference.cc | 12 +- deps/v8/test/cctest/test-heap-profiler.cc | 19 +- deps/v8/test/cctest/test-icache.cc | 4 +- .../test-ignition-statistics-extension.cc | 4 +- .../cctest/test-inobject-slack-tracking.cc | 52 +- deps/v8/test/cctest/test-js-to-wasm.cc | 20 - deps/v8/test/cctest/test-js-weak-refs.cc | 30 +- deps/v8/test/cctest/test-lockers.cc | 8 +- .../cctest/test-macro-assembler-loong64.cc | 22 +- .../cctest/test-macro-assembler-riscv32.cc | 20 +- .../cctest/test-macro-assembler-riscv64.cc | 37 +- deps/v8/test/cctest/test-orderedhashtable.cc | 86 +- deps/v8/test/cctest/test-profile-generator.cc | 2 +- deps/v8/test/cctest/test-regexp.cc | 17 +- deps/v8/test/cctest/test-serialize.cc | 45 +- deps/v8/test/cctest/test-shared-strings.cc | 119 +- deps/v8/test/cctest/test-strings.cc | 7 +- .../cctest/test-swiss-name-dictionary-csa.cc | 16 +- .../cctest/test-swiss-name-dictionary-infra.h | 23 +- .../test-swiss-name-dictionary-shared-tests.h | 3 +- .../test/cctest/test-swiss-name-dictionary.cc | 12 +- deps/v8/test/cctest/torque/test-torque.cc | 6 + .../v8/test/cctest/wasm/test-backing-store.cc | 10 +- deps/v8/test/cctest/wasm/test-c-wasm-entry.cc | 2 +- deps/v8/test/cctest/wasm/test-gc.cc | 7 +- deps/v8/test/cctest/wasm/test-grow-memory.cc | 4 +- deps/v8/test/cctest/wasm/test-run-wasm-64.cc | 2 +- deps/v8/test/cctest/wasm/test-run-wasm-f16.cc | 339 ++- .../cctest/wasm/test-run-wasm-memory64.cc | 4 +- .../v8/test/cctest/wasm/test-run-wasm-simd.cc | 122 +- .../cctest/wasm/test-run-wasm-wrappers.cc | 87 +- deps/v8/test/cctest/wasm/test-run-wasm.cc | 2 +- .../cctest/wasm/test-streaming-compilation.cc | 8 +- .../test/cctest/wasm/test-wasm-breakpoints.cc | 4 +- deps/v8/test/cctest/wasm/test-wasm-codegen.cc | 30 +- .../wasm/test-wasm-import-wrapper-cache.cc | 93 +- deps/v8/test/cctest/wasm/test-wasm-metrics.cc | 2 +- deps/v8/test/cctest/wasm/test-wasm-stack.cc | 2 +- .../cctest/wasm/test-wasm-trap-position.cc | 2 +- deps/v8/test/cctest/wasm/wasm-run-utils.cc | 67 +- deps/v8/test/cctest/wasm/wasm-run-utils.h | 31 +- deps/v8/test/cctest/wasm/wasm-simd-utils.cc | 172 +- deps/v8/test/cctest/wasm/wasm-simd-utils.h | 26 +- deps/v8/test/common/wasm/test-signatures.h | 2 +- deps/v8/test/common/wasm/wasm-macro-gen.h | 2 + .../debug-evaluate-no-side-effect-builtins.js | 5 + ...g-evaluate-no-side-effect-runtime-check.js | 62 + deps/v8/test/debugger/debugger.status | 16 +- deps/v8/test/fuzzer/fuzzer.status | 14 +- deps/v8/test/fuzzer/inspector-fuzzer.cc | 5 +- deps/v8/test/fuzzer/multi-return.cc | 13 +- deps/v8/test/fuzzer/regexp.cc | 2 +- deps/v8/test/fuzzer/wasm-deopt.cc | 27 +- deps/v8/test/fuzzer/wasm-fuzzer-common.cc | 43 +- deps/v8/test/fuzzer/wasm-fuzzer-common.h | 4 +- deps/v8/test/fuzzer/wasm-init-expr.cc | 2 +- deps/v8/test/fuzzilli/libreprl.c | 285 ++- deps/v8/test/fuzzilli/libreprl.h | 50 +- deps/v8/test/fuzzilli/main.cc | 25 +- .../wasm-jspi-async-stack-expected.txt | 422 ++-- .../debugger/wasm-jspi-async-stack.js | 23 +- .../debugger/wasm-scripts-expected.txt | 54 +- .../test/inspector/debugger/wasm-scripts.js | 12 +- .../debugger/wasm-stepping-expected.txt | 112 +- .../test/inspector/debugger/wasm-stepping.js | 79 +- deps/v8/test/inspector/inspector-test.cc | 3 +- deps/v8/test/inspector/inspector.status | 320 --- deps/v8/test/inspector/isolate-data.cc | 6 +- deps/v8/test/inspector/isolate-data.h | 6 +- .../regress-crbug-1469092-expected.txt | 2 +- .../regress/regress-crbug-1469092.js | 2 +- .../CanonicalizeLocaleListTakeLocale.js | 6 +- deps/v8/test/intl/regress-40855035.js | 6 - deps/v8/test/js-perf-test/RegExp.json | 49 +- .../test/js-perf-test/RegExp/RegExpTests.json | 67 - deps/v8/test/js-perf-test/RegExp/base.js | 6 +- .../test/js-perf-test/RegExp/base_replace.js | 3 + deps/v8/test/js-perf-test/RegExp/run.js | 16 +- deps/v8/test/message/message.status | 30 +- .../v8/test/message/wasm-recognize-imports.js | 3 +- deps/v8/test/message/wasm-trace-deopt-32.js | 2 +- deps/v8/test/message/wasm-trace-deopt-64.js | 2 +- .../mjsunit/baseline/flush-baseline-code.js | 78 +- .../baseline/flush-only-baseline-code.js | 76 +- deps/v8/test/mjsunit/clone-ic-regressions.js | 14 + deps/v8/test/mjsunit/compiler/dataview-get.js | 34 + deps/v8/test/mjsunit/compiler/dataview-set.js | 34 +- .../mjsunit/compiler/fast-api-annotations.js | 1 + .../fast-api-calls-64-bit-integer-values.js | 1 + .../mjsunit/compiler/fast-api-calls-8args.js | 1 + .../compiler/fast-api-calls-pointer.js | 1 + .../mjsunit/compiler/fast-api-calls-string.js | 1 + .../mjsunit/compiler/fast-api-calls-throw.js | 1 + .../mjsunit/compiler/fast-api-calls-wasm.js | 1 + .../test/mjsunit/compiler/fast-api-calls.js | 8 +- .../compiler/fast-api-clamp-annotations.js | 1 + .../compiler/fast-api-interface-types.js | 1 + .../compiler/fast-api-sequences-x64.js | 1 + .../mjsunit/compiler/fast-api-sequences.js | 1 + .../mjsunit/compiler/regress-crbug-1502042.js | 2 +- deps/v8/test/mjsunit/date-parse.js | 2 +- deps/v8/test/mjsunit/es9/regexp-lookbehind.js | 261 ++- .../mjsunit/harmony/promise-withresolvers.js | 2 +- .../v8/test/mjsunit/harmony/set-difference.js | 23 + .../test/mjsunit/harmony/set-intersection.js | 21 + .../mjsunit/harmony/set-is-disjoint-from.js | 18 + .../test/mjsunit/harmony/set-is-subset-of.js | 18 + .../mjsunit/harmony/set-is-superset-of.js | 18 + .../harmony/shadowrealm-skip-2-throw.mjs | 6 +- .../shadowrealm-skip-3-throw-object.mjs | 6 +- .../test/mjsunit/harmony/suppressed-error.js | 24 +- .../extend-properties-backing-store-1.js | 1 - .../extend-properties-backing-store-2.js | 1 - deps/v8/test/mjsunit/maglev/literals.js | 4 - .../test/mjsunit/maglev/loop-phi-shrinking.js | 10 +- .../maglev/phi-untagging-conversions.js | 8 +- .../test/mjsunit/maglev/regress-343069823.js | 10 +- .../maglev/regress/regress-crbug-1416795.js | 2 +- .../maglev/regress/regress-crbug-1428524.js | 6 +- deps/v8/test/mjsunit/maglev/string-compare.js | 2 +- deps/v8/test/mjsunit/mjsunit.status | 475 +++-- .../test/mjsunit/number-tostring-subnormal.js | 2 +- .../test/mjsunit/object-assign-regressions.js | 50 +- deps/v8/test/mjsunit/regexp-lookahead.js | 4 + .../regress/proto-transition-regress.js | 2 +- .../v8/test/mjsunit/regress/regress-137768.js | 2 +- .../test/mjsunit/regress/regress-335548148.js | 2 +- deps/v8/test/mjsunit/regress/regress-687.js | 2 +- .../mjsunit/regress/regress-crbug-626715.js | 2 +- .../mjsunit/regress/regress-crbug-935932.js | 2 +- .../regress/regress-refreeze-same-map.js | 2 +- .../regress/wasm/i32-lowering-inlining.js | 2 +- .../mjsunit/regress/wasm/regress-10831.js | 2 +- .../mjsunit/regress/wasm/regress-12874.js | 2 +- .../mjsunit/regress/wasm/regress-1364036.js | 2 +- .../mjsunit/regress/wasm/regress-1374535.js | 2 +- .../mjsunit/regress/wasm/regress-1447367.js | 2 +- .../mjsunit/regress/wasm/regress-14695.js | 2 +- .../mjsunit/regress/wasm/regress-1490847-3.js | 2 +- .../mjsunit/regress/wasm/regress-1492772.js | 2 +- .../mjsunit/regress/wasm/regress-1511849.js | 2 +- .../mjsunit/regress/wasm/regress-1514304.js | 2 +- .../mjsunit/regress/wasm/regress-1523414.js | 2 +- .../mjsunit/regress/wasm/regress-324690505.js | 1 + .../mjsunit/regress/wasm/regress-325372946.js | 2 +- .../mjsunit/regress/wasm/regress-326091470.js | 2 +- .../mjsunit/regress/wasm/regress-326260438.js | 2 +- .../mjsunit/regress/wasm/regress-331358160.js | 11 - .../mjsunit/regress/wasm/regress-334687959.js | 2 +- .../regress/wasm/regress-336358915-a.js | 18 - .../mjsunit/regress/wasm/regress-336358915.js | 2 +- .../mjsunit/regress/wasm/regress-347961785.js | 2 +- .../regress/wasm/regress-crbug-1507663.js | 2 +- .../regress/wasm/regress-crbug-1510626.js | 2 +- .../mjsunit/regress/wasm/regress-v8-14471.js | 8 +- .../mjsunit/sandbox/memory-corruption-api.js | 4 +- .../sandbox/regress/regress-334120897.js | 15 +- .../sandbox/regress/regress-349502157.js | 5 +- .../regress/regress-crbug-335810507.js | 6 +- .../sandbox/regress/regress-crbug-40926051.js | 3 +- .../wasm-imports-concurrent-mutation.js | 16 +- .../mjsunit/sandbox/wasm-inlining-sigcheck.js | 7 +- .../sandbox/wasm-manipulated-instance.js | 15 +- .../sandbox/wasm-signature-verification.js | 15 +- .../test/mjsunit/sandbox/wasm-table-import.js | 3 +- .../mjsunit/sandbox/wasm-table-sigcheck.js | 5 +- .../sandbox/wasm-table-wasmjsfunction.js | 5 +- deps/v8/test/mjsunit/tools/foozzie.js | 5 +- .../turboshaft/maglev-frontend/raw-abs.js | 2 +- .../turboshaft/turboshaft-frontend-test.js | 27 - .../turboshaft-instruction-selection.js | 44 - .../test/mjsunit/turboshaft/type-inference.js | 118 - .../mjsunit/turboshaft/typed-optimizations.js | 2 +- .../mjsunit/wasm/compare-exchange-stress.js | 2 +- .../mjsunit/wasm/compare-exchange64-stress.js | 2 +- .../mjsunit/wasm/deopt/deopt-call-indirect.js | 6 +- .../wasm/deopt/deopt-dynamic-tierup.js | 4 +- .../wasm/deopt/deopt-feedback-states.js | 18 +- .../deopt/deopt-inlined-param-stack-slots.js | 6 +- .../wasm/deopt/deopt-inlined-stacktrace.js | 8 +- .../test/mjsunit/wasm/deopt/deopt-inlined.js | 10 +- .../mjsunit/wasm/deopt/deopt-int64-values.js | 12 +- .../wasm/deopt/deopt-large-i31ref-constant.js | 4 +- .../deopt-many-params-many-locals-s128.js | 8 +- .../wasm/deopt/deopt-many-params-tagged.js | 14 +- .../mjsunit/wasm/deopt/deopt-many-params.js | 6 +- .../mjsunit/wasm/deopt/deopt-memory-access.js | 4 +- .../test/mjsunit/wasm/deopt/deopt-metrics.js | 2 +- .../test/mjsunit/wasm/deopt/deopt-minimal.js | 8 +- .../deopt-multi-instance-different-callee.js | 8 +- .../deopt/deopt-multi-instance-inlined.js | 18 +- .../wasm/deopt/deopt-multi-instance.js | 18 +- .../test/mjsunit/wasm/deopt/deopt-multiple.js | 10 +- deps/v8/test/mjsunit/wasm/deopt/deopt-nan.js | 26 +- .../wasm/deopt/deopt-non-inlineable-target.js | 14 +- .../wasm/deopt/deopt-non-inlined-target.js | 8 +- .../wasm/deopt/deopt-signal-handler.js | 4 +- .../deopt/deopt-tail-call-parent-frame.js | 4 +- .../wasm/deopt/deopt-untagged-parameters.js | 1 + .../mjsunit/wasm/deopt/deopt-value-types.js | 14 +- ...api-calls-with-wellknown-imports-floats.js | 1 + ...st-api-calls-with-wellknown-imports-i64.js | 1 + deps/v8/test/mjsunit/wasm/gc-casts-exnref.js | 2 +- .../mjsunit/wasm/gc-js-interop-helpers.js | 8 +- .../mjsunit/wasm/gc-js-interop-objects.js | 3 + deps/v8/test/mjsunit/wasm/gc-js-interop.js | 15 +- .../mjsunit/wasm/gc-optimization-array-get.js | 2 +- deps/v8/test/mjsunit/wasm/gc-optimizations.js | 2 +- deps/v8/test/mjsunit/wasm/generic-wrapper.js | 1 - .../wasm/imported-strings-constants.js | 4 +- .../mjsunit/wasm/imported-strings-invalid.js | 23 +- .../wasm/imported-strings-streaming.js | 6 +- deps/v8/test/mjsunit/wasm/imported-strings.js | 339 +-- deps/v8/test/mjsunit/wasm/inlining.js | 2 +- .../wasm/lazy-feedback-vector-allocation.js | 2 +- deps/v8/test/mjsunit/wasm/loop-rotation.js | 2 +- deps/v8/test/mjsunit/wasm/memory64.js | 49 +- .../mjsunit/wasm/shared-everything/basic.js | 2 +- .../mjsunit/wasm/stack-switching-export.js | 264 +-- .../wasm/stack-switching-generic-wrapper.js | 7 +- .../mjsunit/wasm/stack-switching-new-api.js | 562 ----- deps/v8/test/mjsunit/wasm/stack-switching.js | 503 ++--- deps/v8/test/mjsunit/wasm/table64-import.js | 4 +- deps/v8/test/mjsunit/wasm/turboshaft/basic.js | 11 - .../test/mjsunit/wasm/wasm-module-builder.js | 56 +- .../v8/test/mjsunit/wasm/wasm-to-js-tierup.js | 2 +- deps/v8/test/mjsunit/wasm/wasm-to-js.js | 2 +- deps/v8/test/test262/BUILD.gn | 1 + deps/v8/test/test262/PRESUBMIT.py | 8 +- ...using-in-async-function-call-with-await.js | 33 - ...ng-in-async-function-call-without-await.js | 32 - .../await-using-in-block.js | 32 - .../await-using-in-for-in-statement.js | 26 - .../await-using-in-for-of-statement.js | 27 - .../await-using-in-for-statement.js | 26 - .../await-using-in-switch-case-block.js | 28 - ...wait-using-with-no-async-dispose-method.js | 23 - .../await-using-with-sync-dispose-method.js | 32 - .../mixed-call-dispose-methods.js | 32 - .../local-tests/test/staging/features.txt | 15 +- deps/v8/test/test262/test262.status | 374 +++- deps/v8/test/test262/testcfg.py | 10 +- deps/v8/test/unittests/BUILD.gn | 8 +- .../test/unittests/api/api-wasm-unittest.cc | 34 +- .../unittests/api/deserialize-unittest.cc | 4 +- .../api/resource-constraints-unittest.cc | 12 +- .../test/unittests/api/v8-array-unittest.cc | 17 +- .../assembler/assembler-x64-unittest.cc | 31 + .../assembler/disasm-riscv-unittest.cc | 10 + .../assembler/disasm-s390-unittest.cc | 76 - .../assembler/macro-assembler-x64-unittest.cc | 109 +- deps/v8/test/unittests/base/cpu-unittest.cc | 1 - .../base/doubly-threaded-list-unittest.cc | 1 - .../test/unittests/base/ieee754-unittest.cc | 20 +- .../unittests/base/platform/time-unittest.cc | 2 - .../unittests/codegen/code-layout-unittest.cc | 4 + .../unittests/codegen/code-pages-unittest.cc | 14 +- .../compiler-dispatcher-unittest.cc | 2 +- .../instruction-selector-arm64-unittest.cc | 6 +- ...aft-instruction-selector-arm64-unittest.cc | 478 +++-- .../backend/instruction-selector-unittest.h | 10 +- ...turboshaft-instruction-selector-unittest.h | 47 +- .../unittests/compiler/compiler-unittest.cc | 265 ++- .../unittests/compiler/function-tester.cc | 6 +- .../test/unittests/compiler/function-tester.h | 6 +- .../instruction-selector-ia32-unittest.cc | 2 +- .../compiler/int64-lowering-unittest.cc | 18 +- .../run-bytecode-graph-builder-unittest.cc | 2 +- .../compiler/run-jscalls-unittest.cc | 4 +- .../compiler/run-tail-calls-unittest.cc | 2 +- .../turboshaft/control-flow-unittest.cc | 1 - .../loop-unrolling-analyzer-unittest.cc | 6 +- .../compiler/turboshaft/opmask-unittest.cc | 5 +- .../simplified-lowering-reducer-unittest.cc | 38 - .../turboshaft/snapshot-table-unittest.cc | 1 - .../x64/instruction-selector-x64-unittest.cc | 2 +- ...shaft-instruction-selector-x64-unittest.cc | 11 +- .../debug/debug-property-iterator-unittest.cc | 1 + .../execution/microtask-queue-unittest.cc | 4 +- .../execution/pointer-auth-arm64-unittest.cc | 12 +- .../execution/thread-termination-unittest.cc | 1 + .../unittests/heap/base/bytes-unittest.cc | 30 +- .../conservative-stack-visitor-unittest.cc | 39 +- .../embedder-roots-handler-unittest.cc | 1 + .../unified-heap-snapshot-unittest.cc | 36 + .../heap/cppgc-js/unified-heap-unittest.cc | 5 +- .../heap/cppgc/concurrent-sweeper-unittest.cc | 3 +- .../heap/cppgc/gc-invoker-unittest.cc | 13 +- .../heap/cppgc/heap-growing-unittest.cc | 14 +- .../heap/cppgc/metric-recorder-unittest.cc | 2 +- .../unittests/heap/cppgc/test-platform.cc | 3 +- .../unittests/heap/direct-handles-unittest.cc | 2 +- .../test/unittests/heap/gc-tracer-unittest.cc | 49 +- .../unittests/heap/global-handles-unittest.cc | 2 + .../heap/global-safepoint-unittest.cc | 4 +- .../heap/heap-controller-unittest.cc | 44 +- deps/v8/test/unittests/heap/heap-unittest.cc | 181 +- .../heap/index-generator-unittest.cc | 6 +- .../heap/inner-pointer-resolution-unittest.cc | 23 - .../test/unittests/heap/iterators-unittest.cc | 3 +- .../unittests/heap/local-factory-unittest.cc | 20 +- .../unittests/heap/local-handles-unittest.cc | 4 +- .../unittests/heap/local-heap-unittest.cc | 8 +- .../heap/persistent-handles-unittest.cc | 6 +- deps/v8/test/unittests/heap/pool-unittest.cc | 1 - .../unittests/heap/shared-heap-unittest.cc | 74 +- .../v8/test/unittests/heap/spaces-unittest.cc | 3 +- .../heap/strong-root-allocator-unittest.cc | 4 +- .../bytecode-array-builder-unittest.cc | 2 +- .../AsyncGenerators.golden | 178 +- .../bytecode_expectations/AsyncModules.golden | 238 +-- .../bytecode_expectations/ForAwaitOf.golden | 68 +- .../bytecode_expectations/ForOfLoop.golden | 34 +- .../bytecode_expectations/Modules.golden | 319 ++- .../PrivateAccessorAccess.golden | 8 +- .../PrivateMethodAccess.golden | 4 +- .../StandardForLoop.golden | 38 +- .../StaticPrivateMethodAccess.golden | 30 +- .../interpreter/bytecodes-unittest.cc | 20 +- .../constant-array-builder-unittest.cc | 2 +- .../interpreter-assembler-unittest.cc | 2 +- .../interpreter/interpreter-tester.h | 2 +- .../interpreter/interpreter-unittest.cc | 12 +- ...mics-synchronization-primitive-unittest.cc | 18 +- .../libplatform/default-platform-unittest.cc | 10 +- .../v8/test/unittests/logging/log-unittest.cc | 9 +- .../unittests/maglev/node-type-unittest.cc | 2 +- .../test/unittests/numbers/bigint-unittest.cc | 4 +- .../unittests/numbers/conversions-unittest.cc | 255 ++- .../concurrent-feedback-vector-unittest.cc | 2 +- .../objects/concurrent-js-array-unittest.cc | 4 +- .../objects/concurrent-prototype-unittest.cc | 6 +- .../concurrent-transition-array-unittest.cc | 8 +- .../objects/elements-kind-unittest.cc | 15 +- .../objects/feedback-vector-unittest.cc | 36 +- .../unittests/objects/hashcode-unittest.cc | 8 +- .../unittests/objects/modules-unittest.cc | 21 + .../test/unittests/objects/object-unittest.cc | 56 +- .../objects/value-serializer-unittest.cc | 22 +- .../objects/wasm-backing-store-unittest.cc | 10 +- .../unittests/objects/weakmaps-unittest.cc | 32 +- .../unittests/objects/weaksets-unittest.cc | 10 +- .../test/unittests/parser/decls-unittest.cc | 3 + .../test/unittests/parser/parsing-unittest.cc | 662 +++++- .../unittests/parser/preparser-unittest.cc | 6 +- .../v8/test/unittests/regexp/regexp-fuzzer.cc | 4 +- .../test/unittests/regexp/regexp-unittest.cc | 97 +- .../regress/regress-crbug-1056054-unittest.cc | 2 +- .../runtime/runtime-debug-unittest.cc | 3 +- .../unittests/strings/unicode-unittest.cc | 1 + .../temporal/temporal-parser-unittest.cc | 26 +- deps/v8/test/unittests/test-helpers.cc | 3 +- deps/v8/test/unittests/test-utils.h | 6 - deps/v8/test/unittests/testcfg.py | 1 + .../torque/earley-parser-unittest.cc | 5 +- .../unittests/torque/ls-message-unittest.cc | 2 +- .../test/unittests/torque/torque-unittest.cc | 8 +- .../unittests/torque/torque-utils-unittest.cc | 10 +- deps/v8/test/unittests/unittests.status | 59 - .../wasm/function-body-decoder-unittest.cc | 139 +- .../wasm/memory-protection-unittest.cc | 91 +- .../wasm/module-decoder-memory64-unittest.cc | 13 +- .../wasm/module-decoder-table64-unittest.cc | 22 +- .../unittests/wasm/module-decoder-unittest.cc | 57 +- .../unittests/wasm/simd-shuffle-unittest.cc | 75 + deps/v8/test/wasm-api-tests/traps.cc | 3 +- .../test/wasm-api-tests/wasm-api-tests.status | 8 - deps/v8/test/wasm-js/testcfg.py | 3 +- deps/v8/test/wasm-js/tests.tar.gz.sha1 | 2 +- deps/v8/test/wasm-js/wasm-js.status | 23 +- .../v8/test/wasm-spec-tests/tests.tar.gz.sha1 | 2 +- .../wasm-spec-tests/wasm-spec-tests.status | 106 +- ...d-arguments-in-closure-inline-expected.txt | 2 +- ...ate-inlined-arguments-in-closure-inline.js | 2 +- ...String-elision-trailing-comma-expected.txt | 2 +- .../webkit/toString-elision-trailing-comma.js | 2 +- deps/v8/test/webkit/webkit.status | 4 +- deps/v8/third_party/glibc/README.v8 | 3 +- .../crdtp/json_platform_v8.cc | 3 +- deps/v8/third_party/v8/builtins/array-sort.tq | 4 +- deps/v8/third_party/v8/codegen/fp16-inl.h | 11 +- deps/v8/tools/.vpython3 | 5 + deps/v8/tools/README.md | 4 +- .../tools/builtins-pgo/download_profiles.py | 417 ++-- .../builtins-pgo/download_profiles_test.py | 167 +- deps/v8/tools/cfi/ignores.txt | 2 +- .../clusterfuzz/foozzie/testdata/build3/d8.py | 2 + .../foozzie/testdata/failure_output.txt | 23 +- .../foozzie/testdata/failure_output_arch.txt | 23 +- .../testdata/failure_output_second.txt | 23 +- .../clusterfuzz/foozzie/testdata/fuzz-123.js | 3 + .../foozzie/testdata/smoke_test_output.txt | 19 +- .../tools/clusterfuzz/foozzie/v8_commands.py | 6 + .../tools/clusterfuzz/foozzie/v8_foozzie.py | 159 +- .../clusterfuzz/foozzie/v8_foozzie_test.py | 219 +- .../clusterfuzz/foozzie/v8_fuzz_flags.json | 1 + deps/v8/tools/clusterfuzz/foozzie/v8_mock.js | 6 + .../clusterfuzz/foozzie/v8_suppressions.py | 44 + .../clusterfuzz/js_fuzzer/source_helpers.js | 25 +- .../js_fuzzer/test_data/mjsunit/test_load.js | 5 + .../test_data/mjsunit/test_load_expected.js | 3 + .../debug_helper/debug-helper-internal.h | 1 + .../debug_helper/get-object-properties.cc | 13 +- deps/v8/tools/dev/gen-tags.py | 2 +- deps/v8/tools/dev/gm.py | 10 +- deps/v8/tools/gcmole/BUILD.gn | 1 + deps/v8/tools/gdbinit | 26 +- deps/v8/tools/gen-postmortem-metadata.py | 1 - deps/v8/tools/grokdump.py | 223 +- deps/v8/tools/lldb_commands.py | 2 +- deps/v8/tools/mb/mb.py | 97 + deps/v8/tools/mb/mb_test.py | 101 +- deps/v8/tools/package-lock.json | 1895 +++++++++-------- deps/v8/tools/package.json | 8 +- deps/v8/tools/parse-processor.html | 2 +- deps/v8/tools/release/common_includes.py | 10 +- deps/v8/tools/run.py | 20 +- deps/v8/tools/run_perf.py | 11 +- deps/v8/tools/system-analyzer/local-server.sh | 27 +- deps/v8/tools/testrunner/build_config.py | 2 +- deps/v8/tools/testrunner/local/statusfile.py | 5 +- deps/v8/tools/testrunner/local/variants.py | 11 +- deps/v8/tools/testrunner/objects/testcase.py | 10 + deps/v8/tools/turbolizer/package-lock.json | 128 +- .../turboshaft-graph-operation.ts | 2 +- .../tools/turbolizer/src/views/range-view.ts | 2 +- deps/v8/tools/v8windbg/src/js-stack.h | 1 - .../wasm/mjsunit-module-disassembler-impl.h | 33 +- deps/v8/tools/wasm/module-inspector.cc | 16 +- deps/v8/tools/whitespace.txt | 1 + v8.cmake | 56 + 1730 files changed, 61543 insertions(+), 37543 deletions(-) delete mode 100755 build.sh delete mode 100644 deps/v8/src/base/optional.h delete mode 100644 deps/v8/src/base/template-meta-programming/algorithm.h delete mode 100644 deps/v8/src/compiler/turboshaft/simplified-lowering-phase.cc delete mode 100644 deps/v8/src/compiler/turboshaft/simplified-lowering-phase.h delete mode 100644 deps/v8/src/compiler/turboshaft/simplified-lowering-reducer.h delete mode 100644 deps/v8/src/heap/third-party/heap-api-stub.cc delete mode 100644 deps/v8/src/heap/third-party/heap-api.h delete mode 100644 deps/v8/src/wasm/memory-tracing.cc delete mode 100644 deps/v8/test/intl/regress-40855035.js delete mode 100644 deps/v8/test/js-perf-test/RegExp/RegExpTests.json delete mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-331358160.js delete mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-336358915-a.js delete mode 100644 deps/v8/test/mjsunit/turboshaft/turboshaft-frontend-test.js delete mode 100644 deps/v8/test/mjsunit/turboshaft/turboshaft-instruction-selection.js delete mode 100644 deps/v8/test/mjsunit/turboshaft/type-inference.js delete mode 100644 deps/v8/test/mjsunit/wasm/stack-switching-new-api.js delete mode 100644 deps/v8/test/test262/local-tests/test/staging/explicit-resource-management/await-using-in-async-function-call-with-await.js delete mode 100644 deps/v8/test/test262/local-tests/test/staging/explicit-resource-management/await-using-in-async-function-call-without-await.js delete mode 100644 deps/v8/test/test262/local-tests/test/staging/explicit-resource-management/await-using-in-block.js delete mode 100644 deps/v8/test/test262/local-tests/test/staging/explicit-resource-management/await-using-in-for-in-statement.js delete mode 100644 deps/v8/test/test262/local-tests/test/staging/explicit-resource-management/await-using-in-for-of-statement.js delete mode 100644 deps/v8/test/test262/local-tests/test/staging/explicit-resource-management/await-using-in-for-statement.js delete mode 100644 deps/v8/test/test262/local-tests/test/staging/explicit-resource-management/await-using-in-switch-case-block.js delete mode 100644 deps/v8/test/test262/local-tests/test/staging/explicit-resource-management/await-using-with-no-async-dispose-method.js delete mode 100644 deps/v8/test/test262/local-tests/test/staging/explicit-resource-management/await-using-with-sync-dispose-method.js delete mode 100644 deps/v8/test/test262/local-tests/test/staging/explicit-resource-management/mixed-call-dispose-methods.js delete mode 100644 deps/v8/test/unittests/compiler/turboshaft/simplified-lowering-reducer-unittest.cc create mode 100644 v8.cmake diff --git a/.gitignore b/.gitignore index 123a354a..f9c13656 100644 --- a/.gitignore +++ b/.gitignore @@ -32,4 +32,12 @@ _ *.app sample pand -build/ \ No newline at end of file +build/ + +# v8 related: +_/ +deps/v8 +deps/.cipd +deps/depot_tools +deps/.gclient* +deps/.gcs_entries diff --git a/README.md b/README.md index 71a8ab24..d1610c46 100644 --- a/README.md +++ b/README.md @@ -18,16 +18,25 @@ My own JavaScript runtime - currently, just randomly messing around with v8 engine in C++. Very unstable as I learn how things work together. -### TODO: - -- [x] Try to bind SWC (written in Rust) into my C++ codebase -- [x] Integrate my async IO library for runtime's event loop: [luxio](https://github.com/michaldziuba03/luxio) (renamed to `pandio`, runtime will use updated version soon). -- [x] Create timers -- [x] Clunky TCP support -- [x] Basic support for ES6 imports -- [ ] Improve TCP module -- [ ] Improve memory management and fix potential leaks -- [ ] File system module +### Building + +Make sure you have CMake installed. + +You need to download v8 as dependency and it will take reasonable amount of time to compile (even 40 mins - depends on machine). + +```sh +# Download v8 and build +cmake -P v8.cmake +mkdir build +cd build + +# Build our actual project +cmake .. +cmake --build . +``` + +> `v8.cmake` script is not tested yet on fresh Linux installation. + > Current state example: diff --git a/build.sh b/build.sh deleted file mode 100755 index fafd1f73..00000000 --- a/build.sh +++ /dev/null @@ -1,21 +0,0 @@ -#!/bin/bash - -LIBS_DIR="./deps" - -V8_DIR="$LIBS_DIR/v8" -INCLUDE_DIR="$V8_DIR/include" -LIB_DIR="$V8_DIR/out.gn/x64.release.sample/obj" - - -SRC="core/main.cc" - -CXXFLAGS="-std=c++20 -I$INCLUDE_DIR -I$LIBS_DIR/swcc/include -I$LIBS_DIR/luxio/src" -LDFLAGS="-L$LIB_DIR -L$LIBS_DIR/luxio/build -L$LIBS_DIR/swcc/target/release -lswcc -lluxio -lv8_libplatform -lv8_monolith -pthread -lrt -ldl -DV8_ENABLE_SANDBOX=1 -DV8_COMPRESS_POINTERS=1" - -g++ $CXXFLAGS $SRC $LDFLAGS -o pand - -if [ $? -eq 0 ]; then - echo "Compiled successfully." -else - echo "Compilation failed." -fi diff --git a/deps/v8/.clang-tidy b/deps/v8/.clang-tidy index f4796364..aa7d3813 100644 --- a/deps/v8/.clang-tidy +++ b/deps/v8/.clang-tidy @@ -2,6 +2,10 @@ --- Checks: '-*, bugprone-unique-ptr-array-mismatch, + # google-build-explicit-make-pair, + google-default-arguments, + google-explicit-constructor, + google-readability-casting, modernize-redundant-void-arg, modernize-replace-random-shuffle, modernize-shrink-to-fit, @@ -11,12 +15,10 @@ # modernize-use-equals-delete, modernize-use-nullptr, modernize-use-override, - # google-build-explicit-make-pair, - google-default-arguments, - google-explicit-constructor, - google-readability-casting' + performance-inefficient-vector-operation, + performance-trivially-destructible, + performance-unnecessary-copy-initialization' WarningsAsErrors: '' HeaderFilterRegex: '' AnalyzeTemporaryDtors: false ... - diff --git a/deps/v8/.editorconfig b/deps/v8/.editorconfig index 9d08a1a8..0a4c9a6c 100644 --- a/deps/v8/.editorconfig +++ b/deps/v8/.editorconfig @@ -1,9 +1,9 @@ -root = true +# editorconfig.org [*] charset = utf-8 -indent_style = space -indent_size = 2 end_of_line = lf +indent_size = 2 +indent_style = space insert_final_newline = true trim_trailing_whitespace = true diff --git a/deps/v8/.gitignore b/deps/v8/.gitignore index 075446de..9142623e 100644 --- a/deps/v8/.gitignore +++ b/deps/v8/.gitignore @@ -68,6 +68,8 @@ /third_party/colorama/src !/third_party/cpu_features /third_party/cpu_features/src +!/third_party/fast_float +/third_party/fast_float/src !/third_party/glibc !/third_party/googletest /third_party/googletest/src @@ -81,8 +83,8 @@ !/third_party/test262-harness !/third_party/v8 !/third_party/wasm-api -/tools/builtins-pgo/profiles/*.profile -/tools/builtins-pgo/profiles/profiles_version +/tools/builtins-pgo/profiles/* +!/tools/builtins-pgo/profiles/.* /tools/clang /tools/gcmole/bootstrap /tools/gcmole/gcmole-tools diff --git a/deps/v8/AUTHORS b/deps/v8/AUTHORS index e53a6577..60b00ad5 100644 --- a/deps/v8/AUTHORS +++ b/deps/v8/AUTHORS @@ -71,7 +71,9 @@ Anton Bershanskiy <8knots@protonmail.com> Anton Bikineev Ao Wang Archil Sharashenidze +Artem Kobzar Arthur Islamov +Asuka Shikina Aurèle Barrière Bala Avulapati Bangfu Tao @@ -143,11 +145,11 @@ Henrique Ferreiro Helmut Januschka Hirofumi Mako Hisham Muhammad -Ho Cheung Honggyu Kim Huáng Jùnliàng HyeockJin Kim Iain Ireland +Ilya Gavrilin Ingvar Stepanyan Ioseb Dzmanashvili Isiah Meadows @@ -170,6 +172,7 @@ Joel Stanley Johan Bergström Johan Levin John Paul Adrian Glaubitz +Jojo R Jonathan Liu Juan Arboleda Julien Brianceau @@ -205,7 +208,9 @@ Matt Hanselman Matthew Sporleder Maxim Mazurok Maxim Mossienko +Md Hasibul Hasan Meir Shpilraien +Meng Tan Michael Lutz Michael Mclaughlin Michael Smith @@ -264,6 +269,7 @@ Sébastien Doeraene Seo Sanghyeon Shawn Anastasio Shawn Presser +Sho Miyamoto Stefan Penner Stefan Stojanovic Stephan Hartmann @@ -299,6 +305,7 @@ Wiktor Garbacz Wouter Vermeiren Xiaofang Zou Xiaoyin Liu +Yagiz Nizipli Yanbo Li Yannic Bonenberger Yi Wang @@ -307,11 +314,13 @@ Youfeng Hao Yu Yin Yujie Wang Yuri Iozzelli +Yuri Gaevsky Yusif Khudhur Yuxiang Cao Zac Hansen Zeynep Cankara Zhao Jiazhong +Zhaojun Meng Zheng Liu Zhongping Wang 柳荣一 diff --git a/deps/v8/BUILD.bazel b/deps/v8/BUILD.bazel index 0718b28b..ce47f37a 100644 --- a/deps/v8/BUILD.bazel +++ b/deps/v8/BUILD.bazel @@ -43,7 +43,6 @@ load(":bazel/v8-non-pointer-compression.bzl", "v8_binary_non_pointer_compression # v8_enable_concurrent_marking # v8_enable_conservative_stack_scanning # v8_enable_direct_handle -# v8_enable_direct_local # v8_enable_local_off_stack_check # v8_enable_ignition_dispatch_counting # v8_enable_builtins_optimization @@ -60,8 +59,6 @@ load(":bazel/v8-non-pointer-compression.bzl", "v8_binary_non_pointer_compression # v8_enable_gdbjit # v8_check_header_includes # v8_enable_lazy_source_positions -# v8_enable_third_party_heap -# v8_third_party_heap_files # v8_disable_write_barriers # v8_enable_unconditional_write_barriers # v8_enable_single_generation @@ -151,6 +148,8 @@ v8_flag(name = "v8_enable_verify_predictable") v8_flag(name = "v8_enable_test_features") +v8_flag(name = "v8_wasm_random_fuzzers") + v8_flag( name = "v8_enable_maglev", default = True, @@ -208,6 +207,49 @@ v8_flag( default = True, ) +v8_flag( + name = "v8_enable_drumbrake", + default = False, +) + +v8_flag( + name = "v8_enable_drumbrake_tracing", + default = False, +) + +selects.config_setting_group( + name = "enable_drumbrake_x64", + match_all = [ + ":is_v8_enable_drumbrake", + "@v8//bazel/config:v8_target_x64", + ], +) + +selects.config_setting_group( + name = "enable_drumbrake_arm64", + match_all = [ + ":is_v8_enable_drumbrake", + "@v8//bazel/config:v8_target_arm64", + ], +) + +selects.config_setting_group( + name = "is_drumbrake_trap_handling_platform", + match_any = [ + "@v8//bazel/config:is_linux", + "@v8//bazel/config:is_macos", + "@v8//bazel/config:is_windows", + ], +) + +selects.config_setting_group( + name = "v8_drumbrake_bounds_checks", + match_all = [ + ":enable_drumbrake_x64", + ":is_drumbrake_trap_handling_platform", + ], +) + v8_flag( name = "v8_jitless", default = False, @@ -286,10 +328,10 @@ selects.config_setting_group( ], ) -# Enable isolated cage if v8_enable_pointer_compression and +# Enable multiple cages if v8_enable_pointer_compression and # NOT v8_enable_pointer_compression_shared_cage. selects.config_setting_group( - name = "enable_pointer_compression_isolated_cage", + name = "enable_pointer_compression_multiple_cages", match_all = [ ":is_v8_enable_pointer_compression", ":is_not_v8_enable_pointer_compression_shared_cage", @@ -411,6 +453,8 @@ v8_config( "v8_enable_verify_heap": "VERIFY_HEAP", "v8_enable_verify_predictable": "VERIFY_PREDICTABLE", "v8_enable_webassembly": "V8_ENABLE_WEBASSEMBLY", + "v8_enable_drumbrake": "V8_ENABLE_DRUMBRAKE", + "v8_enable_drumbrake_tracing": "V8_ENABLE_DRUMBRAKE_TRACING", "v8_jitless": "V8_JITLESS", "v8_enable_vtunejit": "ENABLE_VTUNE_JIT_INTERFACE", }, @@ -438,8 +482,7 @@ v8_config( ], "@v8//bazel/config:v8_target_arm64": ["V8_TARGET_ARCH_ARM64"], "@v8//bazel/config:v8_target_s390x": [ - "V8_TARGET_ARCH_S390", - "V8_TARGET_ARCH_S390X", + "V8_TARGET_ARCH_S390X" ], "@v8//bazel/config:v8_target_riscv64": [ # NOTE: Bazel rules for riscv64 weren't tested on a real system. @@ -448,8 +491,7 @@ v8_config( ], "@v8//bazel/config:v8_target_ppc64le": [ # NOTE: Bazel rules for ppc64le weren't tested on a real system. - "V8_TARGET_ARCH_PPC64", - "V8_TARGET_ARCH_PPC_LE", + "V8_TARGET_ARCH_PPC64" ], }, no_match_error = "Please specify a target cpu supported by v8", @@ -484,8 +526,8 @@ v8_config( ":enable_pointer_compression_shared_cage": [ "V8_COMPRESS_POINTERS_IN_SHARED_CAGE", ], - ":enable_pointer_compression_isolated_cage": [ - "V8_COMPRESS_POINTERS_IN_ISOLATE_CAGE", + ":enable_pointer_compression_multiple_cages": [ + "V8_COMPRESS_POINTERS_IN_MULTIPLE_CAGES", ], "//conditions:default": [], }) + select({ @@ -518,7 +560,13 @@ v8_config( "V8_ENABLE_DOUBLE_CONST_STORE_CHECK", ], "//conditions:default": [], + }) + select({ + "v8_drumbrake_bounds_checks": [ + "V8_DRUMBRAKE_BOUNDS_CHECKS" + ], + "//conditions:default": [], }), + deps = [":default"], ) @@ -757,7 +805,6 @@ filegroup( "src/base/numbers/strtod.h", "src/base/once.cc", "src/base/once.h", - "src/base/optional.h", "src/base/overflowing-math.h", "src/base/page-allocator.cc", "src/base/page-allocator.h", @@ -791,7 +838,7 @@ filegroup( "src/base/strings.h", "src/base/sys-info.cc", "src/base/sys-info.h", - "src/base/template-meta-programming/algorithm.h", + "src/base/template-meta-programming/common.h", "src/base/template-meta-programming/functional.h", "src/base/template-meta-programming/list.h", "src/base/template-meta-programming/string-literal.h", @@ -1268,6 +1315,7 @@ filegroup( "src/builtins/builtins.cc", "src/builtins/builtins-inl.h", "src/builtins/builtins.h", + "src/builtins/builtins-abstract-module-source.cc", "src/builtins/builtins-api.cc", "src/builtins/builtins-array.cc", "src/builtins/builtins-arraybuffer.cc", @@ -1402,6 +1450,8 @@ filegroup( "src/common/ptr-compr.cc", "src/common/ptr-compr.h", "src/common/ptr-compr-inl.h", + "src/common/segmented-table.h", + "src/common/segmented-table-inl.h", "src/common/simd128.h", "src/compiler-dispatcher/lazy-compile-dispatcher.cc", "src/compiler-dispatcher/lazy-compile-dispatcher.h", @@ -1625,6 +1675,9 @@ filegroup( "src/heap/heap-controller.cc", "src/heap/heap-controller.h", "src/heap/heap-inl.h", + "src/heap/heap-layout.cc", + "src/heap/heap-layout.h", + "src/heap/heap-layout-inl.h", "src/heap/heap-layout-tracer.cc", "src/heap/heap-layout-tracer.h", "src/heap/heap-verifier.cc", @@ -1646,6 +1699,8 @@ filegroup( "src/heap/large-spaces.h", "src/heap/linear-allocation-area.h", "src/heap/list.h", + "src/heap/live-object-range.h", + "src/heap/live-object-range-inl.h", "src/heap/local-factory.cc", "src/heap/local-factory.h", "src/heap/local-factory-inl.h", @@ -1741,8 +1796,6 @@ filegroup( "src/heap/stress-scavenge-observer.h", "src/heap/sweeper.cc", "src/heap/sweeper.h", - "src/heap/third-party/heap-api.h", - "src/heap/third-party/heap-api-stub.cc", "src/heap/traced-handles-marking-visitor.cc", "src/heap/traced-handles-marking-visitor.h", "src/heap/weak-object-worklists.cc", @@ -2284,6 +2337,7 @@ filegroup( "src/runtime/runtime-test.cc", "src/runtime/runtime-trace.cc", "src/runtime/runtime-typedarray.cc", + "src/runtime/runtime-utils.cc", "src/runtime/runtime-utils.h", "src/runtime/runtime-weak-refs.cc", "src/sandbox/bounded-size.h", @@ -2505,6 +2559,8 @@ filegroup( "src/codegen/x64/assembler-x64.cc", "src/codegen/x64/assembler-x64.h", "src/codegen/x64/assembler-x64-inl.h", + "src/codegen/x64/builtin-jump-table-info-x64.cc", + "src/codegen/x64/builtin-jump-table-info-x64.h", "src/codegen/x64/constants-x64.h", "src/codegen/x64/cpu-x64.cc", "src/codegen/x64/fma-instr.h", @@ -2827,7 +2883,6 @@ filegroup( "src/wasm/function-body-decoder-impl.h", "src/wasm/function-compiler.cc", "src/wasm/function-compiler.h", - "src/wasm/fuzzing/random-module-generation.cc", "src/wasm/fuzzing/random-module-generation.h", "src/wasm/graph-builder-interface.cc", "src/wasm/graph-builder-interface.h", @@ -2837,7 +2892,6 @@ filegroup( "src/wasm/leb-helper.h", "src/wasm/local-decl-encoder.cc", "src/wasm/local-decl-encoder.h", - "src/wasm/memory-tracing.cc", "src/wasm/memory-tracing.h", "src/wasm/module-compiler.cc", "src/wasm/module-compiler.h", @@ -2872,6 +2926,9 @@ filegroup( "src/wasm/wasm-builtin-list.h", "src/wasm/wasm-code-manager.cc", "src/wasm/wasm-code-manager.h", + "src/wasm/wasm-code-pointer-table.cc", + "src/wasm/wasm-code-pointer-table.h", + "src/wasm/wasm-code-pointer-table-inl.h", "src/wasm/wasm-debug.cc", "src/wasm/wasm-debug.h", "src/wasm/wasm-deopt-data.cc", @@ -2916,6 +2973,26 @@ filegroup( "src/wasm/wrappers.cc", ], "//conditions:default": [], + }) + select({ + ":is_v8_enable_drumbrake": [ + "src/wasm/interpreter/instruction-handlers.h", + "src/wasm/interpreter/wasm-interpreter.cc", + "src/wasm/interpreter/wasm-interpreter.h", + "src/wasm/interpreter/wasm-interpreter-inl.h", + "src/wasm/interpreter/wasm-interpreter-objects.cc", + "src/wasm/interpreter/wasm-interpreter-objects-inl.h", + "src/wasm/interpreter/wasm-interpreter-objects.h", + "src/wasm/interpreter/wasm-interpreter-runtime.cc", + "src/wasm/interpreter/wasm-interpreter-runtime-inl.h", + "src/wasm/interpreter/wasm-interpreter-runtime.h", + "src/wasm/interpreter/wasm-interpreter-simd.cc", + ], + "//conditions:default": [], + }) + select({ + ":is_v8_wasm_random_fuzzers": [ + "src/wasm/fuzzing/random-module-generation.cc", + ], + "//conditions:default": [], }), ) @@ -3215,6 +3292,8 @@ filegroup( "src/compiler/turboshaft/build-graph-phase.cc", "src/compiler/turboshaft/build-graph-phase.h", "src/compiler/turboshaft/builtin-call-descriptors.h", + "src/compiler/turboshaft/builtin-compiler.cc", + "src/compiler/turboshaft/builtin-compiler.h", "src/compiler/turboshaft/csa-optimize-phase.cc", "src/compiler/turboshaft/csa-optimize-phase.h", "src/compiler/turboshaft/dataview-lowering-reducer.h", @@ -3236,6 +3315,7 @@ filegroup( "src/compiler/turboshaft/explicit-truncation-reducer.h", "src/compiler/turboshaft/fast-api-call-lowering-reducer.h", "src/compiler/turboshaft/fast-hash.h", + "src/compiler/turboshaft/field-macro.inc", "src/compiler/turboshaft/graph.cc", "src/compiler/turboshaft/graph.h", "src/compiler/turboshaft/graph-builder.cc", @@ -3296,9 +3376,6 @@ filegroup( "src/compiler/turboshaft/select-lowering-reducer.h", "src/compiler/turboshaft/sidetable.cc", "src/compiler/turboshaft/sidetable.h", - "src/compiler/turboshaft/simplified-lowering-phase.cc", - "src/compiler/turboshaft/simplified-lowering-phase.h", - "src/compiler/turboshaft/simplified-lowering-reducer.h", "src/compiler/turboshaft/simplify-tf-loops.cc", "src/compiler/turboshaft/simplify-tf-loops.h", "src/compiler/turboshaft/snapshot-table.h", @@ -3307,6 +3384,7 @@ filegroup( "src/compiler/turboshaft/store-store-elimination-phase.cc", "src/compiler/turboshaft/store-store-elimination-phase.h", "src/compiler/turboshaft/store-store-elimination-reducer-inl.h", + "src/compiler/turboshaft/string-view.h", "src/compiler/turboshaft/structural-optimization-reducer.h", "src/compiler/turboshaft/tracing.h", "src/compiler/turboshaft/type-assertions-phase.cc", @@ -3416,6 +3494,9 @@ filegroup( "src/compiler/turboshaft/wasm-gc-typed-optimization-reducer.cc", "src/compiler/turboshaft/wasm-gc-typed-optimization-reducer.h", "src/compiler/turboshaft/wasm-load-elimination-reducer.h", + "src/compiler/turboshaft/wasm-in-js-inlining-phase.cc", + "src/compiler/turboshaft/wasm-in-js-inlining-phase.h", + "src/compiler/turboshaft/wasm-in-js-inlining-reducer-inl.h", "src/compiler/turboshaft/wasm-lowering-phase.cc", "src/compiler/turboshaft/wasm-lowering-phase.h", "src/compiler/turboshaft/wasm-lowering-reducer.h", @@ -3520,6 +3601,7 @@ filegroup( "src/builtins/builtins-lazy-gen.h", "src/builtins/builtins-microtask-queue-gen.cc", "src/builtins/builtins-number-gen.cc", + "src/builtins/builtins-number-tsa.cc", "src/builtins/builtins-object-gen.cc", "src/builtins/builtins-object-gen.h", "src/builtins/builtins-promise-gen.cc", @@ -3539,6 +3621,7 @@ filegroup( "src/builtins/builtins-utils-gen.h", "src/builtins/growable-fixed-array-gen.cc", "src/builtins/growable-fixed-array-gen.h", + "src/builtins/number-builtins-reducer-inl.h", "src/builtins/profile-data-reader.cc", "src/builtins/profile-data-reader.h", "src/builtins/setup-builtins-internal.cc", @@ -3548,6 +3631,8 @@ filegroup( "third_party/v8/codegen/fp16-inl.h", "src/codegen/code-stub-assembler-inl.h", "src/codegen/code-stub-assembler.h", + "src/codegen/define-code-stub-assembler-macros.inc", + "src/codegen/undef-code-stub-assembler-macros.inc", "src/heap/setup-heap-internal.cc", "src/ic/accessor-assembler.cc", "src/ic/accessor-assembler.h", @@ -3561,6 +3646,8 @@ filegroup( "src/interpreter/interpreter-assembler.h", "src/interpreter/interpreter-generator.cc", "src/interpreter/interpreter-generator.h", + "src/interpreter/interpreter-generator-tsa.cc", + "src/interpreter/interpreter-generator-tsa.h", "src/interpreter/interpreter-intrinsics-generator.cc", "src/interpreter/interpreter-intrinsics-generator.h", "src/numbers/integer-literal.h", @@ -3579,6 +3666,14 @@ filegroup( "src/builtins/builtins-wasm-gen.h", ], "//conditions:default": [], + }) + select({ + ":enable_drumbrake_x64": [ + "src/wasm/interpreter/x64/interpreter-builtins-x64.cc" + ], + ":enable_drumbrake_arm64": [ + "src/wasm/interpreter/arm64/interpreter-builtins-arm64.cc" + ], + "//conditions:default": [], }), ) @@ -3720,6 +3815,25 @@ filegroup( }), ) +v8_library( + name = "lib_fast_float", + srcs = [ + "third_party/fast_float/src/include/fast_float/ascii_number.h", + "third_party/fast_float/src/include/fast_float/bigint.h", + "third_party/fast_float/src/include/fast_float/constexpr_feature_detect.h", + "third_party/fast_float/src/include/fast_float/decimal_to_binary.h", + "third_party/fast_float/src/include/fast_float/digit_comparison.h", + "third_party/fast_float/src/include/fast_float/fast_float.h", + "third_party/fast_float/src/include/fast_float/fast_table.h", + "third_party/fast_float/src/include/fast_float/float_common.h", + "third_party/fast_float/src/include/fast_float/parse_number.h", + ], + hdrs = [ "third_party/fast_float/src/include/fast_float/fast_float.h" ], + includes = [ + "third_party/fast_float/src/include", + ], +) + v8_library( name = "lib_fp16", srcs = ["third_party/fp16/src/include/fp16.h"], @@ -4223,6 +4337,7 @@ v8_library( ":noicu/generated_torque_definitions", ], deps = [ + ":lib_fast_float", ":lib_fp16", ":v8_libbase", "//external:absl_btree", diff --git a/deps/v8/BUILD.gn b/deps/v8/BUILD.gn index 92e85419..e1396b2d 100644 --- a/deps/v8/BUILD.gn +++ b/deps/v8/BUILD.gn @@ -11,6 +11,7 @@ import("//build/config/mips.gni") import("//build/config/riscv.gni") import("//build/config/sanitizers/sanitizers.gni") import("//build_overrides/build.gni") +import("//third_party/icu/config.gni") import("gni/snapshot_toolchain.gni") import("gni/v8.gni") @@ -61,7 +62,7 @@ declare_args() { # Allows the embedder to add a custom suffix to the version string. v8_embedder_string = "" - # Sets -dENABLE_DISASSEMBLER. + # Sets -DENABLE_DISASSEMBLER. v8_enable_disassembler = "" # Sets the number of internal fields on promise objects. @@ -73,19 +74,19 @@ declare_args() { # Sets the number of internal fields on array buffer view objects. v8_array_buffer_view_internal_field_count = 0 - # Sets -dENABLE_GDB_JIT_INTERFACE. + # Sets -DENABLE_GDB_JIT_INTERFACE. v8_enable_gdbjit = "" - # Sets -dENABLE_VTUNE_JIT_INTERFACE. + # Sets -DENABLE_VTUNE_JIT_INTERFACE. v8_enable_vtunejit = false - # Sets -dENABLE_VTUNE_TRACEMARK. + # Sets -DENABLE_VTUNE_TRACEMARK. v8_enable_vtunetracemark = false - # Sets -dENABLE_HUGEPAGE + # Sets -DENABLE_HUGEPAGE v8_enable_hugepage = false - # Sets -dV8_ENABLE_PRIVATE_MAPPING_FORK_OPTIMIZATION. + # Sets -DV8_ENABLE_PRIVATE_MAPPING_FORK_OPTIMIZATION. # # This flag speeds up the performance of fork/execve on Linux systems for # embedders which use it (like Node.js). It works by marking the pages that @@ -96,7 +97,7 @@ declare_args() { # See v8:7381 for more details. v8_enable_private_mapping_fork_optimization = false - # Sets -dENABLE_HANDLE_ZAPPING. + # Sets -DENABLE_HANDLE_ZAPPING. v8_enable_handle_zapping = is_asan || is_debug # Enable slow dchecks. @@ -117,16 +118,16 @@ declare_args() { # Allow runtime-enabled code comments (with --code-comments). Enabled by # default in debug builds. - # Sets -dV8_CODE_COMMENTS + # Sets -DV8_CODE_COMMENTS v8_code_comments = "" # Allow runtime-enabled debug code (with --debug-code). Enabled by default in # debug builds. - # Sets -dV8_ENABLE_DEBUG_CODE + # Sets -DV8_ENABLE_DEBUG_CODE v8_enable_debug_code = "" # Enable native counters from the snapshot (impacts performance, sets - # -dV8_SNAPSHOT_NATIVE_CODE_COUNTERS). + # -DV8_SNAPSHOT_NATIVE_CODE_COUNTERS). # This option will generate extra code in the snapshot to increment counters, # as per the --native-code-counters flag. v8_enable_snapshot_native_code_counters = "" @@ -141,29 +142,24 @@ declare_args() { # Enable code-generation-time checking of types in the CodeStubAssembler. v8_enable_verify_csa = false - # Enable pointer compression (sets -dV8_COMPRESS_POINTERS). - v8_enable_pointer_compression = "" - v8_enable_pointer_compression_shared_cage = "" - v8_enable_31bit_smis_on_64bit_arch = false - - # Sets -dOBJECT_PRINT. + # Sets -DOBJECT_PRINT. v8_enable_object_print = "" - # Sets -dV8_TRACE_MAPS. + # Sets -DV8_TRACE_MAPS. v8_enable_trace_maps = "" - # Sets -dV8_ENABLE_CHECKS. + # Sets -DV8_ENABLE_CHECKS. v8_enable_v8_checks = "" - # Sets -dV8_TRACE_UNOPTIMIZED. + # Sets -DV8_TRACE_UNOPTIMIZED. v8_enable_trace_unoptimized = "" v8_enable_trace_ignition = false v8_enable_trace_baseline_exec = false - # Sets -dV8_TRACE_FEEDBACK_UPDATES. + # Sets -DV8_TRACE_FEEDBACK_UPDATES. v8_enable_trace_feedback_updates = false - # Sets -dV8_ATOMIC_OBJECT_FIELD_WRITES and turns all field write operations + # Sets -DV8_ATOMIC_OBJECT_FIELD_WRITES and turns all field write operations # into relaxed atomic operations. v8_enable_atomic_object_field_writes = "" @@ -171,7 +167,7 @@ declare_args() { # default setting code below. v8_enable_concurrent_marking = true - # Sets -dV8_IGNITION_DISPATCH_COUNTING. + # Sets -DV8_IGNITION_DISPATCH_COUNTING. # Enables counting frequencies of bytecode dispatches. After building in this # configuration, subsequent runs of d8 can output frequencies for each pair # of (current, next) bytecode instructions executed if you specify @@ -223,12 +219,12 @@ declare_args() { v8_enable_test_features = "" # Enable short builtins call instruction sequences by un-embedding builtins. - # Sets -dV8_SHORT_BUILTIN_CALLS + # Sets -DV8_SHORT_BUILTIN_CALLS v8_enable_short_builtin_calls = "" # Enable support for external code range relative to the pointer compression # cage. - # Sets -dV8_EXTERNAL_CODE_SPACE + # Sets -DV8_EXTERNAL_CODE_SPACE v8_enable_external_code_space = "" # With post mortem support enabled, metadata is embedded into libv8 that @@ -270,15 +266,6 @@ declare_args() { # Enable lazy source positions by default. v8_enable_lazy_source_positions = true - # Enable third party HEAP library - v8_enable_third_party_heap = false - - # Libaries used by third party heap - v8_third_party_heap_libs = [] - - # Source code used by third party heap - v8_third_party_heap_files = [] - # Disable write barriers when GCs are non-incremental and # heap has single generation. v8_disable_write_barriers = false @@ -320,6 +307,9 @@ declare_args() { v8_current_cpu == "arm64" && (target_is_simulator || arm_control_flow_integrity != "none") + # A temporary flag for development of the WasmCodePointerTable. + v8_enable_wasm_code_pointer_table = false + # Enable heap reservation of size 4GB. Only possible for 64bit archs. cppgc_enable_caged_heap = v8_current_cpu == "x64" || v8_current_cpu == "arm64" || @@ -339,6 +329,9 @@ declare_args() { # Sets -DV8_ENABLE_SANDBOX. v8_enable_sandbox = "" + # Explicitly disable leaptiering (on builds where it would otherwise be enabled). + v8_disable_leaptiering = "" + # Enable the memory corruption API. Useful for testing the sandbox. # The memory corruption API is only exposed to JavaScript if sandbox testing # mode is enabled at runtime, for example via --sandbox-fuzzing. @@ -364,7 +357,7 @@ declare_args() { # Sets -DV8_DICT_PROPERTY_CONST_TRACKING v8_dict_property_const_tracking = false - # Enable map packing & unpacking (sets -dV8_MAP_PACKING). + # Enable map packing & unpacking (sets -DV8_MAP_PACKING). v8_enable_map_packing = false # Allow for JS promise hooks (instead of just C++). @@ -375,7 +368,7 @@ declare_args() { # The flag enables disabling the feature, to test this data's overhead. v8_enable_continuation_preserved_embedder_data = true - # Enable allocation folding globally (sets -dV8_ALLOCATION_FOLDING). + # Enable allocation folding globally (sets -DV8_ALLOCATION_FOLDING). # When it's disabled, the --turbo-allocation-folding runtime flag will be ignored. v8_enable_allocation_folding = true @@ -391,6 +384,19 @@ declare_args() { # This is only used by nodejs. v8_scriptormodule_legacy_lifetime = false + # WebAssembly interpreter (DrumBrake) build flag. + v8_enable_drumbrake = false + + # Enable Wasm interpreter tracing. + v8_enable_drumbrake_tracing = false + + # On non-Desktop platforms, enable explicit bounds checks in the Wasm + # interpreter, where the bounds checking is done in the instruction handler, + # not using an unhandled exception filter (which also doesn't work with Win-ASAN). + v8_drumbrake_bounds_checks = + (is_win && (is_asan || is_ubsan || is_msan || is_tsan)) || + !(is_win || is_linux || is_mac) || v8_current_cpu != "x64" + # Enables pointer compression for 8GB heaps. # Sets -DV8_COMPRESS_POINTERS_8GB. v8_enable_pointer_compression_8gb = "" @@ -429,6 +435,12 @@ declare_args() { # ReadOnlySpace. v8_enable_extensible_ro_snapshot = true + # Enable Turboshaft CSA pipeline. + v8_enable_turboshaft_csa = false + + # Black allocate objects on separate pages. + v8_enable_black_allocated_pages = "" + # Use sticky mark-bits for separating object generations. v8_enable_sticky_mark_bits = false @@ -436,6 +448,16 @@ declare_args() { v8_enable_experimental_tsa_builtins = false v8_dcheck_always_on = dcheck_always_on + + # Remote builds require an explicit dependency on icudat, but + # this breaks locally building V8 with ICU support when the file + # isn't present, which some embedders rely on. This option controls + # the explicit dependency and allows the build to complete. + v8_depend_on_icu_data_file = icu_use_data_file + + # Some fuzzers depend on fuzzing functionality linked into the v8 library. + # For binary size reasons this functionality is not always available. + v8_wasm_random_fuzzers = "" } # Derived defaults. @@ -477,9 +499,14 @@ if (v8_enable_debug_code == "") { if (v8_enable_snapshot_native_code_counters == "") { v8_enable_snapshot_native_code_counters = v8_enable_debugging_features } -if (v8_enable_pointer_compression == "") { - v8_enable_pointer_compression = - v8_current_cpu == "arm64" || v8_current_cpu == "x64" + +if (v8_enable_drumbrake && v8_enable_webassembly) { + assert( + is_drumbrake_supported, + "DrumBrake is only available on x64, arm64 on Windows, Linux and MacOS.") +} +if (v8_enable_black_allocated_pages == "") { + v8_enable_black_allocated_pages = !v8_enable_sticky_mark_bits } # Toggle pointer compression for correctness fuzzing when building the @@ -539,14 +566,6 @@ if (v8_enable_single_generation == "") { if (v8_enable_atomic_object_field_writes == "") { v8_enable_atomic_object_field_writes = v8_enable_concurrent_marking } -if (v8_enable_third_party_heap) { - v8_disable_write_barriers = true - v8_enable_single_generation = true - v8_enable_shared_ro_heap = false - v8_enable_pointer_compression = false - v8_enable_pointer_compression_shared_cage = false - v8_enable_allocation_folding = false -} if (v8_enable_single_generation) { v8_allocation_site_tracking = false } @@ -573,8 +592,7 @@ if (v8_enable_short_builtin_calls && v8_enable_short_builtin_calls = false } if (v8_enable_shared_ro_heap == "") { - v8_enable_shared_ro_heap = !v8_enable_pointer_compression || - v8_enable_pointer_compression_shared_cage + v8_enable_shared_ro_heap = true } if (v8_enable_sandbox == "") { @@ -586,6 +604,10 @@ if (v8_enable_sandbox == "") { v8_enable_external_code_space && target_os != "fuchsia" } +if (v8_disable_leaptiering == "") { + v8_disable_leaptiering = false +} + if (v8_enable_static_roots == "") { # Static roots are only valid for builds with pointer compression and a # shared read-only heap. @@ -664,13 +686,6 @@ assert(!v8_disable_write_barriers || v8_enable_single_generation, assert(v8_current_cpu == "arm64" || !v8_control_flow_integrity, "Control-flow integrity is only supported on arm64") -if (v8_enable_shared_ro_heap && v8_enable_pointer_compression && - !v8_enable_pointer_compression_shared_cage) { - assert( - is_linux || is_chromeos || is_android, - "Sharing read-only heap with pointer compression is only supported on Linux or Android") -} - assert(!v8_enable_map_packing || !v8_enable_pointer_compression, "Map packing does not support pointer compression") @@ -689,9 +704,6 @@ assert(!v8_enable_sandbox || v8_enable_pointer_compression_shared_cage, assert(!v8_enable_sandbox || v8_enable_external_code_space, "The sandbox requires the external code space") -assert(!v8_enable_sandbox || !v8_enable_third_party_heap, - "The sandbox is incompatible with the third-party heap") - assert(!v8_enable_memory_corruption_api || v8_enable_sandbox, "The Memory Corruption API requires the sandbox") @@ -729,10 +741,30 @@ if (v8_enable_single_generation == true) { assert(!v8_enable_snapshot_compression || v8_use_zlib, "Snapshot compression requires zlib") +assert(!v8_enable_cet_shadow_stack || + (v8_target_cpu == "x64" && target_os == "win"), + "CET shadow stack is supported only on x64 Windows") + +if (v8_enable_sticky_mark_bits) { + # To support sticky mark bits, pretenured allocations must be allocated from + # a separate free-list and the atomic pause (or the sweeper) must fix up the + # mark bits. + assert(!v8_enable_black_allocated_pages, + "Black allocated pages are not yet supported with sticky mark bits") +} + if (v8_expose_public_symbols == "") { v8_expose_public_symbols = v8_expose_symbols } +# Some fuzzers depend on fuzzing functionality linked into the v8 library. +# For binary size reasons this functionality is not available for official +# builds, therefore these fuzzers do not function there and should be skipped +# instead. +if (v8_wasm_random_fuzzers == "") { + v8_wasm_random_fuzzers = !is_official_build +} + v8_random_seed = "314159265" v8_toolset_for_shell = "host" @@ -886,7 +918,7 @@ external_v8_defines = [ "V8_MAP_PACKING", "V8_IS_TSAN", "V8_ENABLE_CONSERVATIVE_STACK_SCANNING", - "V8_ENABLE_DIRECT_LOCAL", + "V8_ENABLE_DIRECT_HANDLE", "V8_MINORMS_STRING_SHORTCUTTING", "V8_HAVE_TARGET_OS", "V8_TARGET_OS_ANDROID", @@ -940,8 +972,8 @@ if (is_tsan) { if (v8_enable_conservative_stack_scanning) { enabled_external_v8_defines += [ "V8_ENABLE_CONSERVATIVE_STACK_SCANNING" ] } -if (v8_enable_direct_local) { - enabled_external_v8_defines += [ "V8_ENABLE_DIRECT_LOCAL" ] +if (v8_enable_direct_handle) { + enabled_external_v8_defines += [ "V8_ENABLE_DIRECT_HANDLE" ] } if (v8_shortcut_strings_in_minor_ms) { enabled_external_v8_defines += [ "V8_MINORMS_STRING_SHORTCUTTING" ] @@ -1153,9 +1185,6 @@ config("features") { if (v8_disable_write_barriers) { defines += [ "V8_DISABLE_WRITE_BARRIERS" ] } - if (v8_enable_third_party_heap) { - defines += [ "V8_ENABLE_THIRD_PARTY_HEAP" ] - } if (v8_use_external_startup_data) { defines += [ "V8_USE_EXTERNAL_STARTUP_DATA" ] } @@ -1192,6 +1221,12 @@ config("features") { if (v8_enable_cet_ibt) { defines += [ "V8_ENABLE_CET_IBT" ] } + if (v8_enable_memory_sealing) { + defines += [ "V8_ENABLE_MEMORY_SEALING" ] + } + if (v8_enable_wasm_code_pointer_table) { + defines += [ "V8_ENABLE_WASM_CODE_POINTER_TABLE" ] + } if (v8_enable_wasm_gdb_remote_debugging) { defines += [ "V8_ENABLE_WASM_GDB_REMOTE_DEBUGGING" ] } @@ -1258,6 +1293,15 @@ config("features") { if (v8_advanced_bigint_algorithms) { defines += [ "V8_ADVANCED_BIGINT_ALGORITHMS" ] } + if (v8_enable_drumbrake) { + defines += [ "V8_ENABLE_DRUMBRAKE" ] + if (v8_enable_drumbrake_tracing) { + defines += [ "V8_ENABLE_DRUMBRAKE_TRACING" ] + } + if (v8_drumbrake_bounds_checks) { + defines += [ "V8_DRUMBRAKE_BOUNDS_CHECKS" ] + } + } if (v8_enable_memory_corruption_api) { defines += [ "V8_ENABLE_MEMORY_CORRUPTION_API" ] } @@ -1291,21 +1335,27 @@ config("features") { if (v8_enable_builtin_jump_table_switch) { defines += [ "V8_ENABLE_BUILTIN_JUMP_TABLE_SWITCH" ] } - if (v8_enable_direct_handle) { - defines += [ "V8_ENABLE_DIRECT_HANDLE" ] - } if (v8_enable_extensible_ro_snapshot) { defines += [ "V8_ENABLE_EXTENSIBLE_RO_SNAPSHOT" ] } if (v8_enable_local_off_stack_check) { defines += [ "V8_ENABLE_LOCAL_OFF_STACK_CHECK" ] } + if (v8_enable_black_allocated_pages) { + defines += [ "V8_ENABLE_BLACK_ALLOCATED_PAGES" ] + } if (v8_enable_sticky_mark_bits) { defines += [ "V8_ENABLE_STICKY_MARK_BITS" ] } if (v8_enable_experimental_tsa_builtins) { defines += [ "V8_ENABLE_EXPERIMENTAL_TSA_BUILTINS" ] } + if (v8_disable_leaptiering) { + defines += [ "V8_DISABLE_LEAPTIERING" ] + } + if (v8_wasm_random_fuzzers) { + defines += [ "V8_WASM_RANDOM_FUZZERS" ] + } } config("toolchain") { @@ -1396,39 +1446,27 @@ config("toolchain") { defines += [ "V8_TARGET_ARCH_LOONG64" ] } - if (v8_current_cpu == "s390" || v8_current_cpu == "s390x") { - defines += [ "V8_TARGET_ARCH_S390" ] + if (v8_current_cpu == "s390x") { cflags += [ "-ffp-contract=off" ] - if (v8_current_cpu == "s390x") { - defines += [ "V8_TARGET_ARCH_S390X" ] - } + defines += [ "V8_TARGET_ARCH_S390X" ] if (host_byteorder == "little") { - defines += [ "V8_TARGET_ARCH_S390_LE_SIM" ] + defines += [ "V8_TARGET_ARCH_S390X_LE_SIM" ] } else if (current_os != "zos") { cflags += [ "-march=z196" ] } } - if (v8_current_cpu == "ppc" || v8_current_cpu == "ppc64") { - if (v8_current_cpu == "ppc") { - defines += [ "V8_TARGET_ARCH_PPC" ] - } else if (v8_current_cpu == "ppc64") { - defines += [ "V8_TARGET_ARCH_PPC64" ] - cflags += [ "-ffp-contract=off" ] - } - if (host_byteorder == "little") { - defines += [ "V8_TARGET_ARCH_PPC_LE" ] - } else if (host_byteorder == "big") { - defines += [ "V8_TARGET_ARCH_PPC_BE" ] - if (current_os == "aix") { - cflags += [ - # Work around AIX ceil, trunc and round oddities. - "-mcpu=power5+", - "-mfprnd", - - # Work around AIX assembler popcntb bug. - "-mno-popcntb", - ] - } + if (v8_current_cpu == "ppc64") { + defines += [ "V8_TARGET_ARCH_PPC64" ] + cflags += [ "-ffp-contract=off" ] + if (current_os == "aix") { + cflags += [ + # Work around AIX ceil, trunc and round oddities. + "-mcpu=power5+", + "-mfprnd", + + # Work around AIX assembler popcntb bug. + "-mno-popcntb", + ] } } @@ -1445,6 +1483,9 @@ config("toolchain") { if (!is_clang) { cflags += [ "-ffp-contract=off" ] } + if (riscv_use_sv39) { + defines += [ "RISCV_USE_SV39" ] + } } if (v8_current_cpu == "riscv32") { @@ -2415,11 +2456,25 @@ template("run_mksnapshot") { } action("run_mksnapshot_" + name) { deps = [ ":mksnapshot($v8_snapshot_toolchain)" ] + if (v8_verify_deterministic_mksnapshot) { + # We archive the snapshot executable when verifying snapshot + # determinism to ease debugging. + data_deps = [ ":mksnapshot($v8_snapshot_toolchain)" ] + } script = "tools/run.py" sources = [] + if (v8_depend_on_icu_data_file) { + deps += [ "//third_party/icu:copy_icudata" ] + if (host_byteorder == "big") { + sources += [ "$root_out_dir/icudtb.dat" ] + } else { + sources += [ "$root_out_dir/icudtl.dat" ] + } + } + outputs = [] data = [] @@ -2430,7 +2485,20 @@ template("run_mksnapshot") { ext = "s" } - args = [ + args = [] + + if (v8_verify_deterministic_mksnapshot) { + # Output redirection must be the first argument to run.py. We capture + # output when verifying snapshot determinism for debugging. + args += [ + "--redirect-stdout", + rebase_path("$root_out_dir/mksnapshot_output${suffix}.log", + root_build_dir), + ] + data += [ "$root_out_dir/mksnapshot_output${suffix}.log" ] + } + + args += [ "./" + rebase_path(get_label_info(":mksnapshot($v8_snapshot_toolchain)", "root_out_dir") + "/mksnapshot", root_build_dir), @@ -2446,8 +2514,25 @@ template("run_mksnapshot") { "--embedded_src", rebase_path("$target_gen_dir/embedded${suffix}.${ext}", root_build_dir), + + # mksnapshot runs in predictable mode to create deterministic snapshots. + # Note this flag is also set implicitly by mksnapshot itself (see + # mksnapshot.cc). We set it here as well for clarity. + "--predictable", + + # Disable ICs globally in mksnapshot to avoid problems with Code handlers. + # See https://crbug.com/345280736. + # TODO(jgruber): Re-enable once a better fix is available. + # Note this flag is also set implicitly by mksnapshot itself (see + # mksnapshot.cc). We set it here as well for clarity. + "--no-use-ic", ] + if (v8_verify_deterministic_mksnapshot) { + # Flags that help debugging snapshot determinism. + args += [ "--trace-read-only-promotion" ] + } + if (v8_log_builtins_block_count_input != "") { args += [ "--trace-turbo", @@ -2479,6 +2564,10 @@ template("run_mksnapshot") { } } + if (v8_enable_turboshaft_csa) { + args += [ "--turboshaft-csa" ] + } + # This is needed to distinguish between generating code for the simulator # and cross-compiling. The latter may need to run code on the host with the # simulator but cannot use simulator-specific instructions. @@ -2589,11 +2678,15 @@ if (v8_verify_deterministic_mksnapshot) { } } - action("verify_deterministic_mksnapshot") { - deps = [] + group("snapshot_set") { + data_deps = [] foreach(i, runs) { - deps += [ ":run_mksnapshot_$i" ] + data_deps += [ ":run_mksnapshot_$i" ] } + } + + action("verify_deterministic_mksnapshot") { + deps = [ ":snapshot_set" ] report_file = "$target_gen_dir/mksnapshot_comparison.txt" script = "tools/snapshot/compare_mksnapshot_output.py" args = [ @@ -2682,17 +2775,18 @@ action("v8_dump_build_config") { mips_use_msa_var = mips_use_msa } - js_shared_memory = - v8_enable_shared_ro_heap && (!v8_enable_pointer_compression || - v8_enable_pointer_compression_shared_cage) && - !v8_disable_write_barriers + js_shared_memory = v8_enable_shared_ro_heap && !v8_disable_write_barriers simd_mips = mips_arch_variant_var == "r6" && mips_use_msa simulator_run = target_cpu != v8_target_cpu use_sanitizer = is_asan || is_cfi || is_msan || is_tsan || is_ubsan + use_leaptiering = v8_enable_sandbox && !v8_disable_leaptiering + # This lists all build-time switches consumed by the test framework. All # switches can be used automatically in the status files as is - no # further files need to be modified. + # However, the switch also has to be entered in `build_config_content` in + # `bazel/defs.bzl` so that the switch also works for tests triggered by bazel. # # Naming conventions: Keep switch names short and remove unnecessary # qualifiers. Drop v8_enable_, v8_, is_ where possible. @@ -2720,7 +2814,6 @@ action("v8_dump_build_config") { "debugging_features=$v8_enable_debugging_features", "dict_property_const_tracking=$v8_dict_property_const_tracking", "direct_handle=$v8_enable_direct_handle", - "direct_local=$v8_enable_direct_local", "disassembler=$v8_enable_disassembler", "full_debug=$is_full_debug", "gdbjit=$v8_enable_gdbjit", @@ -2728,6 +2821,7 @@ action("v8_dump_build_config") { "has_maglev=$v8_enable_maglev", "has_turbofan=$v8_enable_turbofan", "has_webassembly=$v8_enable_webassembly", + "has_wasm_interpreter=$v8_enable_drumbrake", "i18n=$v8_enable_i18n_support", "is_android=$is_android", "is_ios=$is_ios", @@ -2748,7 +2842,6 @@ action("v8_dump_build_config") { "single_generation=$v8_enable_single_generation", "slow_dchecks=$v8_enable_slow_dchecks", "target_cpu=\"$target_cpu\"", - "third_party_heap=$v8_enable_third_party_heap", "tsan=$is_tsan", "ubsan=$is_ubsan", "use_sanitizer=$use_sanitizer", @@ -2758,7 +2851,12 @@ action("v8_dump_build_config") { "verify_csa=$v8_enable_verify_csa", "verify_heap=$v8_enable_verify_heap", "verify_predictable=$v8_enable_verify_predictable", + "wasm_random_fuzzers=$v8_wasm_random_fuzzers", "memory_corruption_api=$v8_enable_memory_corruption_api", + "leaptiering=$use_leaptiering", + + # Please add new switches also in `build_config_content` in `bazel/defs.bzl` + # so that the switches also work for tests triggered by bazel. ] } @@ -2777,7 +2875,6 @@ generated_file("v8_generate_features_json") { v8_enable_conservative_stack_scanning = v8_enable_conservative_stack_scanning v8_enable_direct_handle = v8_enable_direct_handle - v8_enable_direct_local = v8_enable_direct_local v8_enable_extensible_ro_snapshot = v8_enable_extensible_ro_snapshot v8_enable_gdbjit = v8_enable_gdbjit v8_enable_hugepage = v8_enable_hugepage @@ -2907,6 +3004,7 @@ v8_source_set("v8_initializers") { "src/builtins/builtins-lazy-gen.h", "src/builtins/builtins-microtask-queue-gen.cc", "src/builtins/builtins-number-gen.cc", + "src/builtins/builtins-number-tsa.cc", "src/builtins/builtins-object-gen.cc", "src/builtins/builtins-object-gen.h", "src/builtins/builtins-promise-gen.cc", @@ -2926,6 +3024,7 @@ v8_source_set("v8_initializers") { "src/builtins/builtins-utils-gen.h", "src/builtins/growable-fixed-array-gen.cc", "src/builtins/growable-fixed-array-gen.h", + "src/builtins/number-builtins-reducer-inl.h", "src/builtins/profile-data-reader.cc", "src/builtins/profile-data-reader.h", "src/builtins/setup-builtins-internal.cc", @@ -2933,8 +3032,12 @@ v8_source_set("v8_initializers") { "src/codegen/code-stub-assembler-inl.h", "src/codegen/code-stub-assembler.cc", "src/codegen/code-stub-assembler.h", + "src/codegen/define-code-stub-assembler-macros.inc", "src/codegen/heap-object-list.h", "src/codegen/turboshaft-builtins-assembler-inl.h", + "src/codegen/undef-code-stub-assembler-macros.inc", + "src/compiler/turboshaft/builtin-compiler.cc", + "src/compiler/turboshaft/builtin-compiler.h", "src/heap/setup-heap-internal.cc", "src/ic/accessor-assembler.cc", "src/ic/accessor-assembler.h", @@ -2946,6 +3049,8 @@ v8_source_set("v8_initializers") { "src/ic/unary-op-assembler.h", "src/interpreter/interpreter-assembler.cc", "src/interpreter/interpreter-assembler.h", + "src/interpreter/interpreter-generator-tsa.cc", + "src/interpreter/interpreter-generator-tsa.h", "src/interpreter/interpreter-generator.cc", "src/interpreter/interpreter-generator.h", "src/interpreter/interpreter-intrinsics-generator.cc", @@ -2960,6 +3065,15 @@ v8_source_set("v8_initializers") { "src/builtins/builtins-wasm-gen.cc", "src/builtins/builtins-wasm-gen.h", ] + + if (v8_enable_drumbrake) { + if (v8_current_cpu == "x64") { + sources += [ "src/wasm/interpreter/x64/interpreter-builtins-x64.cc" ] + } else if (v8_current_cpu == "arm64") { + sources += + [ "src/wasm/interpreter/arm64/interpreter-builtins-arm64.cc" ] + } + } } if (v8_current_cpu == "x86") { @@ -2992,17 +3106,12 @@ v8_source_set("v8_initializers") { ### gcmole(loong64) ### "src/builtins/loong64/builtins-loong64.cc", ] - } else if (v8_current_cpu == "ppc") { - sources += [ - ### gcmole(ppc) ### - "src/builtins/ppc/builtins-ppc.cc", - ] } else if (v8_current_cpu == "ppc64") { sources += [ ### gcmole(ppc64) ### "src/builtins/ppc/builtins-ppc.cc", ] - } else if (v8_current_cpu == "s390" || v8_current_cpu == "s390x") { + } else if (v8_current_cpu == "s390x") { sources += [ ### gcmole(s390) ### "src/builtins/s390/builtins-s390.cc", @@ -3324,6 +3433,8 @@ v8_header_set("v8_internal_headers") { "src/common/operation.h", "src/common/ptr-compr-inl.h", "src/common/ptr-compr.h", + "src/common/segmented-table-inl.h", + "src/common/segmented-table.h", "src/common/simd128.h", "src/compiler-dispatcher/lazy-compile-dispatcher.h", "src/compiler-dispatcher/optimizing-compile-dispatcher.h", @@ -3475,6 +3586,7 @@ v8_header_set("v8_internal_headers") { "src/compiler/turboshaft/explicit-truncation-reducer.h", "src/compiler/turboshaft/fast-api-call-lowering-reducer.h", "src/compiler/turboshaft/fast-hash.h", + "src/compiler/turboshaft/field-macro.inc", "src/compiler/turboshaft/graph-builder.h", "src/compiler/turboshaft/graph-visualizer.h", "src/compiler/turboshaft/graph.h", @@ -3513,14 +3625,13 @@ v8_header_set("v8_internal_headers") { "src/compiler/turboshaft/runtime-call-descriptors.h", "src/compiler/turboshaft/select-lowering-reducer.h", "src/compiler/turboshaft/sidetable.h", - "src/compiler/turboshaft/simplified-lowering-phase.h", - "src/compiler/turboshaft/simplified-lowering-reducer.h", "src/compiler/turboshaft/simplify-tf-loops.h", "src/compiler/turboshaft/snapshot-table-opindex.h", "src/compiler/turboshaft/snapshot-table.h", "src/compiler/turboshaft/stack-check-lowering-reducer.h", "src/compiler/turboshaft/store-store-elimination-phase.h", "src/compiler/turboshaft/store-store-elimination-reducer-inl.h", + "src/compiler/turboshaft/string-view.h", "src/compiler/turboshaft/structural-optimization-reducer.h", "src/compiler/turboshaft/tracing.h", "src/compiler/turboshaft/type-assertions-phase.h", @@ -3670,7 +3781,9 @@ v8_header_set("v8_internal_headers") { "src/heap/heap-allocator.h", "src/heap/heap-controller.h", "src/heap/heap-inl.h", + "src/heap/heap-layout-inl.h", "src/heap/heap-layout-tracer.h", + "src/heap/heap-layout.h", "src/heap/heap-write-barrier-inl.h", "src/heap/heap-write-barrier.h", "src/heap/heap.h", @@ -3683,6 +3796,8 @@ v8_header_set("v8_internal_headers") { "src/heap/large-spaces.h", "src/heap/linear-allocation-area.h", "src/heap/list.h", + "src/heap/live-object-range-inl.h", + "src/heap/live-object-range.h", "src/heap/local-factory-inl.h", "src/heap/local-factory.h", "src/heap/local-heap-inl.h", @@ -4297,6 +4412,8 @@ v8_header_set("v8_internal_headers") { "src/compiler/turboshaft/wasm-assembler-helpers.h", "src/compiler/turboshaft/wasm-gc-optimize-phase.h", "src/compiler/turboshaft/wasm-gc-typed-optimization-reducer.h", + "src/compiler/turboshaft/wasm-in-js-inlining-phase.h", + "src/compiler/turboshaft/wasm-in-js-inlining-reducer-inl.h", "src/compiler/turboshaft/wasm-js-lowering-reducer.h", "src/compiler/turboshaft/wasm-load-elimination-reducer.h", "src/compiler/turboshaft/wasm-lowering-phase.h", @@ -4369,6 +4486,8 @@ v8_header_set("v8_internal_headers") { "src/wasm/wasm-arguments.h", "src/wasm/wasm-builtin-list.h", "src/wasm/wasm-code-manager.h", + "src/wasm/wasm-code-pointer-table-inl.h", + "src/wasm/wasm-code-pointer-table.h", "src/wasm/wasm-debug.h", "src/wasm/wasm-deopt-data.h", "src/wasm/wasm-disassembler-impl.h", @@ -4395,6 +4514,18 @@ v8_header_set("v8_internal_headers") { "src/wasm/wasm-value.h", "src/wasm/well-known-imports.h", ] + + if (v8_enable_drumbrake) { + sources += [ + "src/wasm/interpreter/instruction-handlers.h", + "src/wasm/interpreter/wasm-interpreter-inl.h", + "src/wasm/interpreter/wasm-interpreter-objects-inl.h", + "src/wasm/interpreter/wasm-interpreter-objects.h", + "src/wasm/interpreter/wasm-interpreter-runtime-inl.h", + "src/wasm/interpreter/wasm-interpreter-runtime.h", + "src/wasm/interpreter/wasm-interpreter.h", + ] + } } if (v8_enable_wasm_simd256_revec) { @@ -4406,12 +4537,6 @@ v8_header_set("v8_internal_headers") { ] } - if (!v8_enable_third_party_heap) { - sources += filter_include(v8_third_party_heap_files, [ "*.h" ]) - } else { - sources += [ "src/heap/third-party/heap-api.h" ] - } - if (v8_enable_i18n_support) { sources += [ "src/objects/intl-objects.h", @@ -4498,6 +4623,7 @@ v8_header_set("v8_internal_headers") { "src/codegen/shared-ia32-x64/macro-assembler-shared-ia32-x64.h", "src/codegen/x64/assembler-x64-inl.h", "src/codegen/x64/assembler-x64.h", + "src/codegen/x64/builtin-jump-table-info-x64.h", "src/codegen/x64/constants-x64.h", "src/codegen/x64/fma-instr.h", "src/codegen/x64/interface-descriptors-x64-inl.h", @@ -4659,23 +4785,6 @@ v8_header_set("v8_internal_headers") { sources += [ "src/trap-handler/trap-handler-simulator.h" ] } } - } else if (v8_current_cpu == "ppc") { - sources += [ - ### gcmole(ppc) ### - "src/codegen/ppc/assembler-ppc-inl.h", - "src/codegen/ppc/assembler-ppc.h", - "src/codegen/ppc/constants-ppc.h", - "src/codegen/ppc/interface-descriptors-ppc-inl.h", - "src/codegen/ppc/macro-assembler-ppc.h", - "src/codegen/ppc/register-ppc.h", - "src/codegen/ppc/reglist-ppc.h", - "src/compiler/backend/ppc/instruction-codes-ppc.h", - "src/compiler/backend/ppc/unwinding-info-writer-ppc.h", - "src/execution/ppc/frame-constants-ppc.h", - "src/execution/ppc/simulator-ppc.h", - "src/regexp/ppc/regexp-macro-assembler-ppc.h", - "src/wasm/baseline/ppc/liftoff-assembler-ppc-inl.h", - ] } else if (v8_current_cpu == "ppc64") { sources += [ ### gcmole(ppc64) ### @@ -4699,7 +4808,7 @@ v8_header_set("v8_internal_headers") { "src/baseline/ppc/baseline-compiler-ppc-inl.h", ] } - } else if (v8_current_cpu == "s390" || v8_current_cpu == "s390x") { + } else if (v8_current_cpu == "s390x") { sources += [ ### gcmole(s390) ### "src/codegen/s390/assembler-s390-inl.h", @@ -4739,6 +4848,7 @@ v8_header_set("v8_internal_headers") { "src/codegen/riscv/constant-riscv-f.h", "src/codegen/riscv/constant-riscv-m.h", "src/codegen/riscv/constant-riscv-v.h", + "src/codegen/riscv/constant-riscv-zicond.h", "src/codegen/riscv/constant-riscv-zicsr.h", "src/codegen/riscv/constant-riscv-zifencei.h", "src/codegen/riscv/constants-riscv.h", @@ -4750,6 +4860,7 @@ v8_header_set("v8_internal_headers") { "src/codegen/riscv/extension-riscv-inl.h", "src/codegen/riscv/extension-riscv-m.h", "src/codegen/riscv/extension-riscv-v.h", + "src/codegen/riscv/extension-riscv-zicond.h", "src/codegen/riscv/extension-riscv-zicsr.h", "src/codegen/riscv/extension-riscv-zifencei.h", "src/codegen/riscv/interface-descriptors-riscv-inl.h", @@ -5011,14 +5122,6 @@ if (v8_current_cpu == "x86") { "src/compiler/backend/loong64/instruction-scheduler-loong64.cc", "src/compiler/backend/loong64/instruction-selector-loong64.cc", ] -} else if (v8_current_cpu == "ppc") { - v8_compiler_sources += [ - ### gcmole(ppc) ### - "src/compiler/backend/ppc/code-generator-ppc.cc", - "src/compiler/backend/ppc/instruction-scheduler-ppc.cc", - "src/compiler/backend/ppc/instruction-selector-ppc.cc", - "src/compiler/backend/ppc/unwinding-info-writer-ppc.cc", - ] } else if (v8_current_cpu == "ppc64") { v8_compiler_sources += [ ### gcmole(ppc64) ### @@ -5027,7 +5130,7 @@ if (v8_current_cpu == "x86") { "src/compiler/backend/ppc/instruction-selector-ppc.cc", "src/compiler/backend/ppc/unwinding-info-writer-ppc.cc", ] -} else if (v8_current_cpu == "s390" || v8_current_cpu == "s390x") { +} else if (v8_current_cpu == "s390x") { v8_compiler_sources += [ ### gcmole(s390) ### "src/compiler/backend/s390/code-generator-s390.cc", @@ -5057,6 +5160,7 @@ if (v8_enable_webassembly) { "src/compiler/turboshaft/int64-lowering-phase.cc", "src/compiler/turboshaft/wasm-gc-optimize-phase.cc", "src/compiler/turboshaft/wasm-gc-typed-optimization-reducer.cc", + "src/compiler/turboshaft/wasm-in-js-inlining-phase.cc", "src/compiler/turboshaft/wasm-lowering-phase.cc", "src/compiler/turboshaft/wasm-optimize-phase.cc", "src/compiler/turboshaft/wasm-turboshaft-compiler.cc", @@ -5190,7 +5294,6 @@ v8_source_set("v8_turboshaft") { "src/compiler/turboshaft/recreate-schedule.cc", "src/compiler/turboshaft/representations.cc", "src/compiler/turboshaft/sidetable.cc", - "src/compiler/turboshaft/simplified-lowering-phase.cc", "src/compiler/turboshaft/simplify-tf-loops.cc", "src/compiler/turboshaft/store-store-elimination-phase.cc", "src/compiler/turboshaft/type-assertions-phase.cc", @@ -5284,6 +5387,7 @@ v8_source_set("v8_base_without_compiler") { "src/baseline/baseline.cc", "src/baseline/bytecode-offset-iterator.cc", "src/builtins/accessors.cc", + "src/builtins/builtins-abstract-module-source.cc", "src/builtins/builtins-api.cc", "src/builtins/builtins-array.cc", "src/builtins/builtins-arraybuffer.cc", @@ -5437,6 +5541,7 @@ v8_source_set("v8_base_without_compiler") { "src/heap/heap-allocator.cc", "src/heap/heap-controller.cc", "src/heap/heap-layout-tracer.cc", + "src/heap/heap-layout.cc", "src/heap/heap-verifier.cc", "src/heap/heap-write-barrier.cc", "src/heap/heap.cc", @@ -5675,6 +5780,7 @@ v8_source_set("v8_base_without_compiler") { "src/runtime/runtime-test.cc", "src/runtime/runtime-trace.cc", "src/runtime/runtime-typedarray.cc", + "src/runtime/runtime-utils.cc", "src/runtime/runtime-weak-refs.cc", "src/runtime/runtime.cc", "src/sandbox/code-pointer-table.cc", @@ -5823,7 +5929,6 @@ v8_source_set("v8_base_without_compiler") { "src/wasm/graph-builder-interface.cc", "src/wasm/jump-table-assembler.cc", "src/wasm/local-decl-encoder.cc", - "src/wasm/memory-tracing.cc", "src/wasm/module-compiler.cc", "src/wasm/module-decoder.cc", "src/wasm/module-instantiate.cc", @@ -5836,6 +5941,7 @@ v8_source_set("v8_base_without_compiler") { "src/wasm/turboshaft-graph-interface.cc", "src/wasm/value-type.cc", "src/wasm/wasm-code-manager.cc", + "src/wasm/wasm-code-pointer-table.cc", "src/wasm/wasm-debug.cc", "src/wasm/wasm-deopt-data.cc", "src/wasm/wasm-disassembler.cc", @@ -5855,18 +5961,21 @@ v8_source_set("v8_base_without_compiler") { "src/wasm/well-known-imports.cc", "src/wasm/wrappers.cc", ] - if (!is_official_build) { + if (v8_wasm_random_fuzzers) { sources += [ ### gcmole(all) ### "src/wasm/fuzzing/random-module-generation.cc", ] } - } - if (v8_enable_third_party_heap) { - sources += filter_exclude(v8_third_party_heap_files, [ "*.h" ]) - } else { - sources += [ "src/heap/third-party/heap-api-stub.cc" ] + if (v8_enable_drumbrake) { + sources += [ + "src/wasm/interpreter/wasm-interpreter-objects.cc", + "src/wasm/interpreter/wasm-interpreter-runtime.cc", + "src/wasm/interpreter/wasm-interpreter-simd.cc", + "src/wasm/interpreter/wasm-interpreter.cc", + ] + } } if (v8_enable_conservative_stack_scanning) { @@ -5908,6 +6017,7 @@ v8_source_set("v8_base_without_compiler") { ### gcmole(x64) ### "src/codegen/shared-ia32-x64/macro-assembler-shared-ia32-x64.cc", "src/codegen/x64/assembler-x64.cc", + "src/codegen/x64/builtin-jump-table-info-x64.cc", "src/codegen/x64/cpu-x64.cc", "src/codegen/x64/macro-assembler-x64.cc", "src/deoptimizer/x64/deoptimizer-x64.cc", @@ -6041,21 +6151,6 @@ v8_source_set("v8_base_without_compiler") { sources += [ "src/trap-handler/handler-outside-simulator.cc" ] } } - } else if (v8_current_cpu == "ppc") { - sources += [ - ### gcmole(ppc) ### - "src/codegen/ppc/assembler-ppc.cc", - "src/codegen/ppc/constants-ppc.cc", - "src/codegen/ppc/cpu-ppc.cc", - "src/codegen/ppc/macro-assembler-ppc.cc", - "src/deoptimizer/ppc/deoptimizer-ppc.cc", - "src/diagnostics/ppc/disasm-ppc.cc", - "src/diagnostics/ppc/eh-frame-ppc.cc", - "src/diagnostics/ppc/unwinder-ppc.cc", - "src/execution/ppc/frame-constants-ppc.cc", - "src/execution/ppc/simulator-ppc.cc", - "src/regexp/ppc/regexp-macro-assembler-ppc.cc", - ] } else if (v8_current_cpu == "ppc64") { sources += [ ### gcmole(ppc64) ### @@ -6071,7 +6166,7 @@ v8_source_set("v8_base_without_compiler") { "src/execution/ppc/simulator-ppc.cc", "src/regexp/ppc/regexp-macro-assembler-ppc.cc", ] - } else if (v8_current_cpu == "s390" || v8_current_cpu == "s390x") { + } else if (v8_current_cpu == "s390x") { sources += [ ### gcmole(s390) ### "src/codegen/s390/assembler-s390.cc", @@ -6101,6 +6196,7 @@ v8_source_set("v8_base_without_compiler") { "src/codegen/riscv/extension-riscv-f.cc", "src/codegen/riscv/extension-riscv-m.cc", "src/codegen/riscv/extension-riscv-v.cc", + "src/codegen/riscv/extension-riscv-zicond.cc", "src/codegen/riscv/extension-riscv-zicsr.cc", "src/codegen/riscv/extension-riscv-zifencei.cc", "src/codegen/riscv/macro-assembler-riscv.cc", @@ -6140,6 +6236,7 @@ v8_source_set("v8_base_without_compiler") { "src/codegen/riscv/extension-riscv-f.cc", "src/codegen/riscv/extension-riscv-m.cc", "src/codegen/riscv/extension-riscv-v.cc", + "src/codegen/riscv/extension-riscv-zicond.cc", "src/codegen/riscv/extension-riscv-zicsr.cc", "src/codegen/riscv/extension-riscv-zifencei.cc", "src/codegen/riscv/macro-assembler-riscv.cc", @@ -6177,6 +6274,7 @@ v8_source_set("v8_base_without_compiler") { ":v8_tracing", ":v8_version", "src/inspector:inspector", + "//third_party/fast_float", ] public_deps = [ @@ -6240,16 +6338,11 @@ v8_source_set("v8_base_without_compiler") { libs = [] - if (v8_enable_third_party_heap) { - libs += v8_third_party_heap_libs - } - # Platforms that don't have CAS support need to link atomic library # to implement atomic memory access if (v8_current_cpu == "mips64" || v8_current_cpu == "mips64el" || - v8_current_cpu == "ppc" || v8_current_cpu == "ppc64" || - (current_os != "zos" && - (v8_current_cpu == "s390" || v8_current_cpu == "s390x")) || + v8_current_cpu == "ppc64" || + (current_os != "zos" && v8_current_cpu == "s390x") || v8_current_cpu == "riscv64" || v8_current_cpu == "riscv32") { if (!is_clang) { libs += [ "atomic" ] @@ -6462,7 +6555,6 @@ v8_component("v8_libbase") { "src/base/numbers/strtod.h", "src/base/once.cc", "src/base/once.h", - "src/base/optional.h", "src/base/overflowing-math.h", "src/base/page-allocator.cc", "src/base/page-allocator.h", @@ -6504,7 +6596,7 @@ v8_component("v8_libbase") { "src/base/strings.h", "src/base/sys-info.cc", "src/base/sys-info.h", - "src/base/template-meta-programming/algorithm.h", + "src/base/template-meta-programming/common.h", "src/base/template-meta-programming/functional.h", "src/base/template-meta-programming/list.h", "src/base/template-meta-programming/string-literal.h", @@ -7495,7 +7587,7 @@ group("v8_fuzzers") { ] if (v8_enable_webassembly) { - if (!is_official_build) { + if (v8_wasm_random_fuzzers) { data_deps += [ ":v8_simple_wasm_compile_all_fuzzer", ":v8_simple_wasm_compile_fuzzer", @@ -7914,11 +8006,7 @@ if (v8_enable_webassembly) { sources = [ "test/fuzzer/wasm-streaming.cc" ] } - # Some fuzzers depend on fuzzing functionality linked into the v8 library. - # For binary size reasons this functionality is not available for official - # builds, therefore these fuzzers do not function there and should be skipped - # instead. - if (!is_official_build) { + if (v8_wasm_random_fuzzers) { v8_wasm_fuzzer("wasm_compile_all_fuzzer") { sources = [ "test/common/wasm/test-signatures.h", @@ -7954,7 +8042,7 @@ if (v8_enable_webassembly) { v8_wasm_fuzzer("wasm_deopt_fuzzer") { sources = [ "test/fuzzer/wasm-deopt.cc" ] } - } # !is_official_build + } # v8_wasm_random_fuzzers } v8_fuzzer("inspector_fuzzer") { diff --git a/deps/v8/COMMON_OWNERS b/deps/v8/COMMON_OWNERS index 5d4e99de..acd008e3 100644 --- a/deps/v8/COMMON_OWNERS +++ b/deps/v8/COMMON_OWNERS @@ -11,8 +11,8 @@ dlehmann@chromium.org dmercadier@chromium.org ecmziegler@chromium.org evih@chromium.org +fgm@chromium.org gdeepti@chromium.org -hablich@chromium.org hpayer@chromium.org ishell@chromium.org jgruber@chromium.org @@ -22,7 +22,6 @@ liviurau@chromium.org machenbach@chromium.org manoskouk@chromium.org marja@chromium.org -mathias@chromium.org mliedtke@chromium.org mlippautz@chromium.org nicohartmann@chromium.org diff --git a/deps/v8/DEPS b/deps/v8/DEPS index bbc62618..992b3e66 100644 --- a/deps/v8/DEPS +++ b/deps/v8/DEPS @@ -39,6 +39,9 @@ vars = { # Fetch clang-tidy into the same bin/ directory as our clang binary. 'checkout_clang_tidy': False, + # Fetch clangd into the same bin/ directory as our clang binary. + 'checkout_clangd': False, + # Fetch and build V8 builtins with PGO profiles 'checkout_v8_builtins_pgo_profiles': False, @@ -57,7 +60,7 @@ vars = { 'checkout_fuchsia_no_hooks': False, # reclient CIPD package version - 'reclient_version': 're_client_version:0.148.0.41b09b51-gomaip', + 'reclient_version': 're_client_version:0.164.0.76480e37-gomaip', # Fetch configuration files required for the 'use_remoteexec' gn arg 'download_remoteexec_cfg': False, @@ -73,22 +76,22 @@ vars = { 'build_with_chromium': False, # GN CIPD package version. - 'gn_version': 'git_revision:b2afae122eeb6ce09c52d63f67dc53fc517dbdc8', + 'gn_version': 'git_revision:95b0f8fe31a992a33c040bbe3867901335c12762', # ninja CIPD package version - # https://chrome-infra-packages.appspot.com/p/infra/3pp/build_support/ninja-1_11_1/ - 'ninja_version': 'version:2@1.11.1.chromium.2', + # https://chrome-infra-packages.appspot.com/p/infra/3pp/tools/ninja + 'ninja_version': 'version:3@1.12.1.chromium.4', # siso CIPD package version - 'siso_version': 'git_revision:b41f9eaf44dfdaec51ab2d7089aaa4cb6d9e7f5e', + 'siso_version': 'git_revision:e8827a58e51f92cc53a44fb40db89dbde507f800', # luci-go CIPD package version. - 'luci_go': 'git_revision:c9c95dda5f310610a3fc574af44faeed298b3938', + 'luci_go': 'git_revision:89012fa4a0c088cc353b23c6af126e2832114ef6', # Three lines of non-changing comments so that # the commit queue can handle CLs rolling Fuchsia sdk # and whatever else without interference from each other. - 'fuchsia_version': 'version:22.20240717.4.1', + 'fuchsia_version': 'version:24.20240919.7.1', # Three lines of non-changing comments so that # the commit queue can handle CLs rolling android_sdk_build-tools_version @@ -121,14 +124,14 @@ vars = { # Three lines of non-changing comments so that # the commit queue can handle CLs rolling android_sdk_tools-lint_version # and whatever else without interference from each other. - 'android_sdk_cmdline-tools_version': 'mU9jm4LkManzjSzRquV1UIA7fHBZ2pK7NtbCXxoVnVUC', + 'android_sdk_cmdline-tools_version': 'B4p95sDPpm34K8Cf4JcfTM-iYSglWko9qjWgbT9dxWQC', } deps = { 'build': - Var('chromium_url') + '/chromium/src/build.git' + '@' + 'ad2f859fc3b655b9a69157d7f82478ac5f3902bf', + Var('chromium_url') + '/chromium/src/build.git' + '@' + '639edaa7d1f6cbe02429ea9376b8d069d7489437', 'buildtools': - Var('chromium_url') + '/chromium/src/buildtools.git' + '@' + 'adc2a53a411826b429a01363ad0ff598325c1f73', + Var('chromium_url') + '/chromium/src/buildtools.git' + '@' + 'c50ea35e09f8ef663bd98218be7f632f1830d6e3', 'buildtools/linux64': { 'packages': [ { @@ -174,7 +177,7 @@ deps = { 'test/mozilla/data': Var('chromium_url') + '/v8/deps/third_party/mozilla-tests.git' + '@' + 'f6c578a10ea707b1a8ab0b88943fe5115ce2b9be', 'test/test262/data': - Var('chromium_url') + '/external/github.com/tc39/test262.git' + '@' + 'b01075d87cf48f69a468d75a0eb7c372902965c7', + Var('chromium_url') + '/external/github.com/tc39/test262.git' + '@' + '867ca540d6cc991a82b41a3b7f9ccb9e93efe803', 'third_party/android_platform': { 'url': Var('chromium_url') + '/chromium/src/third_party/android_platform.git' + '@' + '6337c445f9963ec3914e7e0c5787941d07b46509', 'condition': 'checkout_android', @@ -221,22 +224,22 @@ deps = { 'packages': [ { 'package': 'chromium/third_party/android_toolchain/android_toolchain', - 'version': 'h9HeidXTeHQ-oskldbqCZx26-7VrVvXpLfqOI87uy4QC', + 'version': 'Idl-vYnWGnM8K3XJhM3h6zjYVDXlnljVz3FE00V9IM8C', }, ], 'condition': 'checkout_android', 'dep_type': 'cipd', }, 'third_party/boringssl': { - 'url': Var('chromium_url') + '/chromium/src/third_party/boringssl.git' + '@' + '35f4fcbdeae229a56fd50320dc03ae6de407aca4', + 'url': Var('chromium_url') + '/chromium/src/third_party/boringssl.git' + '@' + 'c79987a83ceaf2cf911f7d21bec621ddc90c45cc', 'condition': "checkout_centipede_deps", }, 'third_party/boringssl/src': { - 'url': Var('boringssl_url') + '/boringssl.git' + '@' + 'f01108e4761e1d4189cb134322c3cb01dc71ef87', + 'url': Var('boringssl_url') + '/boringssl.git' + '@' + '5a94aff9aebcf9738c7bc464bc95fa4ac3a46ed7', 'condition': "checkout_centipede_deps", }, 'third_party/catapult': { - 'url': Var('chromium_url') + '/catapult.git' + '@' + '29445d0e3f4de0f20d4894506716584e9d604e04', + 'url': Var('chromium_url') + '/catapult.git' + '@' + '4e0ee7600498ca28fd633a58d081180d92f13d00', 'condition': 'checkout_android', }, 'third_party/clang-format/script': @@ -250,11 +253,13 @@ deps = { 'condition': 'checkout_android', }, 'third_party/depot_tools': - Var('chromium_url') + '/chromium/tools/depot_tools.git' + '@' + 'b4102e43a02805cf7bcb100446d27caef1b4e51d', + Var('chromium_url') + '/chromium/tools/depot_tools.git' + '@' + '8050ac421d05d9827af68f6a748aff4ff592eb8e', 'third_party/fp16/src': Var('chromium_url') + '/external/github.com/Maratyszcza/FP16.git' + '@' + '0a92994d729ff76a58f692d3028ca1b64b145d91', + 'third_party/fast_float/src': + Var('chromium_url') + '/external/github.com/fastfloat/fast_float.git' + '@' + '3e57d8dcfb0a04b5a8a26b486b54490a2e9b310f', 'third_party/fuchsia-gn-sdk': { - 'url': Var('chromium_url') + '/chromium/src/third_party/fuchsia-gn-sdk.git' + '@' + '30fee7b68b3675e351fa47303c3b6ef322941ccd', + 'url': Var('chromium_url') + '/chromium/src/third_party/fuchsia-gn-sdk.git' + '@' + 'aa788879ce5f9642a5379322ee20786741a20ee3', 'condition': 'checkout_fuchsia', }, # Exists for rolling the Fuchsia SDK. Check out of the SDK should always @@ -280,7 +285,7 @@ deps = { 'third_party/fuzztest/src': Var('chromium_url') + '/external/github.com/google/fuzztest.git' + '@' + '32eb84a95951fa3a0148fb3e6a1a02f830ded136', 'third_party/googletest/src': - Var('chromium_url') + '/external/github.com/google/googletest.git' + '@' + '9ff2450a56aed4f7f124f5104d9e3088bf791ee9', + Var('chromium_url') + '/external/github.com/google/googletest.git' + '@' + '6dae7eb4a5c3a169f3e298392bff4680224aa94a', 'third_party/highway/src': Var('chromium_url') + '/external/github.com/google/highway.git' + '@' + '8295336dd70f1201d42c22ab5b0861de38cf8fbf', 'third_party/icu': @@ -300,125 +305,153 @@ deps = { 'third_party/jsoncpp/source': Var('chromium_url') + '/external/github.com/open-source-parsers/jsoncpp.git'+ '@' + '42e892d96e47b1f6e29844cc705e148ec4856448', 'third_party/libc++/src': - Var('chromium_url') + '/external/github.com/llvm/llvm-project/libcxx.git' + '@' + '6bb75caa139ee1e686d2205910454cf6ea212e58', + Var('chromium_url') + '/external/github.com/llvm/llvm-project/libcxx.git' + '@' + '06d85ffb29ce1b39d7ad0f5b1863c45551919e20', 'third_party/libc++abi/src': - Var('chromium_url') + '/external/github.com/llvm/llvm-project/libcxxabi.git' + '@' + 'a3c7d3e2f3e1e724b4651891b1a71257cbd88acc', + Var('chromium_url') + '/external/github.com/llvm/llvm-project/libcxxabi.git' + '@' + '448b409508a676e1283968e6440ad2c049032253', 'third_party/libunwind/src': - Var('chromium_url') + '/external/github.com/llvm/llvm-project/libunwind.git' + '@' + 'd09db732ff68f40fd3581306c650b17ea1955b4e', + Var('chromium_url') + '/external/github.com/llvm/llvm-project/libunwind.git' + '@' + 'dc70138c3e68e2f946585f134e20815851e26263', 'third_party/llvm-build/Release+Asserts': { 'dep_type': 'gcs', 'bucket': 'chromium-browser-clang', 'objects': [ { - 'object_name': 'Linux_x64/clang-llvmorg-19-init-14561-gecea8371-3.tar.xz', - 'sha256sum': '2c48fb44f408328f59482a1dafb2143bb8b6b04be23f407600117e6f6d4fa437', - 'size_bytes': 51489572, - 'generation': 1721105679311662, + 'object_name': 'Linux_x64/clang-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': '6a30f7bc7c5f0eac02a40a4ec9a1ab906ddff2adacf2c9ff065916047c79f0fb', + 'size_bytes': 52892060, + 'generation': 1726118358890940, 'condition': 'host_os == "linux"', }, { - 'object_name': 'Linux_x64/clang-tidy-llvmorg-19-init-14561-gecea8371-3.tar.xz', - 'sha256sum': '3570497c3c507be0f8f4c0aa149a57fc600ed49252da42676996ea651df05e60', - 'size_bytes': 13081104, - 'generation': 1721105679453016, + 'object_name': 'Linux_x64/clang-tidy-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': '35e00fc8f58cf7cd30f0ad27c2fdef56b677e287030072c46c0f024d23363ae4', + 'size_bytes': 13283180, + 'generation': 1726118359291453, 'condition': 'host_os == "linux" and checkout_clang_tidy', }, { - 'object_name': 'Linux_x64/llvm-code-coverage-llvmorg-19-init-14561-gecea8371-3.tar.xz', - 'sha256sum': 'dd6f1c05d5fe244b4524af86e6aa20de2d730f7d7e01fe4002b5aa72347b7658', - 'size_bytes': 2357488, - 'generation': 1721105679795112, + 'object_name': 'Linux_x64/clangd-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': '33e2276976dfeaf387f5ea16651ea591eebe3570a12469f3884c74f8079e88bf', + 'size_bytes': 26305668, + 'generation': 1726118359489734, + 'condition': 'host_os == "linux" and checkout_clangd', + }, + { + 'object_name': 'Linux_x64/llvm-code-coverage-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': '426c6bd378848de0817a7695fee821bece9efb51e3ed1d7b750a75bc17bf00eb', + 'size_bytes': 2370472, + 'generation': 1726118360237343, 'condition': 'host_os == "linux" and checkout_clang_coverage_tools', }, { - 'object_name': 'Linux_x64/llvmobjdump-llvmorg-19-init-14561-gecea8371-3.tar.xz', - 'sha256sum': 'a93d8b39ac573376a2db77b04f014d8751375de8c70ee16ca4713e5da467c5ec', - 'size_bytes': 5387304, - 'generation': 1721105679641287, + 'object_name': 'Linux_x64/llvmobjdump-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': 'e11c3043e76c7c79fe7905861a11c78433c6d796d049f837eda0a2ce118f0793', + 'size_bytes': 5410724, + 'generation': 1726118359908897, 'condition': '(checkout_linux or checkout_mac or checkout_android and host_os != "mac")', }, { - 'object_name': 'Mac/clang-llvmorg-19-init-14561-gecea8371-3.tar.xz', - 'sha256sum': '04956a3db535f4cf1ab0a6e40383cbb5db7d6ee09721e31a706d230af206eaa0', - 'size_bytes': 46446976, - 'generation': 1721105680965575, + 'object_name': 'Mac/clang-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': 'cabfc7ca792ef13d3e665c3a7811f9a76cc39094059c11606cea1724f0394bbc', + 'size_bytes': 47551968, + 'generation': 1726118361528729, 'condition': 'host_os == "mac" and host_cpu == "x64"', }, { - 'object_name': 'Mac/clang-mac-runtime-library-llvmorg-19-init-14561-gecea8371-3.tar.xz', - 'sha256sum': 'c684d46962bd39f785a143c2b28a0400c6e6d41a610a04ad6982f7513b930a35', - 'size_bytes': 865444, - 'generation': 1721105687851327, + 'object_name': 'Mac/clang-mac-runtime-library-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': '50a618246d7fd23645640fc50ccb0d4684c1895def378b90963a289f920ea88a', + 'size_bytes': 879508, + 'generation': 1726118377526206, 'condition': 'checkout_mac and not host_os == "mac"', }, { - 'object_name': 'Mac/clang-tidy-llvmorg-19-init-14561-gecea8371-3.tar.xz', - 'sha256sum': '1bcfd396959c5f0e835e33f7bd15f29b2a1b1b27c619480dab767d034da48098', - 'size_bytes': 12650532, - 'generation': 1721105681146275, + 'object_name': 'Mac/clang-tidy-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': '2c325505ea43a8d8a14770890d62aba9af37b397e3063e3fb622cfd51d4706f6', + 'size_bytes': 12884412, + 'generation': 1726118361811669, 'condition': 'host_os == "mac" and host_cpu == "x64" and checkout_clang_tidy', }, { - 'object_name': 'Mac/llvm-code-coverage-llvmorg-19-init-14561-gecea8371-3.tar.xz', - 'sha256sum': 'dbaf0d0bc4d19be0a9bd033b94033a2e9f826f8ed4ec3e9e6fa732ca3b4f1b6f', - 'size_bytes': 2234200, - 'generation': 1721105681470376, + 'object_name': 'Mac/clangd-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': '1c1a0965cc95053dec8c649a7b3bb627ad2300ad230eed97b52ee70a8a8edd85', + 'size_bytes': 26553148, + 'generation': 1726118361978146, + 'condition': 'host_os == "mac" and host_cpu == "x64" and checkout_clangd', + }, + { + 'object_name': 'Mac/llvm-code-coverage-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': '9259bd27c19ca9662c70ffc2b42c10afb584e7c584470d6e656e164643614b50', + 'size_bytes': 2247028, + 'generation': 1726118362377026, 'condition': 'host_os == "mac" and host_cpu == "x64" and checkout_clang_coverage_tools', }, { - 'object_name': 'Mac_arm64/clang-llvmorg-19-init-14561-gecea8371-3.tar.xz', - 'sha256sum': '3d8d0a32604b9c8f9add4865d4e2b4950607d2a201bcd1c3de9e67e2998f1a84', - 'size_bytes': 42076344, - 'generation': 1721105689042846, + 'object_name': 'Mac_arm64/clang-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': 'e87eb4caa95c98ef36c40aec5b8cd07a6c4fb8959d3c7e7d452f6ed860c8c2bf', + 'size_bytes': 41352592, + 'generation': 1726118378868177, 'condition': 'host_os == "mac" and host_cpu == "arm64"', }, { - 'object_name': 'Mac_arm64/clang-tidy-llvmorg-19-init-14561-gecea8371-3.tar.xz', - 'sha256sum': '12524e94777f1d78489f58bcd966a341c8a61dca56175c7d6e8835240b2dcade', - 'size_bytes': 11612984, - 'generation': 1721105689155910, + 'object_name': 'Mac_arm64/clang-tidy-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': 'fcf8f25a8461db90686d0455bd8f195750a2cdc425cb03c48debe4d3e8bb9299', + 'size_bytes': 11476316, + 'generation': 1726118379144738, 'condition': 'host_os == "mac" and host_cpu == "arm64" and checkout_clang_tidy', }, { - 'object_name': 'Mac_arm64/llvm-code-coverage-llvmorg-19-init-14561-gecea8371-3.tar.xz', - 'sha256sum': '85db7e11d059902cd2c3d04e1d0380524d0ef4bf6ec3c93f0afdfd663d8b2a64', - 'size_bytes': 2005884, - 'generation': 1721105689448152, + 'object_name': 'Mac_arm64/clangd-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': 'cca4049d3362528511ebc603db05189c9bef406a80ae4fead22b1db0a4de83e6', + 'size_bytes': 22679568, + 'generation': 1726118379283835, + 'condition': 'host_os == "mac" and host_cpu == "arm64" and checkout_clangd', + }, + { + 'object_name': 'Mac_arm64/llvm-code-coverage-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': '001e8582de4bc7c434f321b5bacd2b0b45e553f3134cb7d78e1a4f62e2b97ac6', + 'size_bytes': 1969844, + 'generation': 1726118379757221, 'condition': 'host_os == "mac" and host_cpu == "arm64" and checkout_clang_coverage_tools', }, { - 'object_name': 'Win/clang-llvmorg-19-init-14561-gecea8371-3.tar.xz', - 'sha256sum': '34ba04b75548fdce4b3d2ba9dc8320a11afb0cad8622d537c1cf37f1c5587bab', - 'size_bytes': 41800448, - 'generation': 1721105697679553, + 'object_name': 'Win/clang-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': 'cb416511e6379b7fd3f362f637ebb8a28957d0d2ff2dc6e2d9f4484a381f2885', + 'size_bytes': 44655000, + 'generation': 1726118399720986, 'condition': 'host_os == "win"', }, { - 'object_name': 'Win/clang-tidy-llvmorg-19-init-14561-gecea8371-3.tar.xz', - 'sha256sum': '41fe89c54964a6a8efb66c398dbf763e8a4aca6a675c6f4d15a94c5236ba1ab7', - 'size_bytes': 12869556, - 'generation': 1721105697770165, + 'object_name': 'Win/clang-tidy-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': '15af2ae61dabdfe0ddbdd48f467b996855ba51d0ef633c5c0ac3c74cdc0d8f2c', + 'size_bytes': 13114928, + 'generation': 1726118400057660, 'condition': 'host_os == "win" and checkout_clang_tidy', }, { - 'object_name': 'Win/clang-win-runtime-library-llvmorg-19-init-14561-gecea8371-3.tar.xz', - 'sha256sum': 'ce7886ecbfb129660a14cc11c4eacd6a2ef6488b36a88a7afb71a8cd22277da0', - 'size_bytes': 2842872, - 'generation': 1721105704724295, + 'object_name': 'Win/clang-win-runtime-library-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': '81d66840357d83ca1a2c85ebca5259a7a86d9e99c77b37727fbaee87ccacf675', + 'size_bytes': 2897452, + 'generation': 1726118416326356, 'condition': 'checkout_win and not host_os == "win"', }, { - 'object_name': 'Win/llvm-code-coverage-llvmorg-19-init-14561-gecea8371-3.tar.xz', - 'sha256sum': 'e5778f9a2fa59936676579b01b3b576d8c545b72e5261c47a36751d4f1f6b61a', - 'size_bytes': 2357104, - 'generation': 1721105698068261, + 'object_name': 'Win/clangd-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': '1304718c221543b16465a4b6108572fa1ba9f2b75c4e4398bdb01fb983428c10', + 'size_bytes': 25169688, + 'generation': 1726118400193324, + 'condition': 'host_os == "win" and checkout_clangd', + }, + { + 'object_name': 'Win/llvm-code-coverage-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': 'e01b8fbca72fc1cca6988e359d9a0eea8fa5ccbaff8d41deffd62970c7f4fed5', + 'size_bytes': 2382756, + 'generation': 1726118400642803, 'condition': 'host_os == "win" and checkout_clang_coverage_tools', }, { - 'object_name': 'Win/llvmobjdump-llvmorg-19-init-14561-gecea8371-3.tar.xz', - 'sha256sum': 'ad7d9162e1632b5c64188f95362318f0d31e09002be0615df847f2c23cddef4c', - 'size_bytes': 5362484, - 'generation': 1721105697937832, + 'object_name': 'Win/llvmobjdump-llvmorg-20-init-3847-g69c43468-28.tar.xz', + 'sha256sum': '2f837a21d910ad748666282d0c1da15a438d9aae4fc1bc85dab7313da6dfeb7b', + 'size_bytes': 5439736, + 'generation': 1726118400404099, 'condition': 'checkout_linux or checkout_mac or checkout_android and host_os == "win"', }, ], @@ -426,11 +459,11 @@ deps = { 'third_party/logdog/logdog': Var('chromium_url') + '/infra/luci/luci-py/client/libs/logdog' + '@' + '0b2078a90f7a638d576b3a7c407d136f2fb62399', 'third_party/markupsafe': - Var('chromium_url') + '/chromium/src/third_party/markupsafe.git' + '@' + 'e582d7f0edb9d67499b0f5abd6ae5550e91da7f2', + Var('chromium_url') + '/chromium/src/third_party/markupsafe.git' + '@' + '6638e9b0a79afc2ff7edd9e84b518fe7d5d5fea9', 'third_party/ninja': { 'packages': [ { - 'package': 'infra/3pp/build_support/ninja-1_11_1/${{platform}}', + 'package': 'infra/3pp/tools/ninja/${{platform}}', 'version': Var('ninja_version'), } ], @@ -439,8 +472,8 @@ deps = { }, 'third_party/perfetto': Var('android_url') + '/platform/external/perfetto.git' + '@' + '6fc824d618d2f06b5d9cd8655ba0419b6b3b366e', - 'third_party/protobuf_chrome': - Var('chromium_url') + '/chromium/src/third_party/protobuf.git' + '@' + 'da2fe725b80ac0ba646fbf77d0ce5b4ac236f823', + 'third_party/protobuf': + Var('chromium_url') + '/chromium/src/third_party/protobuf.git' + '@' + '37bbf271c62d6c01c58c66505b17c7dcf086371a', 'third_party/re2/src': Var('chromium_url') + '/external/github.com/google/re2.git' + '@' + '6dcd83d60f7944926bfd308cc13979fc53dd69ca', 'third_party/requests': { @@ -458,9 +491,9 @@ deps = { 'condition': 'not build_with_chromium and host_cpu != "s390" and host_os != "zos" and host_cpu != "ppc"', }, 'third_party/zlib': - Var('chromium_url') + '/chromium/src/third_party/zlib.git'+ '@' + 'c2469fdd73f192383d2d94288da0ff5b9a3869f5', + Var('chromium_url') + '/chromium/src/third_party/zlib.git'+ '@' + 'fa9f14143c7938e6a1d18443900efee7a1e5e669', 'tools/clang': - Var('chromium_url') + '/chromium/src/tools/clang.git' + '@' + 'a5953b107df1aa821e0f9e890cd3ba1afa180e37', + Var('chromium_url') + '/chromium/src/tools/clang.git' + '@' + '2acd1a18712637243a9a137f0071ef411304bf99', 'tools/luci-go': { 'packages': [ { @@ -478,7 +511,7 @@ deps = { 'tools/protoc_wrapper': Var('chromium_url') + '/chromium/src/tools/protoc_wrapper.git' + '@' + 'dbcbea90c20ae1ece442d8ef64e61c7b10e2b013', 'third_party/abseil-cpp': { - 'url': Var('chromium_url') + '/chromium/src/third_party/abseil-cpp.git' + '@' + '9d1552f25c3d9e9114b7d7aed55790570a99bc4d', + 'url': Var('chromium_url') + '/chromium/src/third_party/abseil-cpp.git' + '@' + 'd2ea9f0eb1a31f0e5a0ab11837ed19333700ab4c', 'condition': 'not build_with_chromium', }, 'third_party/zoslib': { @@ -493,6 +526,7 @@ include_rules = [ '+unicode', '+third_party/fdlibm', '+third_party/ittapi/include', + '+third_party/fast_float/src/include', '+third_party/fp16/src/include', '+third_party/v8/codegen', '+third_party/fuzztest', diff --git a/deps/v8/WATCHLISTS b/deps/v8/WATCHLISTS index adeaa4b0..4486df1b 100644 --- a/deps/v8/WATCHLISTS +++ b/deps/v8/WATCHLISTS @@ -129,7 +129,6 @@ 'verwaest+watch@chromium.org', ], 'feature_shipping_status': [ - 'hablich@chromium.org', 'saelo+watch@chromium.org', ], 'heap_changes': [ diff --git a/deps/v8/bazel/defs.bzl b/deps/v8/bazel/defs.bzl index 520a3115..b7353fff 100644 --- a/deps/v8/bazel/defs.bzl +++ b/deps/v8/bazel/defs.bzl @@ -432,7 +432,7 @@ def _v8_target_cpu_transition_impl(settings, "armeabi-v7a": "arm32", "s390x": "s390x", "riscv64": "riscv64", - "ppc": "ppc64le", + "ppc64": "ppc64le", } v8_target_cpu = mapping[settings["//command_line_option:cpu"]] return {"@v8//bazel/config:v8_target_cpu": v8_target_cpu} @@ -549,7 +549,6 @@ def build_config_content(cpu, icu): ("debugging_features", "false"), ("dict_property_const_tracking", "false"), ("direct_handle", "false"), - ("direct_local", "false"), ("disassembler", "false"), ("full_debug", "false"), ("gdbjit", "false"), @@ -557,10 +556,12 @@ def build_config_content(cpu, icu): ("has_maglev", "true"), ("has_turbofan", "true"), ("has_webassembly", "false"), + ("has_wasm_interpreter", "false"), ("i18n", icu), ("is_android", "false"), ("is_ios", "false"), ("js_shared_memory", "false"), + ("leaptiering", "true"), ("lite_mode", "false"), ("local_off_stack_check", "false"), ("memory_corruption_api", "false"), @@ -578,7 +579,6 @@ def build_config_content(cpu, icu): ("single_generation", "false"), ("slow_dchecks", "false"), ("target_cpu", cpu), - ("third_party_heap", "false"), ("tsan", "false"), ("ubsan", "false"), ("use_sanitizer", "false"), diff --git a/deps/v8/build_overrides/build.gni b/deps/v8/build_overrides/build.gni index 0a1fc3c4..29acce40 100644 --- a/deps/v8/build_overrides/build.gni +++ b/deps/v8/build_overrides/build.gni @@ -17,15 +17,6 @@ build_with_node = false # chromium build. perfetto_build_with_embedder = true -# TODO(https://crbug.com/337736622): Perfetto and FuzzTest need to know the -# path to protobuf targets. V8 stores them in a different location than Chrome -# until M129. Thereafter, it can move to //third_party/protobuf and these -# variables can be removed. -protobuf_target_prefix = "//third_party/protobuf_chrome/" -perfetto_protobuf_target_prefix = protobuf_target_prefix -perfetto_protobuf_gni = "//third_party/protobuf_chrome/proto_library.gni" -perfetto_protobuf_src_dir = "//third_party/protobuf_chrome/src" - # We use Perfetto's Trace Processor to convert traces to the legacy JSON # format. enable_perfetto_trace_processor = true diff --git a/deps/v8/docs/OWNERS b/deps/v8/docs/OWNERS index 39b706f0..07428b27 100644 --- a/deps/v8/docs/OWNERS +++ b/deps/v8/docs/OWNERS @@ -1,2 +1 @@ -hablich@chromium.org -mathias@chromium.org +hpayer@chromium.org diff --git a/deps/v8/gni/v8.gni b/deps/v8/gni/v8.gni index 9ee57a49..09c3e7ad 100644 --- a/deps/v8/gni/v8.gni +++ b/deps/v8/gni/v8.gni @@ -118,12 +118,9 @@ declare_args() { # Scan the call stack conservatively during garbage collection. v8_enable_conservative_stack_scanning = false - # Use direct pointers in internal (direct) handles. + # Use direct pointers in handles (v8::internal::Handle and v8::Local). v8_enable_direct_handle = "" - # Use direct pointers in local handles. - v8_enable_direct_local = "" - # Check for off-stack allocated local handles. v8_enable_local_off_stack_check = false @@ -166,12 +163,22 @@ declare_args() { # Location of zlib. v8_zlib_path = "//third_party/zlib" + # Enable pointer compression (sets -dV8_COMPRESS_POINTERS). + v8_enable_pointer_compression = "" + v8_enable_pointer_compression_shared_cage = "" + v8_enable_31bit_smis_on_64bit_arch = false + # Change code emission and runtime features to be CET shadow-stack compliant # (incomplete and experimental). v8_enable_cet_shadow_stack = false # Emit CET IBT landing pad instructions in JIT generated code (experimental). v8_enable_cet_ibt = false + + # Use memory sealing to protect various global memory mappings for CFI + # (experimental). + # TODO(sroettger): enable by default once we have bot support for testing. + v8_enable_memory_sealing = false } if (v8_use_external_startup_data == "") { @@ -209,6 +216,18 @@ if (v8_enable_webassembly == "") { assert(!(v8_enable_webassembly && v8_enable_lite_mode), "Webassembly is not available in lite mode.") +if (v8_enable_pointer_compression == "") { + v8_enable_pointer_compression = + v8_current_cpu == "arm64" || v8_current_cpu == "x64" +} + +# The Wasm interpreter is currently supported only on arm64 and x64, on +# Windows, Linux and MacOS. +is_drumbrake_supported = + v8_enable_webassembly && v8_enable_pointer_compression && + (v8_current_cpu == "x64" || v8_current_cpu == "arm64") && + (target_os == "win" || target_os == "linux" || target_os == "mac") + # Turbofan is enabled by default, except in lite mode. if (v8_enable_turbofan == "") { v8_enable_turbofan = !v8_enable_lite_mode @@ -221,9 +240,6 @@ assert(v8_enable_turbofan || !v8_enable_webassembly, if (v8_enable_direct_handle == "") { v8_enable_direct_handle = v8_enable_conservative_stack_scanning } -if (v8_enable_direct_local == "") { - v8_enable_direct_local = v8_enable_conservative_stack_scanning -} # Points to // in v8 stand-alone or to //v8/ in chromium. We need absolute # paths for all configs in templates as they are shared in different diff --git a/deps/v8/include/OWNERS b/deps/v8/include/OWNERS index 535040c5..9a2d99e8 100644 --- a/deps/v8/include/OWNERS +++ b/deps/v8/include/OWNERS @@ -19,5 +19,4 @@ per-file v8-version.h=v8-ci-autoroll-builder@chops-service-accounts.iam.gservice # For branch updates: per-file v8-version.h=file:../INFRA_OWNERS -per-file v8-version.h=hablich@chromium.org per-file v8-version.h=vahl@chromium.org diff --git a/deps/v8/include/cppgc/default-platform.h b/deps/v8/include/cppgc/default-platform.h index a27871cc..07ce55bb 100644 --- a/deps/v8/include/cppgc/default-platform.h +++ b/deps/v8/include/cppgc/default-platform.h @@ -37,11 +37,12 @@ class V8_EXPORT DefaultPlatform : public Platform { return v8_platform_->MonotonicallyIncreasingTime(); } - std::shared_ptr GetForegroundTaskRunner() override { + std::shared_ptr GetForegroundTaskRunner( + TaskPriority priority) override { // V8's default platform creates a new task runner when passed the // `v8::Isolate` pointer the first time. For non-default platforms this will // require getting the appropriate task runner. - return v8_platform_->GetForegroundTaskRunner(kNoIsolate); + return v8_platform_->GetForegroundTaskRunner(kNoIsolate, priority); } std::unique_ptr PostJob( diff --git a/deps/v8/include/cppgc/garbage-collected.h b/deps/v8/include/cppgc/garbage-collected.h index 6737c8be..dfd758a3 100644 --- a/deps/v8/include/cppgc/garbage-collected.h +++ b/deps/v8/include/cppgc/garbage-collected.h @@ -94,6 +94,14 @@ class GarbageCollectedMixin { public: using IsGarbageCollectedMixinTypeMarker = void; + // Must use MakeGarbageCollected. + void* operator new(size_t) = delete; + void* operator new[](size_t) = delete; + // The garbage collector is taking care of reclaiming the object. + // Not override the non-array varaint of `delete` to not conflict with the + // operator in GarbageCollected above. + void operator delete[](void*) = delete; + /** * This Trace method must be overriden by objects inheriting from * GarbageCollectedMixin. diff --git a/deps/v8/include/cppgc/heap-consistency.h b/deps/v8/include/cppgc/heap-consistency.h index eb7fdaee..23b5d909 100644 --- a/deps/v8/include/cppgc/heap-consistency.h +++ b/deps/v8/include/cppgc/heap-consistency.h @@ -114,7 +114,7 @@ class HeapConsistency final { * has not yet been processed. * * \param params The parameters retrieved from `GetWriteBarrierType()`. - * \param object The pointer to the object. May be an interior pointer to a + * \param object The pointer to the object. May be an interior pointer to * an interface of the actual object. */ static V8_INLINE void DijkstraWriteBarrier(const WriteBarrierParams& params, diff --git a/deps/v8/include/cppgc/internal/compiler-specific.h b/deps/v8/include/cppgc/internal/compiler-specific.h index 595b6398..175156ca 100644 --- a/deps/v8/include/cppgc/internal/compiler-specific.h +++ b/deps/v8/include/cppgc/internal/compiler-specific.h @@ -5,6 +5,8 @@ #ifndef INCLUDE_CPPGC_INTERNAL_COMPILER_SPECIFIC_H_ #define INCLUDE_CPPGC_INTERNAL_COMPILER_SPECIFIC_H_ +#include "v8config.h" // NOLINT(build/include_directory) + namespace cppgc { #if defined(__has_attribute) @@ -21,7 +23,13 @@ namespace cppgc { // [[no_unique_address]] comes in C++20 but supported in clang with -std >= // c++11. -#if CPPGC_HAS_CPP_ATTRIBUTE(no_unique_address) +#if defined(V8_CC_MSVC) && CPPGC_HAS_CPP_ATTRIBUTE(msvc::no_unique_address) +// Unfortunately MSVC ignores [[no_unique_address]] (see +// https://devblogs.microsoft.com/cppblog/msvc-cpp20-and-the-std-cpp20-switch/#msvc-extensions-and-abi), +// and clang-cl matches it for ABI compatibility reasons. We need to prefer +// [[msvc::no_unique_address]] when available if we actually want any effect. +#define CPPGC_NO_UNIQUE_ADDRESS [[msvc::no_unique_address]] +#elif CPPGC_HAS_CPP_ATTRIBUTE(no_unique_address) #define CPPGC_NO_UNIQUE_ADDRESS [[no_unique_address]] #else #define CPPGC_NO_UNIQUE_ADDRESS diff --git a/deps/v8/include/cppgc/name-provider.h b/deps/v8/include/cppgc/name-provider.h index ec512441..849176fd 100644 --- a/deps/v8/include/cppgc/name-provider.h +++ b/deps/v8/include/cppgc/name-provider.h @@ -55,6 +55,9 @@ class V8_EXPORT NameProvider { * Specifies a name for the garbage-collected object. Such names will never * be hidden, as they are explicitly specified by the user of this API. * + * Implementations of this function must not allocate garbage-collected + * objects or otherwise modify the cppgc heap. + * * V8 may call this function while generating a heap snapshot or at other * times. If V8 is currently generating a heap snapshot (according to * HeapProfiler::IsTakingSnapshot), then the returned string must stay alive diff --git a/deps/v8/include/cppgc/platform.h b/deps/v8/include/cppgc/platform.h index ae96579d..a5eccfa8 100644 --- a/deps/v8/include/cppgc/platform.h +++ b/deps/v8/include/cppgc/platform.h @@ -52,6 +52,15 @@ class V8_EXPORT Platform { * Foreground task runner that should be used by a Heap. */ virtual std::shared_ptr GetForegroundTaskRunner() { + return GetForegroundTaskRunner(TaskPriority::kUserBlocking); + } + + /** + * Returns a TaskRunner with a specific |priority| which can be used to post a + * task on the foreground thread. + */ + virtual std::shared_ptr GetForegroundTaskRunner( + TaskPriority priority) { return nullptr; } diff --git a/deps/v8/include/js_protocol.pdl b/deps/v8/include/js_protocol.pdl index 8dad9c98..b106a709 100644 --- a/deps/v8/include/js_protocol.pdl +++ b/deps/v8/include/js_protocol.pdl @@ -606,7 +606,6 @@ domain Debugger properties # Type of the debug symbols. enum type - None SourceMap EmbeddedDWARF ExternalDWARF @@ -689,8 +688,8 @@ domain Debugger experimental optional integer codeOffset # The language of the script. experimental optional Debugger.ScriptLanguage scriptLanguage - # If the scriptLanguage is WebASsembly, the source of debug symbols for the module. - experimental optional Debugger.DebugSymbols debugSymbols + # If the scriptLanguage is WebAssembly, the source of debug symbols for the module. + experimental optional array of Debugger.DebugSymbols debugSymbols # The name the embedder supplied for this script. experimental optional string embedderName diff --git a/deps/v8/include/v8-callbacks.h b/deps/v8/include/v8-callbacks.h index 60963012..567b36fa 100644 --- a/deps/v8/include/v8-callbacks.h +++ b/deps/v8/include/v8-callbacks.h @@ -254,15 +254,7 @@ using AddCrashKeyCallback = void (*)(CrashKeyId id, const std::string& value); using BeforeCallEnteredCallback = void (*)(Isolate*); using CallCompletedCallback = void (*)(Isolate*); -// --- AllowCodeGenerationFromStrings callbacks --- - -/** - * Callback to check if code generation from strings is allowed. See - * Context::AllowCodeGenerationFromStrings. - */ -using AllowCodeGenerationFromStringsCallback = bool (*)(Local context, - Local source); - +// --- Modify Code Generation From Strings Callback --- struct ModifyCodeGenerationFromStringsResult { // If true, proceed with the codegen algorithm. Otherwise, block it. bool codegen_allowed = false; @@ -272,6 +264,20 @@ struct ModifyCodeGenerationFromStringsResult { MaybeLocal modified_source; }; +/** + * Callback to check if codegen is allowed from a source object, and convert + * the source to string if necessary. See: ModifyCodeGenerationFromStrings. + */ +using ModifyCodeGenerationFromStringsCallback = + ModifyCodeGenerationFromStringsResult (*)(Local context, + Local source); +using ModifyCodeGenerationFromStringsCallback2 = + ModifyCodeGenerationFromStringsResult (*)(Local context, + Local source, + bool is_code_like); + +// --- Failed Access Check Callback --- + /** * Access type specification. */ @@ -283,23 +289,9 @@ enum AccessType { ACCESS_KEYS }; -// --- Failed Access Check Callback --- - using FailedAccessCheckCallback = void (*)(Local target, AccessType type, Local data); -/** - * Callback to check if codegen is allowed from a source object, and convert - * the source to string if necessary. See: ModifyCodeGenerationFromStrings. - */ -using ModifyCodeGenerationFromStringsCallback = - ModifyCodeGenerationFromStringsResult (*)(Local context, - Local source); -using ModifyCodeGenerationFromStringsCallback2 = - ModifyCodeGenerationFromStringsResult (*)(Local context, - Local source, - bool is_code_like); - // --- WebAssembly compilation callbacks --- using ExtensionCallback = bool (*)(const FunctionCallbackInfo&); @@ -359,7 +351,7 @@ enum class ModuleImportPhase { * The import_attributes are import attributes for this request in the form: * [key1, value1, key2, value2, ...] where the keys and values are of type * v8::String. Note, unlike the FixedArray passed to ResolveModuleCallback and - * returned from ModuleRequest::GetImportAssertions(), this array does not + * returned from ModuleRequest::GetImportAttributes(), this array does not * contain the source Locations of the attributes. * * The embedder must compile, instantiate, evaluate the Module, and diff --git a/deps/v8/include/v8-context.h b/deps/v8/include/v8-context.h index f432ff67..0861d664 100644 --- a/deps/v8/include/v8-context.h +++ b/deps/v8/include/v8-context.h @@ -320,7 +320,7 @@ class V8_EXPORT Context : public Data { * 'Function' constructor are used an exception will be thrown. * * If code generation from strings is not allowed the - * V8::AllowCodeGenerationFromStrings callback will be invoked if + * V8::ModifyCodeGenerationFromStringsCallback callback will be invoked if * set before blocking the call to 'eval' or the 'Function' * constructor. If that callback returns true, the call will be * allowed, otherwise an exception will be thrown. If no callback is diff --git a/deps/v8/include/v8-debug.h b/deps/v8/include/v8-debug.h index 52255f37..55ee9381 100644 --- a/deps/v8/include/v8-debug.h +++ b/deps/v8/include/v8-debug.h @@ -130,6 +130,11 @@ class V8_EXPORT StackTrace { kDetailed = kOverview | kIsEval | kIsConstructor | kScriptNameOrSourceURL }; + /** + * Returns the (unique) ID of this stack trace. + */ + int GetID() const; + /** * Returns a StackFrame at a particular index. */ diff --git a/deps/v8/include/v8-fast-api-calls.h b/deps/v8/include/v8-fast-api-calls.h index 1cd99cb8..18466688 100644 --- a/deps/v8/include/v8-fast-api-calls.h +++ b/deps/v8/include/v8-fast-api-calls.h @@ -589,37 +589,10 @@ struct FastApiCallbackOptions { v8::Isolate* isolate = nullptr; - /** - * If the callback wants to signal an error condition or to perform an - * allocation, it must set options.fallback to true and do an early return - * from the fast method. Then V8 checks the value of options.fallback and if - * it's true, falls back to executing the SlowCallback, which is capable of - * reporting the error (either by throwing a JS exception or logging to the - * console) or doing the allocation. It's the embedder's responsibility to - * ensure that the fast callback is idempotent up to the point where error and - * fallback conditions are checked, because otherwise executing the slow - * callback might produce visible side-effects twice. - */ - V8_DEPRECATED( - "It is not necessary to use the `fallback` flag anymore, as it is " - "possible now to trigger GC, throw exceptions, and call back into " - "JavaScript even in API functions called with a fast API call.") - bool fallback = false; - /** * The `data` passed to the FunctionTemplate constructor, or `undefined`. */ v8::Local data; - - /** - * When called from WebAssembly, a view of the calling module's memory. - */ - V8_DEPRECATED( - "The wasm memory should either be provided as a field of the receiver, " - "the data object of the FunctionTemplate, or as a normal parameter of " - "the API function. Since regular API calls don't have this magic " - "`wasm_memory parameter, one of the options above should be possible.") - FastApiTypedArray* const wasm_memory = nullptr; }; namespace internal { diff --git a/deps/v8/include/v8-function-callback.h b/deps/v8/include/v8-function-callback.h index 7208c19e..9ff4c595 100644 --- a/deps/v8/include/v8-function-callback.h +++ b/deps/v8/include/v8-function-callback.h @@ -325,7 +325,7 @@ class PropertyCallbackInfo { static constexpr int kSize = kArgsLength * internal::kApiSystemPointerSize; - explicit PropertyCallbackInfo() = default; + PropertyCallbackInfo() = default; mutable internal::Address args_[kArgsLength]; }; diff --git a/deps/v8/include/v8-function.h b/deps/v8/include/v8-function.h index 50f730f3..d28d4b50 100644 --- a/deps/v8/include/v8-function.h +++ b/deps/v8/include/v8-function.h @@ -52,6 +52,10 @@ class V8_EXPORT Function : public Object { Local context, int argc, Local argv[], SideEffectType side_effect_type = SideEffectType::kHasSideEffect) const; + V8_WARN_UNUSED_RESULT MaybeLocal Call(v8::Isolate* isolate, + Local context, + Local recv, int argc, + Local argv[]); V8_WARN_UNUSED_RESULT MaybeLocal Call(Local context, Local recv, int argc, Local argv[]); diff --git a/deps/v8/include/v8-handle-base.h b/deps/v8/include/v8-handle-base.h index c2e1947a..3075441e 100644 --- a/deps/v8/include/v8-handle-base.h +++ b/deps/v8/include/v8-handle-base.h @@ -90,7 +90,7 @@ class IndirectHandleBase { internal::Address* location_ = nullptr; }; -#ifdef V8_ENABLE_DIRECT_LOCAL +#ifdef V8_ENABLE_DIRECT_HANDLE /** * A base class for abstract handles containing direct pointers. @@ -130,7 +130,7 @@ class DirectHandleBase { internal::Address ptr_ = internal::ValueHelper::kEmpty; }; -#endif // V8_ENABLE_DIRECT_LOCAL +#endif // V8_ENABLE_DIRECT_HANDLE } // namespace v8::api_internal diff --git a/deps/v8/include/v8-initialization.h b/deps/v8/include/v8-initialization.h index c3984668..46a21a02 100644 --- a/deps/v8/include/v8-initialization.h +++ b/deps/v8/include/v8-initialization.h @@ -112,11 +112,18 @@ class V8_EXPORT V8 { const bool kV8TargetOsIsAndroid = false; #endif +#ifdef V8_ENABLE_CHECKS + const bool kV8EnableChecks = true; +#else + const bool kV8EnableChecks = false; +#endif + const int kBuildConfiguration = (internal::PointerCompressionIsEnabled() ? kPointerCompression : 0) | (internal::SmiValuesAre31Bits() ? k31BitSmis : 0) | (internal::SandboxIsEnabled() ? kSandbox : 0) | - (kV8TargetOsIsAndroid ? kTargetOsIsAndroid : 0); + (kV8TargetOsIsAndroid ? kTargetOsIsAndroid : 0) | + (kV8EnableChecks ? kEnableChecks : 0); return Initialize(kBuildConfiguration); } @@ -288,6 +295,7 @@ class V8_EXPORT V8 { k31BitSmis = 1 << 1, kSandbox = 1 << 2, kTargetOsIsAndroid = 1 << 3, + kEnableChecks = 1 << 4, }; /** diff --git a/deps/v8/include/v8-internal.h b/deps/v8/include/v8-internal.h index 8c385aa1..f81a2108 100644 --- a/deps/v8/include/v8-internal.h +++ b/deps/v8/include/v8-internal.h @@ -18,6 +18,22 @@ #include "v8config.h" // NOLINT(build/include_directory) +// TODO(pkasting): Use /spaceship unconditionally after dropping +// support for old libstdc++ versions. +#if __has_include() +#include +#endif +#if defined(__cpp_lib_three_way_comparison) && \ + __cpp_lib_three_way_comparison >= 201711L && \ + defined(__cpp_lib_concepts) && __cpp_lib_concepts >= 202002L +#include +#include + +#define V8_HAVE_SPACESHIP_OPERATOR 1 +#else +#define V8_HAVE_SPACESHIP_OPERATOR 0 +#endif + namespace v8 { class Array; @@ -144,15 +160,15 @@ struct SmiTagging<8> { std::is_signed_v>* = nullptr> V8_INLINE static constexpr bool IsValidSmi(T value) { // To be representable as a long smi, the value must be a 32-bit integer. - return (value == static_cast(value)); + return std::numeric_limits::min() <= value && + value <= std::numeric_limits::max(); } template && std::is_unsigned_v>* = nullptr> V8_INLINE static constexpr bool IsValidSmi(T value) { - return (static_cast(value) == - static_cast(static_cast(value))); + return value <= std::numeric_limits::max(); } }; @@ -295,7 +311,8 @@ constexpr size_t kExternalPointerTableReservationSize = 256 * MB; // The external pointer table indices stored in HeapObjects as external // pointers are shifted to the left by this amount to guarantee that they are -// smaller than the maximum table size. +// smaller than the maximum table size even after the C++ compiler multiplies +// them by 8 to be used as indexes into a table of 64 bit pointers. constexpr uint32_t kExternalPointerIndexShift = 7; #else constexpr size_t kExternalPointerTableReservationSize = 512 * MB; @@ -946,12 +963,10 @@ class Internals { kIsolateCppHeapPointerTableOffset + kExternalPointerTableSize; static const int kIsolateTrustedPointerTableOffset = kIsolateTrustedCageBaseOffset + kApiSystemPointerSize; - static const int kIsolateExternalBufferTableOffset = + static const int kIsolateSharedTrustedPointerTableAddressOffset = kIsolateTrustedPointerTableOffset + kTrustedPointerTableSize; - static const int kIsolateSharedExternalBufferTableAddressOffset = - kIsolateExternalBufferTableOffset + kExternalBufferTableSize; static const int kIsolateApiCallbackThunkArgumentOffset = - kIsolateSharedExternalBufferTableAddressOffset + kApiSystemPointerSize; + kIsolateSharedTrustedPointerTableAddressOffset + kApiSystemPointerSize; #else static const int kIsolateApiCallbackThunkArgumentOffset = kIsolateCppHeapPointerTableOffset + kExternalPointerTableSize; @@ -978,7 +993,7 @@ class Internals { V(TrueValue, 0xc9) \ V(FalseValue, 0xad) \ V(EmptyString, 0xa1) \ - V(TheHoleValue, 0x741) + V(TheHoleValue, 0x791) using Tagged_t = uint32_t; struct StaticReadOnlyRoot { @@ -986,8 +1001,9 @@ class Internals { EXPORTED_STATIC_ROOTS_PTR_LIST(DEF_ROOT) #undef DEF_ROOT - static constexpr Tagged_t kFirstStringMap = 0xe5; - static constexpr Tagged_t kLastStringMap = 0x47d; + // Use 0 for kStringMapLowerBound since string maps are the first maps. + static constexpr Tagged_t kStringMapLowerBound = 0; + static constexpr Tagged_t kStringMapUpperBound = 0x47d; #define PLUSONE(...) +1 static constexpr size_t kNumberOfExportedStaticRoots = @@ -1354,11 +1370,11 @@ class V8_EXPORT StrongRootAllocatorBase { public: Heap* heap() const { return heap_; } - bool operator==(const StrongRootAllocatorBase& other) const { - return heap_ == other.heap_; - } - bool operator!=(const StrongRootAllocatorBase& other) const { - return heap_ != other.heap_; + friend bool operator==(const StrongRootAllocatorBase& a, + const StrongRootAllocatorBase& b) { + // TODO(pkasting): Replace this body with `= default` after dropping support + // for old gcc versions. + return a.heap_ == b.heap_; } protected: @@ -1393,22 +1409,60 @@ class StrongRootAllocator : private std::allocator { using std::allocator::deallocate; }; +// TODO(pkasting): Replace with `requires` clauses after dropping support for +// old gcc versions. +template +inline constexpr bool kHaveIteratorConcept = false; +template +inline constexpr bool kHaveIteratorConcept< + Iterator, std::void_t> = true; + +template +inline constexpr bool kHaveIteratorCategory = false; +template +inline constexpr bool kHaveIteratorCategory< + Iterator, std::void_t> = true; + +// Helper struct that contains an `iterator_concept` type alias only when either +// `Iterator` or `std::iterator_traits` do. +// Default: no alias. +template +struct MaybeDefineIteratorConcept {}; +// Use `Iterator::iterator_concept` if available. +template +struct MaybeDefineIteratorConcept< + Iterator, std::enable_if_t>> { + using iterator_concept = Iterator::iterator_concept; +}; +// Otherwise fall back to `std::iterator_traits` if possible. +template +struct MaybeDefineIteratorConcept< + Iterator, std::enable_if_t && + !kHaveIteratorConcept>> { + // There seems to be no feature-test macro covering this, so use the + // presence of `` as a crude proxy, since it was added to the + // standard as part of the Ranges papers. + // TODO(pkasting): Add this unconditionally after dropping support for old + // libstdc++ versions. +#if __has_include() + using iterator_concept = std::iterator_traits::iterator_concept; +#endif +}; + // A class of iterators that wrap some different iterator type. // If specified, ElementType is the type of element accessed by the wrapper // iterator; in this case, the actual reference and pointer types of Iterator // must be convertible to ElementType& and ElementType*, respectively. template -class WrappedIterator { +class WrappedIterator : public MaybeDefineIteratorConcept { public: static_assert( - !std::is_void_v || + std::is_void_v || (std::is_convertible_v::pointer, - ElementType*> && + std::add_pointer_t> && std::is_convertible_v::reference, - ElementType&>)); + std::add_lvalue_reference_t>)); - using iterator_category = - typename std::iterator_traits::iterator_category; using difference_type = typename std::iterator_traits::difference_type; using value_type = @@ -1418,24 +1472,96 @@ class WrappedIterator { using pointer = std::conditional_t, typename std::iterator_traits::pointer, - ElementType*>; + std::add_pointer_t>; using reference = std::conditional_t, typename std::iterator_traits::reference, - ElementType&>; + std::add_lvalue_reference_t>; + using iterator_category = + typename std::iterator_traits::iterator_category; - constexpr WrappedIterator() noexcept : it_() {} + constexpr WrappedIterator() noexcept = default; constexpr explicit WrappedIterator(Iterator it) noexcept : it_(it) {} + // TODO(pkasting): Switch to `requires` and concepts after dropping support + // for old gcc and libstdc++ versions. template , - bool> = true> + typename = std::enable_if_t< + std::is_convertible_v>> constexpr WrappedIterator( - const WrappedIterator& it) noexcept - : it_(it.base()) {} + const WrappedIterator& other) noexcept + : it_(other.base()) {} - constexpr reference operator*() const noexcept { return *it_; } - constexpr pointer operator->() const noexcept { return it_.operator->(); } + [[nodiscard]] constexpr reference operator*() const noexcept { return *it_; } + [[nodiscard]] constexpr pointer operator->() const noexcept { + return it_.operator->(); + } + + template + [[nodiscard]] constexpr bool operator==( + const WrappedIterator& other) + const noexcept { + return it_ == other.base(); + } +#if V8_HAVE_SPACESHIP_OPERATOR + template + [[nodiscard]] constexpr auto operator<=>( + const WrappedIterator& other) + const noexcept { + if constexpr (std::three_way_comparable_with) { + return it_ <=> other.base(); + } else if constexpr (std::totally_ordered_with) { + if (it_ < other.base()) { + return std::strong_ordering::less; + } + return (it_ > other.base()) ? std::strong_ordering::greater + : std::strong_ordering::equal; + } else { + if (it_ < other.base()) { + return std::partial_ordering::less; + } + if (other.base() < it_) { + return std::partial_ordering::greater; + } + return (it_ == other.base()) ? std::partial_ordering::equivalent + : std::partial_ordering::unordered; + } + } +#else + // Assume that if spaceship isn't present, operator rewriting might not be + // either. + template + [[nodiscard]] constexpr bool operator!=( + const WrappedIterator& other) + const noexcept { + return it_ != other.base(); + } + + template + [[nodiscard]] constexpr bool operator<( + const WrappedIterator& other) + const noexcept { + return it_ < other.base(); + } + template + [[nodiscard]] constexpr bool operator<=( + const WrappedIterator& other) + const noexcept { + return it_ <= other.base(); + } + template + [[nodiscard]] constexpr bool operator>( + const WrappedIterator& other) + const noexcept { + return it_ > other.base(); + } + template + [[nodiscard]] constexpr bool operator>=( + const WrappedIterator& other) + const noexcept { + return it_ >= other.base(); + } +#endif constexpr WrappedIterator& operator++() noexcept { ++it_; @@ -1456,112 +1582,55 @@ class WrappedIterator { --(*this); return result; } - constexpr WrappedIterator operator+(difference_type n) const noexcept { + [[nodiscard]] constexpr WrappedIterator operator+( + difference_type n) const noexcept { WrappedIterator result(*this); result += n; return result; } + [[nodiscard]] friend constexpr WrappedIterator operator+( + difference_type n, const WrappedIterator& x) noexcept { + return x + n; + } constexpr WrappedIterator& operator+=(difference_type n) noexcept { it_ += n; return *this; } - constexpr WrappedIterator operator-(difference_type n) const noexcept { - return *this + (-n); + [[nodiscard]] constexpr WrappedIterator operator-( + difference_type n) const noexcept { + return *this + -n; } constexpr WrappedIterator& operator-=(difference_type n) noexcept { - *this += -n; - return *this; + return *this += -n; } - constexpr reference operator[](difference_type n) const noexcept { + template + [[nodiscard]] constexpr auto operator-( + const WrappedIterator& other) + const noexcept { + return it_ - other.base(); + } + [[nodiscard]] constexpr reference operator[]( + difference_type n) const noexcept { return it_[n]; } - constexpr Iterator base() const noexcept { return it_; } - - private: - template - friend class WrappedIterator; + [[nodiscard]] constexpr const Iterator& base() const noexcept { return it_; } private: Iterator it_; }; -template -constexpr bool operator==( - const WrappedIterator& x, - const WrappedIterator& y) noexcept { - return x.base() == y.base(); -} - -template -constexpr bool operator<( - const WrappedIterator& x, - const WrappedIterator& y) noexcept { - return x.base() < y.base(); -} - -template -constexpr bool operator!=( - const WrappedIterator& x, - const WrappedIterator& y) noexcept { - return !(x == y); -} - -template -constexpr bool operator>( - const WrappedIterator& x, - const WrappedIterator& y) noexcept { - return y < x; -} - -template -constexpr bool operator>=( - const WrappedIterator& x, - const WrappedIterator& y) noexcept { - return !(x < y); -} - -template -constexpr bool operator<=( - const WrappedIterator& x, - const WrappedIterator& y) noexcept { - return !(y < x); -} - -template -constexpr auto operator-( - const WrappedIterator& x, - const WrappedIterator& y) noexcept - -> decltype(x.base() - y.base()) { - return x.base() - y.base(); -} - -template -constexpr WrappedIterator operator+( - typename WrappedIterator::difference_type n, - const WrappedIterator& x) noexcept { - x += n; - return x; -} - // Helper functions about values contained in handles. // A value is either an indirect pointer or a direct pointer, depending on // whether direct local support is enabled. class ValueHelper final { public: -#ifdef V8_ENABLE_DIRECT_LOCAL +#ifdef V8_ENABLE_DIRECT_HANDLE static constexpr Address kTaggedNullAddress = 1; static constexpr Address kEmpty = kTaggedNullAddress; #else static constexpr Address kEmpty = kNullAddress; -#endif // V8_ENABLE_DIRECT_LOCAL +#endif // V8_ENABLE_DIRECT_HANDLE template V8_INLINE static bool IsEmpty(T* value) { @@ -1577,7 +1646,7 @@ class ValueHelper final { return handle.template value(); } -#ifdef V8_ENABLE_DIRECT_LOCAL +#ifdef V8_ENABLE_DIRECT_HANDLE template V8_INLINE static Address ValueAsAddress(const T* value) { @@ -1592,7 +1661,7 @@ class ValueHelper final { return *reinterpret_cast(slot); } -#else // !V8_ENABLE_DIRECT_LOCAL +#else // !V8_ENABLE_DIRECT_HANDLE template V8_INLINE static Address ValueAsAddress(const T* value) { @@ -1604,7 +1673,7 @@ class ValueHelper final { return reinterpret_cast(slot); } -#endif // V8_ENABLE_DIRECT_LOCAL +#endif // V8_ENABLE_DIRECT_HANDLE }; /** diff --git a/deps/v8/include/v8-isolate.h b/deps/v8/include/v8-isolate.h index 17c10776..54571391 100644 --- a/deps/v8/include/v8-isolate.h +++ b/deps/v8/include/v8-isolate.h @@ -9,6 +9,7 @@ #include #include +#include #include #include "cppgc/common.h" @@ -547,6 +548,7 @@ class V8_EXPORT Isolate { kDocumentAllLegacyCall = 141, kDocumentAllLegacyConstruct = 142, kConsoleContext = 143, + kWasmImportedStringsUtf8 = 144, // If you add new values here, you'll also need to update Chromium's: // web_feature.mojom, use_counter_callback.cc, and enums.xml. V8 changes to @@ -936,6 +938,12 @@ class V8_EXPORT Isolate { */ Local GetIncumbentContext(); + /** + * Returns the host defined options set for currently running script or + * module, if available. + */ + MaybeLocal GetCurrentHostDefinedOptions(); + /** * Schedules a v8::Exception::Error with the given message. * See ThrowException for more details. Templatized to provide compile-time @@ -1717,6 +1725,12 @@ class V8_EXPORT Isolate { */ void LocaleConfigurationChangeNotification(); + /** + * Returns the default locale in a string if Intl support is enabled. + * Otherwise returns an empty string. + */ + std::string GetDefaultLocale(); + Isolate() = delete; ~Isolate() = delete; Isolate(const Isolate&) = delete; @@ -1733,7 +1747,7 @@ class V8_EXPORT Isolate { friend class PersistentValueMapBase; internal::Address* GetDataFromSnapshotOnce(size_t index); - void ReportExternalAllocationLimitReached(); + void HandleExternalMemoryInterrupt(); }; void Isolate::SetData(uint32_t slot, void* data) { diff --git a/deps/v8/include/v8-local-handle.h b/deps/v8/include/v8-local-handle.h index 98feeeba..476b80a6 100644 --- a/deps/v8/include/v8-local-handle.h +++ b/deps/v8/include/v8-local-handle.h @@ -150,11 +150,11 @@ class V8_EXPORT V8_NODISCARD HandleScope { /** * A base class for local handles. - * Its implementation depends on whether direct local support is enabled. + * Its implementation depends on whether direct handle support is enabled. * When it is, a local handle contains a direct pointer to the referenced * object, otherwise it contains an indirect pointer. */ -#ifdef V8_ENABLE_DIRECT_LOCAL +#ifdef V8_ENABLE_DIRECT_HANDLE template class LocalBase : public api_internal::DirectHandleBase { @@ -183,7 +183,7 @@ class LocalBase : public api_internal::DirectHandleBase { } }; -#else // !V8_ENABLE_DIRECT_LOCAL +#else // !V8_ENABLE_DIRECT_HANDLE template class LocalBase : public api_internal::IndirectHandleBase { @@ -215,7 +215,7 @@ class LocalBase : public api_internal::IndirectHandleBase { } }; -#endif // V8_ENABLE_DIRECT_LOCAL +#endif // V8_ENABLE_DIRECT_HANDLE /** * An object reference managed by the v8 garbage collector. @@ -400,13 +400,13 @@ class V8_TRIVIAL_ABI Local : public LocalBase, return Local(LocalBase::FromSlot(slot)); } -#ifdef V8_ENABLE_DIRECT_LOCAL +#ifdef V8_ENABLE_DIRECT_HANDLE friend class TypecheckWitness; V8_INLINE static Local FromAddress(internal::Address ptr) { return Local(LocalBase(ptr)); } -#endif // V8_ENABLE_DIRECT_LOCAL +#endif // V8_ENABLE_DIRECT_HANDLE V8_INLINE static Local New(Isolate* isolate, internal::Address value) { return Local(LocalBase::New(isolate, value)); @@ -434,8 +434,9 @@ class V8_TRIVIAL_ABI LocalUnchecked : public Local { #if defined(V8_ENABLE_LOCAL_OFF_STACK_CHECK) && V8_HAS_ATTRIBUTE_TRIVIAL_ABI // In this case, the check is also enforced in the copy constructor and we // need to suppress it. - LocalUnchecked(const LocalUnchecked& other) - : Local(other, Local::do_not_check) noexcept {} + LocalUnchecked( + const LocalUnchecked& other) noexcept // NOLINT(runtime/explicit) + : Local(other, Local::do_not_check) {} LocalUnchecked& operator=(const LocalUnchecked&) noexcept = default; #endif @@ -444,7 +445,7 @@ class V8_TRIVIAL_ABI LocalUnchecked : public Local { : Local(other, Local::do_not_check) {} }; -#ifdef V8_ENABLE_DIRECT_LOCAL +#ifdef V8_ENABLE_DIRECT_HANDLE // Off-stack allocated direct locals must be registered as strong roots. // For off-stack indirect locals, this is not necessary. @@ -471,7 +472,7 @@ class StrongRootAllocator> : public StrongRootAllocatorBase { return deallocate_impl(reinterpret_cast(p), n); } }; -#endif // V8_ENABLE_DIRECT_LOCAL +#endif // V8_ENABLE_DIRECT_HANDLE } // namespace internal template @@ -479,7 +480,7 @@ class LocalVector { private: using element_type = internal::LocalUnchecked; -#ifdef V8_ENABLE_DIRECT_LOCAL +#ifdef V8_ENABLE_DIRECT_HANDLE using allocator_type = internal::StrongRootAllocator; static allocator_type make_allocator(Isolate* isolate) noexcept { @@ -491,7 +492,7 @@ class LocalVector { static allocator_type make_allocator(Isolate* isolate) noexcept { return allocator_type(); } -#endif // V8_ENABLE_DIRECT_LOCAL +#endif // V8_ENABLE_DIRECT_HANDLE using vector_type = std::vector; @@ -715,7 +716,7 @@ class V8_EXPORT V8_NODISCARD EscapableHandleScope V8_INLINE ~EscapableHandleScope() = default; template V8_INLINE Local Escape(Local value) { -#ifdef V8_ENABLE_DIRECT_LOCAL +#ifdef V8_ENABLE_DIRECT_HANDLE return value; #else if (value.IsEmpty()) return value; diff --git a/deps/v8/include/v8-memory-span.h b/deps/v8/include/v8-memory-span.h index a7614cf7..7556b20f 100644 --- a/deps/v8/include/v8-memory-span.h +++ b/deps/v8/include/v8-memory-span.h @@ -13,6 +13,40 @@ #include "v8config.h" // NOLINT(build/include_directory) +// TODO(pkasting): Use /spaceship unconditionally after dropping +// support for old libstdc++ versions. +#if __has_include() +#include +#endif +#if defined(__cpp_lib_three_way_comparison) && \ + __cpp_lib_three_way_comparison >= 201711L +#define V8_HAVE_SPACESHIP_OPERATOR 1 +#else +#define V8_HAVE_SPACESHIP_OPERATOR 0 +#endif + +// TODO(pkasting): Make this block unconditional after dropping support for old +// libstdc++ versions. +#if __has_include() +#include + +namespace v8 { + +template +class V8_EXPORT MemorySpan; + +} // namespace v8 + +// Mark `MemorySpan` as satisfying the `view` and `borrowed_range` concepts. +// This should be done before the definition of `MemorySpan`, so that any +// inlined calls to range functionality use the correct specializations. +template +inline constexpr bool std::ranges::enable_view> = true; +template +inline constexpr bool std::ranges::enable_borrowed_range> = + true; +#endif + namespace v8 { /** @@ -53,13 +87,13 @@ class V8_EXPORT MemorySpan { is_compatible_iterator::value; template - static constexpr U* to_address(U* p) noexcept { + [[nodiscard]] static constexpr U* to_address(U* p) noexcept { return p; } template ().operator->())>> - static constexpr auto to_address(It it) noexcept { + [[nodiscard]] static constexpr auto to_address(It it) noexcept { return it.operator->(); } @@ -108,50 +142,139 @@ class V8_EXPORT MemorySpan { : data_(a.data()), size_{N} {} /** Returns a pointer to the beginning of the buffer. */ - constexpr T* data() const { return data_; } + [[nodiscard]] constexpr T* data() const { return data_; } /** Returns the number of elements that the buffer holds. */ - constexpr size_t size() const { return size_; } + [[nodiscard]] constexpr size_t size() const { return size_; } - constexpr T& operator[](size_t i) const { return data_[i]; } + [[nodiscard]] constexpr T& operator[](size_t i) const { return data_[i]; } /** Returns true if the buffer is empty. */ - constexpr bool empty() const { return size() == 0; } + [[nodiscard]] constexpr bool empty() const { return size() == 0; } class Iterator { public: - using iterator_category = std::forward_iterator_tag; - using value_type = T; using difference_type = std::ptrdiff_t; + using value_type = T; using pointer = value_type*; using reference = value_type&; + using iterator_category = std::random_access_iterator_tag; + // There seems to be no feature-test macro covering this, so use the + // presence of `` as a crude proxy, since it was added to the + // standard as part of the Ranges papers. + // TODO(pkasting): Add this unconditionally after dropping support for old + // libstdc++ versions. +#if __has_include() + using iterator_concept = std::contiguous_iterator_tag; +#endif + + // Required to satisfy `std::semiregular<>`. + constexpr Iterator() = default; + + [[nodiscard]] friend constexpr bool operator==(const Iterator& a, + const Iterator& b) { + // TODO(pkasting): Replace this body with `= default` after dropping + // support for old gcc versions. + return a.ptr_ == b.ptr_; + } +#if V8_HAVE_SPACESHIP_OPERATOR + [[nodiscard]] friend constexpr auto operator<=>(const Iterator&, + const Iterator&) = default; +#else + // Assume that if spaceship isn't present, operator rewriting might not be + // either. + [[nodiscard]] friend constexpr bool operator!=(const Iterator& a, + const Iterator& b) { + return a.ptr_ != b.ptr_; + } - T& operator*() const { return *ptr_; } - T* operator->() const { return ptr_; } - - bool operator==(Iterator other) const { return ptr_ == other.ptr_; } - bool operator!=(Iterator other) const { return !(*this == other); } + [[nodiscard]] friend constexpr bool operator<(const Iterator& a, + const Iterator& b) { + return a.ptr_ < b.ptr_; + } + [[nodiscard]] friend constexpr bool operator<=(const Iterator& a, + const Iterator& b) { + return a.ptr_ <= b.ptr_; + } + [[nodiscard]] friend constexpr bool operator>(const Iterator& a, + const Iterator& b) { + return a.ptr_ > b.ptr_; + } + [[nodiscard]] friend constexpr bool operator>=(const Iterator& a, + const Iterator& b) { + return a.ptr_ >= b.ptr_; + } +#endif - Iterator& operator++() { + constexpr Iterator& operator++() { ++ptr_; return *this; } - Iterator operator++(int) { - Iterator temp(*this); - ++(*this); + constexpr Iterator operator++(int) { + Iterator temp = *this; + ++*this; return temp; } + constexpr Iterator& operator--() { + --ptr_; + return *this; + } + + constexpr Iterator operator--(int) { + Iterator temp = *this; + --*this; + return temp; + } + + constexpr Iterator& operator+=(difference_type rhs) { + ptr_ += rhs; + return this; + } + + [[nodiscard]] friend constexpr Iterator operator+(Iterator lhs, + difference_type rhs) { + lhs += rhs; + return lhs; + } + + [[nodiscard]] friend constexpr Iterator operator+(difference_type lhs, + const Iterator& rhs) { + return rhs + lhs; + } + + constexpr Iterator& operator-=(difference_type rhs) { + ptr_ -= rhs; + return this; + } + + [[nodiscard]] friend constexpr Iterator operator-(Iterator lhs, + difference_type rhs) { + lhs -= rhs; + return lhs; + } + + [[nodiscard]] friend constexpr difference_type operator-( + const Iterator& lhs, const Iterator& rhs) { + return lhs.ptr_ - rhs.ptr_; + } + + [[nodiscard]] constexpr reference operator*() const { return *ptr_; } + [[nodiscard]] constexpr pointer operator->() const { return ptr_; } + [[nodiscard]] constexpr reference operator[](size_t offset) const { + return ptr_[offset]; + } + private: friend class MemorySpan; - explicit Iterator(T* ptr) : ptr_(ptr) {} + constexpr explicit Iterator(T* ptr) : ptr_(ptr) {} T* ptr_ = nullptr; }; - Iterator begin() const { return Iterator(data_); } - Iterator end() const { return Iterator(data_ + size_); } + [[nodiscard]] Iterator begin() const { return Iterator(data_); } + [[nodiscard]] Iterator end() const { return Iterator(data_ + size_); } private: T* data_ = nullptr; @@ -171,25 +294,26 @@ class V8_EXPORT MemorySpan { namespace detail { template -constexpr std::array, N> to_array_lvalue_impl( +[[nodiscard]] constexpr std::array, N> to_array_lvalue_impl( T (&a)[N], std::index_sequence) { return {{a[I]...}}; } template -constexpr std::array, N> to_array_rvalue_impl( +[[nodiscard]] constexpr std::array, N> to_array_rvalue_impl( T (&&a)[N], std::index_sequence) { return {{std::move(a[I])...}}; } } // namespace detail template -constexpr std::array, N> to_array(T (&a)[N]) { +[[nodiscard]] constexpr std::array, N> to_array(T (&a)[N]) { return detail::to_array_lvalue_impl(a, std::make_index_sequence{}); } template -constexpr std::array, N> to_array(T (&&a)[N]) { +[[nodiscard]] constexpr std::array, N> to_array( + T (&&a)[N]) { return detail::to_array_rvalue_impl(std::move(a), std::make_index_sequence{}); } diff --git a/deps/v8/include/v8-metrics.h b/deps/v8/include/v8-metrics.h index 9e77744b..bf19dead 100644 --- a/deps/v8/include/v8-metrics.h +++ b/deps/v8/include/v8-metrics.h @@ -8,9 +8,11 @@ #include #include +#include #include #include "v8-internal.h" // NOLINT(build/include_directory) +#include "v8-isolate.h" // NOLINT(build/include_directory) #include "v8-local-handle.h" // NOLINT(build/include_directory) #include "v8config.h" // NOLINT(build/include_directory) @@ -37,6 +39,10 @@ struct GarbageCollectionSizes { struct GarbageCollectionFullCycle { int reason = -1; + // The priority of the isolate during the GC cycle. A nullopt value denotes a + // mixed priority cycle, meaning the Isolate's priority was changed while the + // cycle was in progress. + std::optional priority = std::nullopt; GarbageCollectionPhases total; GarbageCollectionPhases total_cpp; GarbageCollectionPhases main_thread; @@ -86,6 +92,10 @@ using GarbageCollectionFullMainThreadBatchedIncrementalSweep = struct GarbageCollectionYoungCycle { int reason = -1; + // The priority of the isolate during the GC cycle. A nullopt value denotes a + // mixed priority cycle, meaning the Isolate's priority was changed while the + // cycle was in progress. + std::optional priority = std::nullopt; int64_t total_wall_clock_duration_in_us = -1; int64_t main_thread_wall_clock_duration_in_us = -1; double collection_rate_in_percent = -1.0; diff --git a/deps/v8/include/v8-object.h b/deps/v8/include/v8-object.h index d03b33ac..71a6c2c9 100644 --- a/deps/v8/include/v8-object.h +++ b/deps/v8/include/v8-object.h @@ -690,14 +690,17 @@ class V8_EXPORT Object : public Value { int GetIdentityHash(); /** - * Clone this object with a fast but shallow copy. Values will point - * to the same values as the original object. + * Clone this object with a fast but shallow copy. Values will point to the + * same values as the original object. + * + * Prefer using version with Isolate parameter. */ - // TODO(dcarney): take an isolate and optionally bail out? + Local Clone(v8::Isolate* isolate); Local Clone(); /** * Returns the context in which the object was created. + * * Prefer using version with Isolate parameter. */ MaybeLocal GetCreationContext(v8::Isolate* isolate); @@ -705,6 +708,7 @@ class V8_EXPORT Object : public Value { /** * Shortcut for GetCreationContext(...).ToLocalChecked(). + * * Prefer using version with Isolate parameter. **/ Local GetCreationContextChecked(v8::Isolate* isolate); diff --git a/deps/v8/include/v8-platform.h b/deps/v8/include/v8-platform.h index 56bfd727..a3a93972 100644 --- a/deps/v8/include/v8-platform.h +++ b/deps/v8/include/v8-platform.h @@ -14,7 +14,7 @@ #include #include "v8-source-location.h" // NOLINT(build/include_directory) -#include "v8config.h" // NOLINT(build/include_directory) +#include "v8config.h" // NOLINT(build/include_directory) namespace v8 { @@ -79,9 +79,8 @@ class TaskRunner { * * Embedders should override PostTaskImpl instead of this. */ - void PostTask( - std::unique_ptr task, - const SourceLocation& location = SourceLocation::Current()) { + void PostTask(std::unique_ptr task, + const SourceLocation& location = SourceLocation::Current()) { PostTaskImpl(std::move(task), location); } @@ -553,6 +552,19 @@ class PageAllocator { */ virtual bool DecommitPages(void* address, size_t size) = 0; + /** + * Block any modifications to the given mapping such as changing permissions + * or unmapping the pages on supported platforms. + * The address space reservation will exist until the process ends, but it's + * possible to release the memory using DiscardSystemPages. Note that this + * might require write permissions to the page as e.g. on Linux, mseal will + * block discarding sealed anonymous memory. + */ + virtual bool SealPages(void* address, size_t length) { + // TODO(360048056): make it pure once it's implemented on Chromium side. + return false; + } + /** * INTERNAL ONLY: This interface has not been stabilised and may change * without notice from one release to another without being deprecated first. @@ -1027,18 +1039,6 @@ class VirtualAddressSpace { const PagePermissions max_page_permissions_; }; -/** - * V8 Allocator used for allocating zone backings. - */ -class ZoneBackingAllocator { - public: - using MallocFn = void* (*)(size_t); - using FreeFn = void (*)(void*); - - virtual MallocFn GetMallocFn() const { return ::malloc; } - virtual FreeFn GetFreeFn() const { return ::free; } -}; - /** * Observer used by V8 to notify the embedder about entering/leaving sections * with high throughput of malloc/free operations. @@ -1075,14 +1075,6 @@ class Platform { return nullptr; } - /** - * Allows the embedder to specify a custom allocator used for zones. - */ - virtual ZoneBackingAllocator* GetZoneBackingAllocator() { - static ZoneBackingAllocator default_allocator; - return &default_allocator; - } - /** * Enables the embedder to respond in cases where V8 can't allocate large * blocks of memory. V8 retries the failed allocation once after calling this @@ -1106,11 +1098,8 @@ class Platform { * Returns a TaskRunner which can be used to post a task on the foreground. * The TaskRunner's NonNestableTasksEnabled() must be true. This function * should only be called from a foreground thread. - * TODO(chromium:1448758): Deprecate once |GetForegroundTaskRunner(Isolate*, - * TaskPriority)| is ready. */ - virtual std::shared_ptr GetForegroundTaskRunner( - Isolate* isolate) { + std::shared_ptr GetForegroundTaskRunner(Isolate* isolate) { return GetForegroundTaskRunner(isolate, TaskPriority::kUserBlocking); } @@ -1118,12 +1107,9 @@ class Platform { * Returns a TaskRunner with a specific |priority| which can be used to post a * task on the foreground thread. The TaskRunner's NonNestableTasksEnabled() * must be true. This function should only be called from a foreground thread. - * TODO(chromium:1448758): Make pure virtual once embedders implement it. */ virtual std::shared_ptr GetForegroundTaskRunner( - Isolate* isolate, TaskPriority priority) { - return nullptr; - } + Isolate* isolate, TaskPriority priority) = 0; /** * Schedules a task to be invoked on a worker thread. diff --git a/deps/v8/include/v8-primitive.h b/deps/v8/include/v8-primitive.h index 1adb9cbc..426bb379 100644 --- a/deps/v8/include/v8-primitive.h +++ b/deps/v8/include/v8-primitive.h @@ -388,6 +388,8 @@ class V8_EXPORT String : public Name { * regardless of the encoding, otherwise return NULL. The encoding of the * string is returned in encoding_out. */ + V8_INLINE ExternalStringResourceBase* GetExternalStringResourceBase( + v8::Isolate* isolate, Encoding* encoding_out) const; V8_INLINE ExternalStringResourceBase* GetExternalStringResourceBase( Encoding* encoding_out) const; @@ -878,6 +880,28 @@ String::ExternalStringResource* String::GetExternalStringResource() const { return result; } +String::ExternalStringResourceBase* String::GetExternalStringResourceBase( + v8::Isolate* isolate, String::Encoding* encoding_out) const { + using A = internal::Address; + using I = internal::Internals; + A obj = internal::ValueHelper::ValueAsAddress(this); + int type = I::GetInstanceType(obj) & I::kStringRepresentationAndEncodingMask; + *encoding_out = static_cast(type & I::kStringEncodingMask); + ExternalStringResourceBase* resource; + if (type == I::kExternalOneByteRepresentationTag || + type == I::kExternalTwoByteRepresentationTag) { + A value = I::ReadExternalPointerField( + isolate, obj, I::kStringResourceOffset); + resource = reinterpret_cast(value); + } else { + resource = GetExternalStringResourceBaseSlow(encoding_out); + } +#ifdef V8_ENABLE_CHECKS + VerifyExternalStringResourceBase(resource, *encoding_out); +#endif + return resource; +} + String::ExternalStringResourceBase* String::GetExternalStringResourceBase( String::Encoding* encoding_out) const { using A = internal::Address; diff --git a/deps/v8/include/v8-profiler.h b/deps/v8/include/v8-profiler.h index 3451da26..d6741aec 100644 --- a/deps/v8/include/v8-profiler.h +++ b/deps/v8/include/v8-profiler.h @@ -1109,6 +1109,12 @@ class V8_EXPORT HeapProfiler { ObjectNameResolver* global_object_name_resolver = nullptr, bool hide_internals = true, bool capture_numeric_value = false); + /** + * Obtains list of Detached JS Wrapper Objects. This functon calls garbage + * collection, then iterates over traced handles in the isolate + */ + std::vector> GetDetachedJSWrapperObjects(); + /** * Starts tracking of heap objects population statistics. After calling * this method, all heap objects relocations done by the garbage collector diff --git a/deps/v8/include/v8-script.h b/deps/v8/include/v8-script.h index f4c7412c..0c81aae0 100644 --- a/deps/v8/include/v8-script.h +++ b/deps/v8/include/v8-script.h @@ -129,6 +129,11 @@ class V8_EXPORT ModuleRequest : public Data { */ Local GetSpecifier() const; + /** + * Returns the module import phase for this ModuleRequest. + */ + ModuleImportPhase GetPhase() const; + /** * Returns the source code offset of this module request. * Use Module::SourceOffsetToLocation to convert this to line/column numbers. @@ -210,7 +215,10 @@ class V8_EXPORT Module : public Data { using ResolveModuleCallback = MaybeLocal (*)( Local context, Local specifier, - Local import_assertions, Local referrer); + Local import_attributes, Local referrer); + using ResolveSourceCallback = MaybeLocal (*)( + Local context, Local specifier, + Local import_attributes, Local referrer); /** * Instantiates the module and its dependencies. @@ -220,7 +228,8 @@ class V8_EXPORT Module : public Data { * exception is propagated.) */ V8_WARN_UNUSED_RESULT Maybe InstantiateModule( - Local context, ResolveModuleCallback callback); + Local context, ResolveModuleCallback module_callback, + ResolveSourceCallback source_callback = nullptr); /** * Evaluates the module and its dependencies. @@ -264,6 +273,13 @@ class V8_EXPORT Module : public Data { */ bool IsGraphAsync() const; + /** + * Returns whether this module is individually asynchronous (for example, + * if it's a Source Text Module Record containing a top-level await). + * See [[HasTLA]] in https://tc39.es/ecma262/#sec-cyclic-module-records + */ + bool HasTopLevelAwait() const; + /** * Returns whether the module is a SourceTextModule. */ diff --git a/deps/v8/include/v8-template.h b/deps/v8/include/v8-template.h index ba5ff7bf..93b94285 100644 --- a/deps/v8/include/v8-template.h +++ b/deps/v8/include/v8-template.h @@ -9,6 +9,7 @@ #include #include "v8-data.h" // NOLINT(build/include_directory) +#include "v8-exception.h" // NOLINT(build/include_directory) #include "v8-function-callback.h" // NOLINT(build/include_directory) #include "v8-local-handle.h" // NOLINT(build/include_directory) #include "v8-memory-span.h" // NOLINT(build/include_directory) @@ -71,8 +72,6 @@ class V8_EXPORT Template : public Data { * \param name The name of the property for which an accessor is added. * \param getter The callback to invoke when getting the property. * \param setter The callback to invoke when setting the property. - * \param data A piece of data that will be passed to the getter and setter - * callbacks whenever they are invoked. * \param attribute The attributes of the property for which an accessor * is added. */ @@ -657,6 +656,18 @@ class V8_EXPORT FunctionTemplate : public Template { */ void SetClassName(Local name); + /** + * Set the interface name of the FunctionTemplate. This is provided as + * contextual information in an ExceptionPropagationMessage to the embedder. + */ + void SetInterfaceName(Local name); + + /** + * Provides information on the type of FunctionTemplate for embedder + * exception handling. + */ + void SetExceptionContext(ExceptionContext context); + /** * When set to true, no access check will be performed on the receiver of a * function call. Currently defaults to true, but this is subject to change. diff --git a/deps/v8/include/v8-traced-handle.h b/deps/v8/include/v8-traced-handle.h index 04752c4f..28fe6cf5 100644 --- a/deps/v8/include/v8-traced-handle.h +++ b/deps/v8/include/v8-traced-handle.h @@ -37,15 +37,13 @@ enum class TracedReferenceHandling { kDroppable }; -V8_EXPORT internal::Address* GlobalizeTracedReference( - internal::Isolate* isolate, internal::Address value, - internal::Address* slot, TracedReferenceStoreMode store_mode, - internal::TracedReferenceHandling reference_handling); -V8_EXPORT void MoveTracedReference(internal::Address** from, - internal::Address** to); -V8_EXPORT void CopyTracedReference(const internal::Address* const* from, - internal::Address** to); -V8_EXPORT void DisposeTracedReference(internal::Address* global_handle); +V8_EXPORT Address* GlobalizeTracedReference( + Isolate* isolate, Address value, Address* slot, + TracedReferenceStoreMode store_mode, + TracedReferenceHandling reference_handling); +V8_EXPORT void MoveTracedReference(Address** from, Address** to); +V8_EXPORT void CopyTracedReference(const Address* const* from, Address** to); +V8_EXPORT void DisposeTracedReference(Address* global_handle); } // namespace internal @@ -55,6 +53,9 @@ V8_EXPORT void DisposeTracedReference(internal::Address* global_handle); */ class TracedReferenceBase : public api_internal::IndirectHandleBase { public: + static_assert(sizeof(std::atomic) == + sizeof(internal::Address*)); + /** * If non-empty, destroy the underlying storage cell. |IsEmpty| will return * true after this call. @@ -73,9 +74,7 @@ class TracedReferenceBase : public api_internal::IndirectHandleBase { * Returns true if this TracedReference is empty, i.e., has not been * assigned an object. This version of IsEmpty is thread-safe. */ - bool IsEmptyThreadSafe() const { - return this->GetSlotThreadSafe() == nullptr; - } + bool IsEmptyThreadSafe() const { return GetSlotThreadSafe() == nullptr; } protected: V8_INLINE TracedReferenceBase() = default; @@ -83,17 +82,17 @@ class TracedReferenceBase : public api_internal::IndirectHandleBase { /** * Update this reference in a thread-safe way. */ - void SetSlotThreadSafe(void* new_val) { - reinterpret_cast*>(&slot())->store( + void SetSlotThreadSafe(internal::Address* new_val) { + reinterpret_cast*>(&slot())->store( new_val, std::memory_order_relaxed); } /** * Get this reference in a thread-safe way */ - const void* GetSlotThreadSafe() const { - return reinterpret_cast const*>(&slot())->load( - std::memory_order_relaxed); + const internal::Address* GetSlotThreadSafe() const { + return reinterpret_cast*>(&slot()) + ->load(std::memory_order_relaxed); } V8_EXPORT void CheckValue() const; diff --git a/deps/v8/include/v8-unwinder-state.h b/deps/v8/include/v8-unwinder-state.h index 18bb410d..084692f3 100644 --- a/deps/v8/include/v8-unwinder-state.h +++ b/deps/v8/include/v8-unwinder-state.h @@ -18,9 +18,8 @@ struct CalleeSavedRegisters { void* arm_r10; }; #elif V8_TARGET_ARCH_X64 || V8_TARGET_ARCH_IA32 || V8_TARGET_ARCH_ARM64 || \ - V8_TARGET_ARCH_MIPS64 || V8_TARGET_ARCH_PPC || V8_TARGET_ARCH_PPC64 || \ - V8_TARGET_ARCH_RISCV64 || V8_TARGET_ARCH_S390 || V8_TARGET_ARCH_LOONG64 || \ - V8_TARGET_ARCH_RISCV32 + V8_TARGET_ARCH_MIPS64 || V8_TARGET_ARCH_PPC64 || V8_TARGET_ARCH_RISCV64 || \ + V8_TARGET_ARCH_S390X || V8_TARGET_ARCH_LOONG64 || V8_TARGET_ARCH_RISCV32 struct CalleeSavedRegisters {}; #else #error Target architecture was not detected as supported by v8 diff --git a/deps/v8/include/v8-util.h b/deps/v8/include/v8-util.h index b7d53f14..05ade0a3 100644 --- a/deps/v8/include/v8-util.h +++ b/deps/v8/include/v8-util.h @@ -182,7 +182,7 @@ class PersistentValueMapBase { */ Local Get(const K& key) { V* p = FromVal(Traits::Get(&impl_, key)); -#ifdef V8_ENABLE_DIRECT_LOCAL +#ifdef V8_ENABLE_DIRECT_HANDLE if (p == nullptr) return Local(); #endif return Local::New(isolate_, p); diff --git a/deps/v8/include/v8-value.h b/deps/v8/include/v8-value.h index ac04525d..656b5719 100644 --- a/deps/v8/include/v8-value.h +++ b/deps/v8/include/v8-value.h @@ -635,8 +635,9 @@ bool Value::QuickIsString() const { A obj = internal::ValueHelper::ValueAsAddress(this); if (!I::HasHeapObjectTag(obj)) return false; #if V8_STATIC_ROOTS_BOOL && !V8_MAP_PACKING - return I::CheckInstanceMapRange(obj, I::StaticReadOnlyRoot::kFirstStringMap, - I::StaticReadOnlyRoot::kLastStringMap); + return I::CheckInstanceMapRange(obj, + I::StaticReadOnlyRoot::kStringMapLowerBound, + I::StaticReadOnlyRoot::kStringMapUpperBound); #else return (I::GetInstanceType(obj) < I::kFirstNonstringType); #endif // V8_STATIC_ROOTS_BOOL diff --git a/deps/v8/include/v8-version.h b/deps/v8/include/v8-version.h index 758b2b6e..7fd543af 100644 --- a/deps/v8/include/v8-version.h +++ b/deps/v8/include/v8-version.h @@ -8,8 +8,8 @@ // These macros define the version number for the current version. // NOTE these macros are used by some of the tool scripts and the build // system so their names cannot be changed without changing the scripts. -#define V8_MAJOR_VERSION 12 -#define V8_MINOR_VERSION 8 +#define V8_MAJOR_VERSION 13 +#define V8_MINOR_VERSION 1 #define V8_BUILD_NUMBER 0 #define V8_PATCH_LEVEL 0 diff --git a/deps/v8/include/v8config.h b/deps/v8/include/v8config.h index 4a6f255b..9d58e85d 100644 --- a/deps/v8/include/v8config.h +++ b/deps/v8/include/v8config.h @@ -392,8 +392,14 @@ path. Add it with -I to the command line # define V8_HAS_ATTRIBUTE_WEAK (__has_attribute(weak)) # define V8_HAS_CPP_ATTRIBUTE_NODISCARD (V8_HAS_CPP_ATTRIBUTE(nodiscard)) +#if defined(V8_CC_MSVC) +# define V8_HAS_CPP_ATTRIBUTE_NO_UNIQUE_ADDRESS \ + (V8_HAS_CPP_ATTRIBUTE(msvc::no_unique_address) || \ + V8_HAS_CPP_ATTRIBUTE(no_unique_address)) +#else # define V8_HAS_CPP_ATTRIBUTE_NO_UNIQUE_ADDRESS \ (V8_HAS_CPP_ATTRIBUTE(no_unique_address)) +#endif # define V8_HAS_BUILTIN_ADD_OVERFLOW (__has_builtin(__builtin_add_overflow)) # define V8_HAS_BUILTIN_ASSUME (__has_builtin(__builtin_assume)) @@ -692,7 +698,15 @@ path. Add it with -I to the command line // [[no_unique_address]] comes in C++20 but supported in clang with // -std >= c++11. #if V8_HAS_CPP_ATTRIBUTE_NO_UNIQUE_ADDRESS +#if defined(V8_CC_MSVC) && V8_HAS_CPP_ATTRIBUTE(msvc::no_unique_address) +// Unfortunately MSVC ignores [[no_unique_address]] (see +// https://devblogs.microsoft.com/cppblog/msvc-cpp20-and-the-std-cpp20-switch/#msvc-extensions-and-abi), +// and clang-cl matches it for ABI compatibility reasons. We need to prefer +// [[msvc::no_unique_address]] when available if we actually want any effect. +#define V8_NO_UNIQUE_ADDRESS [[msvc::no_unique_address]] +#else #define V8_NO_UNIQUE_ADDRESS [[no_unique_address]] +#endif #else #define V8_NO_UNIQUE_ADDRESS /* NOT SUPPORTED */ #endif @@ -815,16 +829,9 @@ V8 shared library set USING_V8_SHARED. #elif defined(__PPC64__) || defined(_ARCH_PPC64) #define V8_HOST_ARCH_PPC64 1 #define V8_HOST_ARCH_64_BIT 1 -#elif defined(__PPC__) || defined(_ARCH_PPC) -#define V8_HOST_ARCH_PPC 1 -#define V8_HOST_ARCH_32_BIT 1 -#elif defined(__s390__) || defined(__s390x__) -#define V8_HOST_ARCH_S390 1 -#if defined(__s390x__) +#elif defined(__s390x__) +#define V8_HOST_ARCH_S390X 1 #define V8_HOST_ARCH_64_BIT 1 -#else -#define V8_HOST_ARCH_32_BIT 1 -#endif #elif defined(__riscv) || defined(__riscv__) #if __riscv_xlen == 64 #define V8_HOST_ARCH_RISCV64 1 @@ -844,10 +851,10 @@ V8 shared library set USING_V8_SHARED. // The macros may be set externally. If not, detect in the same way as the host // architecture, that is, target the native environment as presented by the // compiler. -#if !V8_TARGET_ARCH_X64 && !V8_TARGET_ARCH_IA32 && !V8_TARGET_ARCH_ARM && \ - !V8_TARGET_ARCH_ARM64 && !V8_TARGET_ARCH_MIPS64 && !V8_TARGET_ARCH_PPC && \ - !V8_TARGET_ARCH_PPC64 && !V8_TARGET_ARCH_S390 && \ - !V8_TARGET_ARCH_RISCV64 && !V8_TARGET_ARCH_LOONG64 && \ +#if !V8_TARGET_ARCH_X64 && !V8_TARGET_ARCH_IA32 && !V8_TARGET_ARCH_ARM && \ + !V8_TARGET_ARCH_ARM64 && !V8_TARGET_ARCH_MIPS64 && \ + !V8_TARGET_ARCH_PPC64 && !V8_TARGET_ARCH_S390X && \ + !V8_TARGET_ARCH_RISCV64 && !V8_TARGET_ARCH_LOONG64 && \ !V8_TARGET_ARCH_RISCV32 #if defined(_M_X64) || defined(__x86_64__) #define V8_TARGET_ARCH_X64 1 @@ -863,13 +870,8 @@ V8 shared library set USING_V8_SHARED. #define V8_TARGET_ARCH_LOONG64 1 #elif defined(_ARCH_PPC64) #define V8_TARGET_ARCH_PPC64 1 -#elif defined(_ARCH_PPC) -#define V8_TARGET_ARCH_PPC 1 -#elif defined(__s390__) -#define V8_TARGET_ARCH_S390 1 -#if defined(__s390x__) +#elif defined(__s390x__) #define V8_TARGET_ARCH_S390X 1 -#endif #elif defined(__riscv) || defined(__riscv__) #if __riscv_xlen == 64 #define V8_TARGET_ARCH_RISCV64 1 @@ -902,16 +904,10 @@ V8 shared library set USING_V8_SHARED. #define V8_TARGET_ARCH_64_BIT 1 #elif V8_TARGET_ARCH_LOONG64 #define V8_TARGET_ARCH_64_BIT 1 -#elif V8_TARGET_ARCH_PPC -#define V8_TARGET_ARCH_32_BIT 1 #elif V8_TARGET_ARCH_PPC64 #define V8_TARGET_ARCH_64_BIT 1 -#elif V8_TARGET_ARCH_S390 -#if V8_TARGET_ARCH_S390X +#elif V8_TARGET_ARCH_S390X #define V8_TARGET_ARCH_64_BIT 1 -#else -#define V8_TARGET_ARCH_32_BIT 1 -#endif #elif V8_TARGET_ARCH_RISCV64 #define V8_TARGET_ARCH_64_BIT 1 #elif V8_TARGET_ARCH_RISCV32 @@ -968,14 +964,14 @@ V8 shared library set USING_V8_SHARED. #else #define V8_TARGET_LITTLE_ENDIAN 1 #endif -#elif defined(__BIG_ENDIAN__) // FOR PPCGR on AIX +#elif V8_TARGET_ARCH_PPC64 +#if V8_OS_AIX #define V8_TARGET_BIG_ENDIAN 1 -#elif V8_TARGET_ARCH_PPC_LE +#else #define V8_TARGET_LITTLE_ENDIAN 1 -#elif V8_TARGET_ARCH_PPC_BE -#define V8_TARGET_BIG_ENDIAN 1 -#elif V8_TARGET_ARCH_S390 -#if V8_TARGET_ARCH_S390_LE_SIM +#endif +#elif V8_TARGET_ARCH_S390X +#if V8_TARGET_ARCH_S390X_LE_SIM #define V8_TARGET_LITTLE_ENDIAN 1 #else #define V8_TARGET_BIG_ENDIAN 1 @@ -999,5 +995,10 @@ V8 shared library set USING_V8_SHARED. #else #define V8_STATIC_ROOTS_BOOL true #endif +#ifdef V8_TARGET_BIG_ENDIAN +#define V8_TARGET_BIG_ENDIAN_BOOL true +#else +#define V8_TARGET_BIG_ENDIAN_BOOL false +#endif #endif // V8CONFIG_H_ diff --git a/deps/v8/infra/mb/gn_isolate_map.pyl b/deps/v8/infra/mb/gn_isolate_map.pyl index 40df0f01..924bba4a 100644 --- a/deps/v8/infra/mb/gn_isolate_map.pyl +++ b/deps/v8/infra/mb/gn_isolate_map.pyl @@ -71,6 +71,10 @@ "label": "//test:v8_run_num_fuzzer", "type": "script", }, + "snapshot_set": { + "label": "//:snapshot_set", + "type": "script", + }, "test262": { "label": "//test/test262:v8_test262", "type": "script", diff --git a/deps/v8/infra/mb/mb_config.pyl b/deps/v8/infra/mb/mb_config.pyl index 838e6581..ce26b4df 100644 --- a/deps/v8/infra/mb/mb_config.pyl +++ b/deps/v8/infra/mb/mb_config.pyl @@ -70,6 +70,7 @@ 'V8 Linux64 - builder (reclient compare)': 'release_x64_reclient', 'V8 Linux64 - official - builder': 'official_x64_on_release_branch', 'V8 Linux64 - debug builder': 'debug_x64', + 'V8 Linux64 - no leaptiering - debug builder': 'debug_x64_no_leaptiering', 'V8 Linux64 - no shared cage - debug builder': 'debug_x64_no_shared_cage', 'V8 Linux64 - external code space - debug - builder': 'debug_x64_external_code_space', 'V8 Linux64 - custom snapshot - debug builder': 'debug_x64_custom', @@ -154,43 +155,43 @@ 'V8 Centipede Linux64 ASAN - release builder': 'release_x64_asan_centipede', 'V8 Clusterfuzz Win64 ASAN - release builder': - 'release_x64_asan_no_lsan_verify_heap', + 'release_x64_asan_no_lsan_verify_heap_turboshaft_csa', # Note this is called a debug builder, but it uses a release build # configuration with dchecks (which enables DEBUG in V8), since win-asan # debug is not supported. 'V8 Clusterfuzz Win64 ASAN - debug builder': - 'release_x64_asan_no_lsan_verify_heap_dchecks', + 'release_x64_asan_no_lsan_verify_heap_dchecks_turboshaft_csa', 'V8 Clusterfuzz Mac64 ASAN - release builder': - 'release_x64_asan_no_lsan_verify_heap', + 'release_x64_asan_no_lsan_verify_heap_turboshaft_csa', 'V8 Clusterfuzz Mac64 ASAN - debug builder': - 'debug_x64_asan_no_lsan_static', + 'debug_x64_asan_no_lsan_static_turboshaft_csa', 'V8 Clusterfuzz Linux64 - release builder': - 'release_x64_correctness_fuzzer', - 'V8 Clusterfuzz Linux64 - debug builder': 'debug_x64', + 'release_x64_correctness_fuzzer_turboshaft_csa', + 'V8 Clusterfuzz Linux64 - debug builder': 'debug_x64_turboshaft_csa', 'V8 Clusterfuzz Linux64 ASAN no inline - release builder': - 'release_x64_asan_symbolized_verify_heap', + 'release_x64_asan_symbolized_verify_heap_turboshaft_csa', 'V8 Clusterfuzz Linux ASAN no inline - release builder': - 'release_x86_asan_symbolized_verify_heap', - 'V8 Clusterfuzz Linux64 ASAN - debug builder': 'debug_x64_asan', - 'V8 Clusterfuzz Linux ASAN - debug builder': 'debug_x86_asan', + 'release_x86_asan_symbolized_verify_heap_turboshaft_csa', + 'V8 Clusterfuzz Linux64 ASAN - debug builder': 'debug_x64_asan_turboshaft_csa', + 'V8 Clusterfuzz Linux ASAN - debug builder': 'debug_x86_asan_turboshaft_csa', 'V8 Clusterfuzz Linux64 ASAN arm64 - debug builder': - 'debug_simulate_arm64_asan', - 'V8 Clusterfuzz Linux - debug builder': 'debug_x86', + 'debug_simulate_arm64_asan_turboshaft_csa', + 'V8 Clusterfuzz Linux - debug builder': 'debug_x86_turboshaft_csa', 'V8 Clusterfuzz Linux ASAN arm - debug builder': - 'debug_simulate_arm_asan', + 'debug_simulate_arm_asan_turboshaft_csa', 'V8 Clusterfuzz Linux64 CFI - release builder': - 'release_x64_cfi_clusterfuzz', + 'release_x64_cfi_clusterfuzz_turboshaft_csa', 'V8 Clusterfuzz Linux MSAN no origins': - 'release_simulate_arm64_msan_no_origins', + 'release_simulate_arm64_msan_no_origins_turboshaft_csa', 'V8 Clusterfuzz Linux MSAN chained origins': - 'release_simulate_arm64_msan', - 'V8 Clusterfuzz Linux64 TSAN - release builder': 'release_x64_tsan', + 'release_simulate_arm64_msan_turboshaft_csa', + 'V8 Clusterfuzz Linux64 TSAN - release builder': 'release_x64_tsan_turboshaft_csa', 'V8 Clusterfuzz Linux64 UBSan - release builder': - 'release_x64_ubsan_recover', + 'release_x64_ubsan_recover_turboshaft_csa', 'V8 Clusterfuzz Linux64 sandbox testing - release builder': - 'release_x64_sandbox_testing', + 'release_x64_sandbox_testing_turboshaft_csa', 'V8 Clusterfuzz Linux64 ASAN sandbox testing - release builder': - 'release_x64_asan_sandbox_testing', + 'release_x64_asan_sandbox_testing_turboshaft_csa', }, 'client.v8.perf' : { # Arm @@ -273,6 +274,7 @@ 'v8_linux64_asan_centipede_compile_rel': 'release_x64_asan_centipede', 'v8_linux64_cppgc_non_default_compile_dbg': 'debug_x64_non_default_cppgc', 'v8_linux64_compile_dbg': 'debug_x64_trybot', + 'v8_linux64_no_leaptiering_compile_dbg': 'debug_x64_no_leaptiering', 'v8_linux64_no_shared_cage_compile_dbg': 'debug_x64_no_shared_cage', 'v8_linux64_coverage_dbg': 'debug_x64_coverage', 'v8_linux64_coverage_rel': 'release_x64_coverage', @@ -305,8 +307,8 @@ 'v8_linux64_arm64_no_wasm_compile_dbg': 'debug_arm64_webassembly_disabled', 'v8_linux64_verify_csa_compile_rel': 'release_x64_verify_csa', 'v8_linux64_asan_compile_rel': 'release_x64_asan_minimal_symbols', - 'v8_linux64_sandbox_testing_compile_rel': 'release_x64_sandbox_testing', - 'v8_linux64_asan_sandbox_testing_compile_rel': 'release_x64_asan_sandbox_testing', + 'v8_linux64_sandbox_testing_compile_rel': 'release_x64_sandbox_testing_turboshaft_csa', + 'v8_linux64_asan_sandbox_testing_compile_rel': 'release_x64_asan_sandbox_testing_turboshaft_csa', 'v8_linux64_cfi_compile_rel': 'release_x64_cfi', 'v8_linux64_fuzzilli_compile_rel': 'release_x64_fuzzilli', 'v8_linux64_loong64_compile_rel': 'release_simulate_loong64', @@ -454,14 +456,15 @@ # Debug configs for simulators. 'debug_simulate_arm': [ 'debug_bot', 'simulate_arm'], - 'debug_simulate_arm_asan': [ - 'debug_bot', 'simulate_arm', 'asan'], + 'debug_simulate_arm_asan_turboshaft_csa': [ + 'debug_bot', 'simulate_arm', 'asan', 'v8_enable_turboshaft_csa'], 'debug_simulate_arm_lite': [ 'debug_bot', 'simulate_arm', 'v8_enable_lite_mode'], 'debug_simulate_arm64': [ 'debug_bot', 'simulate_arm64'], - 'debug_simulate_arm64_asan': [ - 'debug_bot', 'simulate_arm64', 'asan', 'lsan'], + 'debug_simulate_arm64_asan_turboshaft_csa': [ + 'debug_bot', 'simulate_arm64', 'asan', 'lsan', + 'v8_enable_turboshaft_csa'], # Release configs for simulators. 'release_simulate_arm_gcmole': [ @@ -487,10 +490,11 @@ 'release_bot', 'simulate_arm64', 'msan'], 'release_simulate_arm64_msan_minimal_symbols': [ 'release_bot', 'simulate_arm64', 'msan', 'minimal_symbols'], - 'release_simulate_arm64_msan': [ - 'release_bot', 'simulate_arm64', 'msan'], - 'release_simulate_arm64_msan_no_origins': [ - 'release_bot', 'simulate_arm64', 'msan_no_origins'], + 'release_simulate_arm64_msan_no_origins_turboshaft_csa': [ + 'release_bot', 'simulate_arm64', 'msan_no_origins', + 'v8_enable_turboshaft_csa'], + 'release_simulate_arm64_msan_turboshaft_csa': [ + 'release_bot', 'simulate_arm64', 'msan', 'v8_enable_turboshaft_csa'], 'release_simulate_loong64': [ 'release_bot', 'simulate_loong64'], 'release_simulate_mips64el': [ @@ -582,25 +586,25 @@ 'release_bot', 'x64', 'asan', 'lsan', 'minimal_symbols'], 'release_x64_asan_no_lsan': [ 'release_bot', 'x64', 'asan'], - 'release_x64_asan_no_lsan_verify_heap': [ - 'release_bot', 'x64', 'asan', 'v8_verify_heap'], - 'release_x64_asan_no_lsan_verify_heap': [ - 'release_bot', 'x64', 'asan', 'v8_verify_heap'], - 'release_x64_asan_no_lsan_verify_heap_dchecks': [ + 'release_x64_asan_no_lsan_verify_heap_turboshaft_csa': [ + 'release_bot', 'x64', 'asan', 'v8_verify_heap', + 'v8_enable_turboshaft_csa'], + 'release_x64_asan_no_lsan_verify_heap_dchecks_turboshaft_csa': [ 'release_bot', 'x64', 'asan', 'dcheck_always_on', - 'v8_enable_slow_dchecks', 'v8_verify_heap'], - 'release_x64_sandbox_testing': [ - 'release_bot', 'x64', 'symbolized', 'v8_enable_memory_corruption_api'], - 'release_x64_asan_sandbox_testing': [ + 'v8_enable_slow_dchecks', 'v8_verify_heap', 'v8_enable_turboshaft_csa'], + 'release_x64_sandbox_testing_turboshaft_csa': [ + 'release_bot', 'x64', 'symbolized', 'v8_enable_memory_corruption_api', + 'v8_enable_turboshaft_csa'], + 'release_x64_asan_sandbox_testing_turboshaft_csa': [ 'release_bot', 'x64', 'asan', 'symbolized', - 'v8_enable_memory_corruption_api'], - 'release_x64_asan_symbolized_verify_heap': [ + 'v8_enable_memory_corruption_api', 'v8_enable_turboshaft_csa'], + 'release_x64_asan_symbolized_verify_heap_turboshaft_csa': [ 'release_bot', 'x64', 'asan', 'lsan', 'symbolized', - 'v8_verify_heap'], + 'v8_verify_heap', 'v8_enable_turboshaft_csa'], 'release_x64_cfi': [ 'release_bot', 'x64', 'cfi'], - 'release_x64_cfi_clusterfuzz': [ - 'release_bot', 'x64', 'cfi_clusterfuzz'], + 'release_x64_cfi_clusterfuzz_turboshaft_csa': [ + 'release_bot', 'x64', 'cfi_clusterfuzz', 'v8_enable_turboshaft_csa'], 'release_x64_coverage': [ 'release_bot', 'x64', 'clang_coverage'], 'release_x64_fuzzilli': [ @@ -610,8 +614,9 @@ 'release_bot', 'x64', 'gcmole'], 'release_x64_msvc': [ 'release_bot_no_reclient', 'x64', 'minimal_symbols', 'msvc'], - 'release_x64_correctness_fuzzer' : [ - 'release_bot', 'x64', 'v8_correctness_fuzzer'], + 'release_x64_correctness_fuzzer_turboshaft_csa' : [ + 'release_bot', 'x64', 'v8_correctness_fuzzer', + 'v8_enable_turboshaft_csa'], 'release_x64_disable_runtime_call_stats': [ 'release_bot', 'x64', 'v8_disable_runtime_call_stats'], 'release_x64_fuchsia': [ @@ -647,12 +652,14 @@ 'release_bot', 'x64', 'tsan', 'disable_concurrent_marking'], 'release_x64_tsan_minimal_symbols': [ 'release_bot', 'x64', 'tsan', 'minimal_symbols'], + 'release_x64_tsan_turboshaft_csa': [ + 'release_bot', 'x64', 'tsan', 'v8_enable_turboshaft_csa'], 'release_x64_ubsan': [ 'release_bot', 'x64', 'ubsan'], 'release_x64_ubsan_minimal_symbols': [ 'release_bot', 'x64', 'ubsan', 'minimal_symbols'], - 'release_x64_ubsan_recover': [ - 'release_bot', 'x64', 'ubsan_recover'], + 'release_x64_ubsan_recover_turboshaft_csa': [ + 'release_bot', 'x64', 'ubsan_recover', 'v8_enable_turboshaft_csa'], 'release_x64_shared_verify_heap': [ 'release_bot', 'x64', 'shared', 'v8_verify_heap'], 'release_x64_verify_builtins': [ @@ -678,13 +685,13 @@ # Debug configs for x64. 'debug_x64': [ 'debug_bot', 'x64'], - 'debug_x64_asan': [ - 'debug_bot', 'x64', 'asan', 'lsan'], + 'debug_x64_asan_turboshaft_csa': [ + 'debug_bot', 'x64', 'asan', 'lsan', 'v8_enable_turboshaft_csa'], 'debug_x64_asan_centipede': [ 'debug_bot', 'x64', 'asan', 'use_centipede'], - 'debug_x64_asan_no_lsan_static': [ - 'debug', 'static', 'reclient', 'v8_enable_slow_dchecks', 'v8_optimized_debug', - 'x64', 'asan'], + 'debug_x64_asan_no_lsan_static_turboshaft_csa': [ + 'debug', 'static', 'reclient', 'v8_enable_slow_dchecks', + 'v8_optimized_debug', 'x64', 'asan', 'v8_enable_turboshaft_csa'], 'debug_x64_conservative_stack_scanning': [ 'debug_bot', 'x64', 'conservative_stack_scanning'], 'debug_x64_coverage': [ @@ -701,6 +708,8 @@ 'debug_bot_no_reclient', 'x64', 'gcc', 'lld', 'no_custom_libcxx'], 'debug_x64_header_includes': [ 'debug_bot', 'x64', 'v8_check_header_includes'], + 'debug_x64_no_leaptiering': [ + 'debug_bot', 'x64', 'v8_disable_leaptiering'], 'debug_x64_no_shared_cage': [ 'debug_bot', 'x64', 'v8_disable_pointer_compression_shared_cage'], 'debug_x64_minimal_symbols': [ @@ -717,6 +726,8 @@ 'debug_bot', 'x64', 'v8_enable_sticky_mark_bits'], 'debug_x64_trybot': [ 'debug_trybot', 'x64'], + 'debug_x64_turboshaft_csa': [ + 'debug_bot', 'x64', 'v8_enable_turboshaft_csa'], 'debug_x64_dict_tracking_trybot': [ 'debug_trybot', 'x64', 'v8_enable_dict_property_const_tracking'], 'debug_x64_trybot_custom': [ @@ -730,8 +741,8 @@ # Debug configs for x86. 'debug_x86': [ 'debug_bot', 'x86'], - 'debug_x86_asan': [ - 'debug_bot', 'x86', 'asan', 'lsan'], + 'debug_x86_asan_turboshaft_csa': [ + 'debug_bot', 'x86', 'asan', 'lsan', 'v8_enable_turboshaft_csa'], 'debug_x86_minimal_symbols': [ 'debug_bot', 'x86', 'minimal_symbols'], 'debug_x86_msvc': [ @@ -740,15 +751,17 @@ 'debug_bot', 'x86', 'v8_no_i18n'], 'debug_x86_trybot': [ 'debug_trybot', 'x86'], + 'debug_x86_turboshaft_csa': [ + 'debug_bot', 'x86', 'v8_enable_turboshaft_csa'], 'debug_x86_vtunejit': [ 'debug_bot', 'x86', 'v8_enable_vtunejit'], 'full_debug_x86': [ 'debug', 'x86', 'reclient', 'v8_enable_slow_dchecks', 'v8_full_debug'], # Release configs for x86. - 'release_x86_asan_symbolized_verify_heap': [ + 'release_x86_asan_symbolized_verify_heap_turboshaft_csa': [ 'release_bot', 'x86', 'asan', 'lsan', 'symbolized', - 'v8_verify_heap'], + 'v8_verify_heap', 'v8_enable_turboshaft_csa'], 'release_x86_gcmole': [ 'release_bot', 'x86', 'gcmole'], 'release_x86_gcmole_trybot': [ @@ -1068,6 +1081,10 @@ 'gn_args': 'v8_control_flow_integrity=true', }, + 'v8_disable_leaptiering': { + 'gn_args': 'v8_disable_leaptiering=true', + }, + 'v8_disable_runtime_call_stats': { 'gn_args': 'v8_enable_runtime_call_stats=false', }, @@ -1132,6 +1149,10 @@ 'gn_args': 'v8_enable_test_features=true', }, + 'v8_enable_turboshaft_csa': { + 'gn_args': 'v8_enable_turboshaft_csa=true', + }, + 'v8_enable_verify_predictable': { 'gn_args': 'v8_enable_verify_predictable=true', }, diff --git a/deps/v8/infra/testing/builders.pyl b/deps/v8/infra/testing/builders.pyl index 194928d3..1afe4558 100644 --- a/deps/v8/infra/testing/builders.pyl +++ b/deps/v8/infra/testing/builders.pyl @@ -621,6 +621,14 @@ {'name': 'v8testing', 'shards': 3}, ], }, + 'v8_linux64_no_leaptiering_dbg': { + 'swarming_dimensions' : { + 'os': 'Ubuntu-22.04', + }, + 'tests': [ + {'name': 'v8testing', 'shards': 3}, + ], + }, 'v8_linux64_no_shared_cage_dbg': { 'swarming_dimensions' : { 'os': 'Ubuntu-22.04', @@ -1694,6 +1702,14 @@ {'name': 'v8testing'}, ], }, + 'V8 Linux64 - no leaptiering - debug': { + 'swarming_dimensions' : { + 'os': 'Ubuntu-22.04', + }, + 'tests': [ + {'name': 'v8testing', 'shards': 2}, + ], + }, 'V8 Linux64 - no shared cage - debug': { 'swarming_dimensions' : { 'os': 'Ubuntu-22.04', diff --git a/deps/v8/samples/OWNERS b/deps/v8/samples/OWNERS index 6df8720d..904e7d11 100644 --- a/deps/v8/samples/OWNERS +++ b/deps/v8/samples/OWNERS @@ -1,2 +1,2 @@ -mathias@chromium.org +ahaas@chromium.org cbruni@chromium.org diff --git a/deps/v8/src/DEPS b/deps/v8/src/DEPS index 8cd950b5..6cf85f8c 100644 --- a/deps/v8/src/DEPS +++ b/deps/v8/src/DEPS @@ -18,6 +18,7 @@ include_rules = [ "-src/heap", "+src/heap/memory-chunk-metadata.h", "+src/heap/code-range.h", + "+src/heap/read-only-spaces.h", "+src/heap/trusted-range.h", "+src/heap/combined-heap.h", "+src/heap/factory.h", @@ -29,6 +30,8 @@ include_rules = [ "+src/heap/heap.h", "+src/heap/heap-verifier.h", "+src/heap/heap-inl.h", + "+src/heap/heap-layout-inl.h", + "+src/heap/heap-layout.h", "+src/heap/heap-write-barrier-inl.h", "+src/heap/heap-write-barrier.h", "+src/heap/local-factory-inl.h", diff --git a/deps/v8/src/api/api-arguments-inl.h b/deps/v8/src/api/api-arguments-inl.h index 3ebc8a18..651c13dc 100644 --- a/deps/v8/src/api/api-arguments-inl.h +++ b/deps/v8/src/api/api-arguments-inl.h @@ -166,7 +166,7 @@ Handle PropertyCallbackArguments::CallNamedQuery( slot_at(kReturnValueIndex).store(Smi::FromInt(v8::None)); NamedPropertyQueryCallback f = ToCData( - interceptor->query()); + isolate, interceptor->query()); PREPARE_CALLBACK_INFO_INTERCEPTOR(isolate, f, v8::Integer, interceptor, ExceptionContext::kNamedQuery); v8::Intercepted intercepted = f(v8::Utils::ToLocal(name), callback_info); @@ -183,7 +183,7 @@ Handle PropertyCallbackArguments::CallNamedGetter( slot_at(kReturnValueIndex).store(ReadOnlyRoots(isolate).undefined_value()); NamedPropertyGetterCallback f = ToCData( - interceptor->getter()); + isolate, interceptor->getter()); PREPARE_CALLBACK_INFO_INTERCEPTOR(isolate, f, v8::Value, interceptor, ExceptionContext::kNamedGetter); v8::Intercepted intercepted = f(v8::Utils::ToLocal(name), callback_info); @@ -201,7 +201,7 @@ Handle PropertyCallbackArguments::CallNamedDescriptor( NamedPropertyDescriptorCallback f = ToCData( - interceptor->descriptor()); + isolate, interceptor->descriptor()); PREPARE_CALLBACK_INFO_INTERCEPTOR(isolate, f, v8::Value, interceptor, ExceptionContext::kNamedDescriptor); v8::Intercepted intercepted = f(v8::Utils::ToLocal(name), callback_info); @@ -219,7 +219,7 @@ v8::Intercepted PropertyCallbackArguments::CallNamedSetter( slot_at(kReturnValueIndex).store(ReadOnlyRoots(isolate).true_value()); NamedPropertySetterCallback f = ToCData( - interceptor->setter()); + isolate, interceptor->setter()); Handle has_side_effects; PREPARE_CALLBACK_INFO_INTERCEPTOR(isolate, f, void, has_side_effects, ExceptionContext::kNamedSetter); @@ -236,9 +236,9 @@ v8::Intercepted PropertyCallbackArguments::CallNamedDefiner( RCS_SCOPE(isolate, RuntimeCallCounterId::kNamedDefinerCallback); slot_at(kPropertyKeyIndex).store(*name); slot_at(kReturnValueIndex).store(ReadOnlyRoots(isolate).true_value()); - NamedPropertyDefinerCallback f = - ToCData(interceptor->definer()); + NamedPropertyDefinerCallback f = ToCData( + isolate, interceptor->definer()); Handle has_side_effects; PREPARE_CALLBACK_INFO_INTERCEPTOR(isolate, f, void, has_side_effects, ExceptionContext::kNamedDefiner); @@ -254,9 +254,9 @@ v8::Intercepted PropertyCallbackArguments::CallNamedDeleter( RCS_SCOPE(isolate, RuntimeCallCounterId::kNamedDeleterCallback); slot_at(kPropertyKeyIndex).store(*name); slot_at(kReturnValueIndex).store(ReadOnlyRoots(isolate).true_value()); - NamedPropertyDeleterCallback f = - ToCData(interceptor->deleter()); + NamedPropertyDeleterCallback f = ToCData( + isolate, interceptor->deleter()); Handle has_side_effects; PREPARE_CALLBACK_INFO_INTERCEPTOR(isolate, f, v8::Boolean, has_side_effects, ExceptionContext::kNamedDeleter); @@ -285,7 +285,8 @@ Handle PropertyCallbackArguments::CallIndexedQuery( slot_at(kReturnValueIndex).store(Smi::FromInt(v8::None)); IndexedPropertyQueryCallbackV2 f = ToCData(interceptor->query()); + kApiIndexedPropertyQueryCallbackTag>(isolate, + interceptor->query()); PREPARE_CALLBACK_INFO_INTERCEPTOR(isolate, f, v8::Integer, interceptor, ExceptionContext::kIndexedQuery); v8::Intercepted intercepted = f(index, callback_info); @@ -303,7 +304,8 @@ Handle PropertyCallbackArguments::CallIndexedGetter( slot_at(kReturnValueIndex).store(ReadOnlyRoots(isolate).undefined_value()); IndexedPropertyGetterCallbackV2 f = ToCData(interceptor->getter()); + kApiIndexedPropertyGetterCallbackTag>(isolate, + interceptor->getter()); PREPARE_CALLBACK_INFO_INTERCEPTOR(isolate, f, v8::Value, interceptor, ExceptionContext::kIndexedGetter); v8::Intercepted intercepted = f(index, callback_info); @@ -322,7 +324,7 @@ Handle PropertyCallbackArguments::CallIndexedDescriptor( IndexedPropertyDescriptorCallbackV2 f = ToCData( - interceptor->descriptor()); + isolate, interceptor->descriptor()); PREPARE_CALLBACK_INFO_INTERCEPTOR(isolate, f, v8::Value, interceptor, ExceptionContext::kIndexedDescriptor); v8::Intercepted intercepted = f(index, callback_info); @@ -341,7 +343,8 @@ v8::Intercepted PropertyCallbackArguments::CallIndexedSetter( slot_at(kReturnValueIndex).store(ReadOnlyRoots(isolate).true_value()); IndexedPropertySetterCallbackV2 f = ToCData(interceptor->setter()); + kApiIndexedPropertySetterCallbackTag>(isolate, + interceptor->setter()); Handle has_side_effects; PREPARE_CALLBACK_INFO_INTERCEPTOR(isolate, f, void, has_side_effects, ExceptionContext::kIndexedSetter); @@ -361,7 +364,8 @@ v8::Intercepted PropertyCallbackArguments::CallIndexedDefiner( slot_at(kReturnValueIndex).store(ReadOnlyRoots(isolate).true_value()); IndexedPropertyDefinerCallbackV2 f = ToCData(interceptor->definer()); + kApiIndexedPropertyDefinerCallbackTag>(isolate, + interceptor->definer()); Handle has_side_effects; PREPARE_CALLBACK_INFO_INTERCEPTOR(isolate, f, void, has_side_effects, ExceptionContext::kIndexedDefiner); @@ -379,7 +383,8 @@ v8::Intercepted PropertyCallbackArguments::CallIndexedDeleter( slot_at(kReturnValueIndex).store(ReadOnlyRoots(isolate).true_value()); IndexedPropertyDeleterCallbackV2 f = ToCData(interceptor->deleter()); + kApiIndexedPropertyDeleterCallbackTag>(isolate, + interceptor->deleter()); PREPARE_CALLBACK_INFO_INTERCEPTOR(isolate, f, v8::Boolean, interceptor, ExceptionContext::kIndexedDeleter); v8::Intercepted intercepted = f(index, callback_info); @@ -401,7 +406,7 @@ Handle PropertyCallbackArguments::CallPropertyEnumerator( IndexedPropertyEnumeratorCallback f = v8::ToCData( - interceptor->enumerator()); + isolate, interceptor->enumerator()); PREPARE_CALLBACK_INFO_INTERCEPTOR(isolate, f, v8::Array, interceptor, ExceptionContext::kNamedEnumerator); f(callback_info); @@ -470,7 +475,7 @@ bool PropertyCallbackArguments::CallAccessorSetter( // v8::AccessorNameSetterCallback or AccessorNameBooleanSetterCallback // the result is guaranteed to be v8::Boolean value indicating success or // failure. - Handle result = GetReturnValue(isolate); + DirectHandle result = GetReturnValue(isolate); return IsTrue(*result, isolate); } diff --git a/deps/v8/src/api/api-inl.h b/deps/v8/src/api/api-inl.h index c7be6489..32e3e476 100644 --- a/deps/v8/src/api/api-inl.h +++ b/deps/v8/src/api/api-inl.h @@ -18,18 +18,21 @@ namespace v8 { template -inline T ToCData(v8::internal::Tagged obj) { +inline T ToCData(i::Isolate* isolate, + v8::internal::Tagged obj) { static_assert(sizeof(T) == sizeof(v8::internal::Address)); if (obj == v8::internal::Smi::zero()) return nullptr; return reinterpret_cast( - v8::internal::Cast(obj)->foreign_address()); + v8::internal::Cast(obj)->foreign_address( + isolate)); } template inline v8::internal::Address ToCData( - v8::internal::Tagged obj) { + i::Isolate* isolate, v8::internal::Tagged obj) { if (obj == v8::internal::Smi::zero()) return v8::internal::kNullAddress; - return v8::internal::Cast(obj)->foreign_address(); + return v8::internal::Cast(obj)->foreign_address( + isolate); } template @@ -51,66 +54,51 @@ inline v8::internal::Handle> FromCData( } template -inline Local Utils::Convert(v8::internal::Handle obj) { - DCHECK(obj.is_null() || (IsSmi(*obj) || !IsTheHole(*obj))); -#ifdef V8_ENABLE_DIRECT_LOCAL +inline Local Utils::Convert(v8::internal::DirectHandle obj) { + DCHECK(obj.is_null() || IsSmi(*obj) || !IsTheHole(*obj)); +#ifdef V8_ENABLE_DIRECT_HANDLE if (obj.is_null()) return Local(); -#endif - return Local::FromSlot(obj.location()); -} - -template -inline Local Utils::Convert(v8::internal::DirectHandle obj, - v8::internal::Isolate* isolate) { -#if defined(V8_ENABLE_DIRECT_LOCAL) - DCHECK(obj.is_null() || (IsSmi(*obj) || !IsTheHole(*obj))); return Local::FromAddress(obj.address()); -#elif defined(V8_ENABLE_DIRECT_HANDLE) - if (obj.is_null()) return Local(); - return Convert(v8::internal::Handle(*obj, isolate)); #else - return Convert(obj); + return Local::FromSlot(obj.location()); #endif } // Implementations of ToLocal -#define MAKE_TO_LOCAL(Name, From, To) \ - Local Utils::Name(v8::internal::Handle obj) { \ - return Convert(obj); \ - } \ - \ - Local Utils::Name( \ - v8::internal::DirectHandle obj, \ - i::Isolate* isolate) { \ - return Convert(obj, isolate); \ +#define MAKE_TO_LOCAL(Name) \ + template