From 9b44b05f1ece80b36c94f2a931de53fece870b86 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C3=ABl=20Zasso?= Date: Sat, 18 Mar 2023 10:32:52 +0100 Subject: [PATCH 1/8] deps: update V8 to 11.2.214.9 --- deps/v8/.git-blame-ignore-revs | 95 + deps/v8/.gitignore | 2 + deps/v8/AUTHORS | 5 + deps/v8/BUILD.bazel | 305 +- deps/v8/BUILD.gn | 765 +- deps/v8/DEPS | 82 +- deps/v8/PPC_OWNERS | 1 - deps/v8/PRESUBMIT.py | 9 +- deps/v8/S390_OWNERS | 1 - deps/v8/WATCHLISTS | 17 +- .../trace_event/common/trace_event_common.h | 15 +- deps/v8/bazel/config/BUILD.bazel | 7 + deps/v8/bazel/defs.bzl | 122 +- deps/v8/gni/snapshot_toolchain.gni | 4 + deps/v8/gni/v8.gni | 26 + .../include/cppgc/cross-thread-persistent.h | 6 +- deps/v8/include/cppgc/heap-consistency.h | 4 +- .../v8/include/cppgc/internal/api-constants.h | 2 +- deps/v8/include/cppgc/internal/gc-info.h | 68 +- .../include/cppgc/internal/member-storage.h | 13 +- .../include/cppgc/internal/pointer-policies.h | 40 +- .../v8/include/cppgc/internal/write-barrier.h | 20 +- deps/v8/include/cppgc/member.h | 296 +- deps/v8/include/cppgc/persistent.h | 37 +- deps/v8/include/cppgc/type-traits.h | 7 +- deps/v8/include/cppgc/visitor.h | 17 +- deps/v8/include/js_protocol.pdl | 12 +- deps/v8/include/libplatform/v8-tracing.h | 4 +- deps/v8/include/v8-array-buffer.h | 41 + deps/v8/include/v8-callbacks.h | 4 + deps/v8/include/v8-context.h | 19 +- deps/v8/include/v8-cppgc.h | 6 + deps/v8/include/v8-embedder-heap.h | 169 - deps/v8/include/v8-fast-api-calls.h | 10 +- deps/v8/include/v8-function-callback.h | 21 +- deps/v8/include/v8-inspector.h | 25 +- deps/v8/include/v8-internal.h | 159 +- deps/v8/include/v8-isolate.h | 40 +- deps/v8/include/v8-local-handle.h | 117 +- deps/v8/include/v8-metrics.h | 30 +- deps/v8/include/v8-object.h | 11 +- deps/v8/include/v8-persistent-handle.h | 40 +- deps/v8/include/v8-platform.h | 37 +- deps/v8/include/v8-primitive.h | 14 +- deps/v8/include/v8-profiler.h | 1 + deps/v8/include/v8-script.h | 9 +- deps/v8/include/v8-snapshot.h | 25 +- deps/v8/include/v8-template.h | 4 +- deps/v8/include/v8-traced-handle.h | 36 +- deps/v8/include/v8-util.h | 17 + deps/v8/include/v8-value.h | 13 +- deps/v8/include/v8-version.h | 6 +- deps/v8/include/v8config.h | 54 +- deps/v8/infra/mb/gn_isolate_map.pyl | 4 + deps/v8/infra/mb/mb_config.pyl | 142 +- deps/v8/infra/testing/builders.pyl | 315 +- deps/v8/src/DEPS | 9 +- deps/v8/src/api/api-arguments-inl.h | 30 +- deps/v8/src/api/api-arguments.h | 14 +- deps/v8/src/api/api-inl.h | 39 +- deps/v8/src/api/api-macros.h | 19 +- deps/v8/src/api/api-natives.cc | 4 +- deps/v8/src/api/api.cc | 705 +- deps/v8/src/api/api.h | 5 +- deps/v8/src/asmjs/asm-parser.cc | 2 +- deps/v8/src/asmjs/asm-parser.h | 2 +- deps/v8/src/asmjs/asm-types.h | 2 +- deps/v8/src/ast/ast.h | 7 +- deps/v8/src/ast/prettyprinter.cc | 4 + deps/v8/src/ast/scopes.cc | 39 +- deps/v8/src/ast/scopes.h | 2 + deps/v8/src/base/DEPS | 6 + deps/v8/src/base/bit-field.h | 2 +- deps/v8/src/base/bits.h | 29 + deps/v8/src/base/build_config.h | 10 +- deps/v8/src/base/container-utils.h | 66 +- deps/v8/src/base/cpu.cc | 31 +- deps/v8/src/base/cpu.h | 4 + deps/v8/src/base/ieee754.cc | 15 +- deps/v8/src/base/ieee754.h | 25 +- deps/v8/src/base/immediate-crash.h | 4 +- deps/v8/src/base/ios-headers.h | 31 + deps/v8/src/base/logging.h | 10 +- deps/v8/src/base/numbers/diy-fp.h | 9 + deps/v8/src/base/numbers/double.h | 3 +- deps/v8/src/base/numbers/fast-dtoa.cc | 113 +- deps/v8/src/base/platform/memory.h | 4 +- deps/v8/src/base/platform/platform-darwin.cc | 137 +- deps/v8/src/base/platform/platform-fuchsia.cc | 4 +- deps/v8/src/base/platform/platform-macos.cc | 133 - deps/v8/src/base/platform/platform-posix.cc | 41 +- deps/v8/src/base/platform/platform-win32.cc | 2 +- deps/v8/src/base/platform/platform.h | 2 +- deps/v8/src/base/platform/time.h | 9 +- deps/v8/src/base/small-vector.h | 82 +- deps/v8/src/base/sys-info.cc | 16 + deps/v8/src/base/sys-info.h | 6 + deps/v8/src/base/template-utils.h | 5 + .../src/base/utils/random-number-generator.h | 8 + deps/v8/src/base/vector.h | 44 +- deps/v8/src/base/vlq.h | 17 +- .../baseline/arm/baseline-assembler-arm-inl.h | 103 +- .../arm64/baseline-assembler-arm64-inl.h | 140 +- deps/v8/src/baseline/baseline-assembler-inl.h | 5 +- deps/v8/src/baseline/baseline-assembler.h | 26 +- .../src/baseline/baseline-batch-compiler.cc | 4 +- deps/v8/src/baseline/baseline-compiler.cc | 90 +- .../ia32/baseline-assembler-ia32-inl.h | 113 +- .../loong64/baseline-assembler-loong64-inl.h | 111 +- .../mips64/baseline-assembler-mips64-inl.h | 113 +- .../baseline/ppc/baseline-assembler-ppc-inl.h | 184 +- .../riscv/baseline-assembler-riscv-inl.h | 112 +- .../s390/baseline-assembler-s390-inl.h | 180 +- .../baseline/x64/baseline-assembler-x64-inl.h | 184 +- deps/v8/src/bigint/tostring.cc | 3 +- deps/v8/src/builtins/accessors.cc | 30 +- deps/v8/src/builtins/accessors.h | 2 - deps/v8/src/builtins/arm/builtins-arm.cc | 99 +- deps/v8/src/builtins/arm64/builtins-arm64.cc | 364 +- deps/v8/src/builtins/array-from.tq | 29 +- deps/v8/src/builtins/array-join.tq | 20 +- deps/v8/src/builtins/array-of.tq | 23 +- deps/v8/src/builtins/array-reverse.tq | 77 +- deps/v8/src/builtins/array-to-reversed.tq | 95 +- deps/v8/src/builtins/arraybuffer.tq | 21 + deps/v8/src/builtins/base.tq | 36 +- deps/v8/src/builtins/builtins-api.cc | 11 +- deps/v8/src/builtins/builtins-array-gen.cc | 4 +- deps/v8/src/builtins/builtins-array.cc | 27 +- deps/v8/src/builtins/builtins-arraybuffer.cc | 181 +- deps/v8/src/builtins/builtins-async-gen.cc | 2 +- .../builtins/builtins-async-generator-gen.cc | 16 +- deps/v8/src/builtins/builtins-bigint-gen.h | 119 + deps/v8/src/builtins/builtins-bigint.tq | 381 + deps/v8/src/builtins/builtins-call-gen.cc | 3 +- deps/v8/src/builtins/builtins-callsite.cc | 37 +- .../src/builtins/builtins-collections-gen.cc | 32 +- .../src/builtins/builtins-collections-gen.h | 10 +- .../src/builtins/builtins-constructor-gen.cc | 9 +- .../src/builtins/builtins-conversion-gen.cc | 21 + deps/v8/src/builtins/builtins-dataview.cc | 36 +- deps/v8/src/builtins/builtins-date-gen.cc | 17 +- deps/v8/src/builtins/builtins-date.cc | 8 +- deps/v8/src/builtins/builtins-definitions.h | 45 +- deps/v8/src/builtins/builtins-descriptors.h | 7 +- deps/v8/src/builtins/builtins-error.cc | 2 +- .../v8/src/builtins/builtins-generator-gen.cc | 6 +- deps/v8/src/builtins/builtins-ic-gen.cc | 11 + deps/v8/src/builtins/builtins-internal-gen.cc | 215 +- deps/v8/src/builtins/builtins-intl-gen.cc | 10 +- deps/v8/src/builtins/builtins-lazy-gen.cc | 25 +- deps/v8/src/builtins/builtins-lazy-gen.h | 2 +- deps/v8/src/builtins/builtins-object-gen.cc | 381 +- deps/v8/src/builtins/builtins-object-gen.h | 58 + deps/v8/src/builtins/builtins-object.cc | 36 +- deps/v8/src/builtins/builtins-proxy-gen.cc | 2 + deps/v8/src/builtins/builtins-reflect.cc | 26 - deps/v8/src/builtins/builtins-regexp-gen.cc | 60 +- deps/v8/src/builtins/builtins-regexp-gen.h | 2 - .../src/builtins/builtins-shadow-realm-gen.cc | 27 +- deps/v8/src/builtins/builtins-shadow-realm.cc | 8 +- deps/v8/src/builtins/builtins-string-gen.cc | 292 +- deps/v8/src/builtins/builtins-string-gen.h | 11 +- deps/v8/src/builtins/builtins-struct.cc | 80 +- deps/v8/src/builtins/builtins-typed-array.cc | 1 + .../v8/src/builtins/builtins-web-snapshots.cc | 119 - deps/v8/src/builtins/builtins.cc | 192 +- deps/v8/src/builtins/builtins.h | 71 +- deps/v8/src/builtins/cast.tq | 8 +- .../src/builtins/constants-table-builder.cc | 6 +- .../v8/src/builtins/constants-table-builder.h | 6 +- deps/v8/src/builtins/convert.tq | 3 + deps/v8/src/builtins/data-view.tq | 27 +- deps/v8/src/builtins/ia32/builtins-ia32.cc | 163 +- deps/v8/src/builtins/iterator-helpers.tq | 166 + .../src/builtins/loong64/builtins-loong64.cc | 90 +- .../v8/src/builtins/mips64/builtins-mips64.cc | 93 +- deps/v8/src/builtins/number.tq | 33 +- deps/v8/src/builtins/object.tq | 147 + deps/v8/src/builtins/ppc/builtins-ppc.cc | 237 +- deps/v8/src/builtins/promise-resolve.tq | 6 - deps/v8/src/builtins/proxy-set-property.tq | 2 + deps/v8/src/builtins/reflect.tq | 16 + deps/v8/src/builtins/regexp-replace.tq | 60 +- deps/v8/src/builtins/riscv/builtins-riscv.cc | 227 +- deps/v8/src/builtins/s390/builtins-s390.cc | 230 +- .../src/builtins/setup-builtins-internal.cc | 25 +- deps/v8/src/builtins/string-iswellformed.tq | 48 + deps/v8/src/builtins/string-towellformed.tq | 62 + deps/v8/src/builtins/torque-internal.tq | 17 +- .../builtins/typed-array-createtypedarray.tq | 22 +- deps/v8/src/builtins/wasm.tq | 175 +- deps/v8/src/builtins/x64/builtins-x64.cc | 775 +- deps/v8/src/codegen/OWNERS | 1 + deps/v8/src/codegen/arm/assembler-arm-inl.h | 4 +- deps/v8/src/codegen/arm/assembler-arm.cc | 17 +- deps/v8/src/codegen/arm/assembler-arm.h | 8 +- deps/v8/src/codegen/arm/constants-arm.h | 16 + .../arm/interface-descriptors-arm-inl.h | 3 + .../v8/src/codegen/arm/macro-assembler-arm.cc | 528 +- deps/v8/src/codegen/arm/macro-assembler-arm.h | 161 +- .../src/codegen/arm64/assembler-arm64-inl.h | 17 +- deps/v8/src/codegen/arm64/assembler-arm64.cc | 210 +- deps/v8/src/codegen/arm64/assembler-arm64.h | 652 +- deps/v8/src/codegen/arm64/constants-arm64.h | 153 +- deps/v8/src/codegen/arm64/decoder-arm64-inl.h | 32 +- deps/v8/src/codegen/arm64/decoder-arm64.h | 1 + .../arm64/interface-descriptors-arm64-inl.h | 3 + .../codegen/arm64/macro-assembler-arm64-inl.h | 387 +- .../codegen/arm64/macro-assembler-arm64.cc | 1012 +-- .../src/codegen/arm64/macro-assembler-arm64.h | 505 +- deps/v8/src/codegen/arm64/register-arm64.h | 32 +- deps/v8/src/codegen/assembler.cc | 17 +- deps/v8/src/codegen/assembler.h | 21 +- deps/v8/src/codegen/background-merge-task.h | 7 +- deps/v8/src/codegen/bailout-reason.h | 34 +- deps/v8/src/codegen/callable.h | 8 +- deps/v8/src/codegen/code-comments.h | 2 +- deps/v8/src/codegen/code-desc.h | 2 +- deps/v8/src/codegen/code-factory.cc | 61 +- deps/v8/src/codegen/code-factory.h | 9 +- deps/v8/src/codegen/code-reference.cc | 11 +- deps/v8/src/codegen/code-reference.h | 17 +- deps/v8/src/codegen/code-stub-assembler.cc | 1275 +++- deps/v8/src/codegen/code-stub-assembler.h | 181 +- deps/v8/src/codegen/compilation-cache.cc | 4 +- deps/v8/src/codegen/compiler.cc | 360 +- deps/v8/src/codegen/compiler.h | 45 +- deps/v8/src/codegen/cpu-features.h | 4 + deps/v8/src/codegen/external-reference.cc | 108 +- deps/v8/src/codegen/external-reference.h | 26 + deps/v8/src/codegen/handler-table.cc | 10 +- deps/v8/src/codegen/handler-table.h | 15 +- deps/v8/src/codegen/ia32/assembler-ia32-inl.h | 4 +- deps/v8/src/codegen/ia32/assembler-ia32.cc | 17 +- deps/v8/src/codegen/ia32/assembler-ia32.h | 22 +- .../ia32/interface-descriptors-ia32-inl.h | 17 + .../src/codegen/ia32/macro-assembler-ia32.cc | 442 +- .../src/codegen/ia32/macro-assembler-ia32.h | 109 +- .../src/codegen/interface-descriptors-inl.h | 23 + deps/v8/src/codegen/interface-descriptors.h | 110 +- .../codegen/loong64/assembler-loong64-inl.h | 2 +- .../src/codegen/loong64/assembler-loong64.cc | 17 +- .../src/codegen/loong64/assembler-loong64.h | 16 +- .../src/codegen/loong64/constants-loong64.h | 16 + .../interface-descriptors-loong64-inl.h | 3 + .../loong64/macro-assembler-loong64.cc | 731 +- .../codegen/loong64/macro-assembler-loong64.h | 165 +- deps/v8/src/codegen/machine-type.h | 2 + ...o-assembler.cc => macro-assembler-base.cc} | 27 +- ...rbo-assembler.h => macro-assembler-base.h} | 38 +- deps/v8/src/codegen/macro-assembler.h | 24 +- deps/v8/src/codegen/maglev-safepoint-table.cc | 21 +- deps/v8/src/codegen/maglev-safepoint-table.h | 18 +- .../src/codegen/mips64/assembler-mips64-inl.h | 2 +- .../v8/src/codegen/mips64/assembler-mips64.cc | 22 +- deps/v8/src/codegen/mips64/assembler-mips64.h | 18 +- deps/v8/src/codegen/mips64/constants-mips64.h | 16 + .../mips64/interface-descriptors-mips64-inl.h | 3 + .../codegen/mips64/macro-assembler-mips64.cc | 911 ++- .../codegen/mips64/macro-assembler-mips64.h | 233 +- deps/v8/src/codegen/ppc/assembler-ppc-inl.h | 4 +- deps/v8/src/codegen/ppc/assembler-ppc.cc | 16 +- deps/v8/src/codegen/ppc/assembler-ppc.h | 8 +- deps/v8/src/codegen/ppc/constants-ppc.h | 66 +- .../ppc/interface-descriptors-ppc-inl.h | 3 + .../v8/src/codegen/ppc/macro-assembler-ppc.cc | 1399 ++-- deps/v8/src/codegen/ppc/macro-assembler-ppc.h | 235 +- deps/v8/src/codegen/register-base.h | 9 +- deps/v8/src/codegen/reloc-info.cc | 58 +- deps/v8/src/codegen/reloc-info.h | 21 +- .../src/codegen/riscv/assembler-riscv-inl.h | 22 +- deps/v8/src/codegen/riscv/assembler-riscv.cc | 494 +- deps/v8/src/codegen/riscv/assembler-riscv.h | 35 +- .../src/codegen/riscv/base-constants-riscv.h | 44 +- deps/v8/src/codegen/riscv/constant-riscv-a.h | 71 +- deps/v8/src/codegen/riscv/constant-riscv-c.h | 90 +- deps/v8/src/codegen/riscv/constant-riscv-d.h | 97 +- deps/v8/src/codegen/riscv/constant-riscv-f.h | 86 +- deps/v8/src/codegen/riscv/constant-riscv-i.h | 124 +- deps/v8/src/codegen/riscv/constant-riscv-m.h | 46 +- deps/v8/src/codegen/riscv/constant-riscv-v.h | 1027 +-- .../src/codegen/riscv/constant-riscv-zicsr.h | 16 +- .../codegen/riscv/constant-riscv-zifencei.h | 4 +- .../v8/src/codegen/riscv/extension-riscv-v.cc | 37 +- deps/v8/src/codegen/riscv/extension-riscv-v.h | 26 +- .../riscv/interface-descriptors-riscv-inl.h | 3 + .../codegen/riscv/macro-assembler-riscv.cc | 1048 ++- .../src/codegen/riscv/macro-assembler-riscv.h | 260 +- deps/v8/src/codegen/s390/assembler-s390-inl.h | 4 +- deps/v8/src/codegen/s390/assembler-s390.cc | 12 +- deps/v8/src/codegen/s390/assembler-s390.h | 11 +- deps/v8/src/codegen/s390/constants-s390.h | 66 +- .../s390/interface-descriptors-s390-inl.h | 3 + .../src/codegen/s390/macro-assembler-s390.cc | 1278 ++-- .../src/codegen/s390/macro-assembler-s390.h | 132 +- deps/v8/src/codegen/safepoint-table.cc | 30 +- deps/v8/src/codegen/safepoint-table.h | 18 +- .../macro-assembler-shared-ia32-x64.cc | 379 +- .../macro-assembler-shared-ia32-x64.h | 48 +- deps/v8/src/codegen/signature.h | 37 +- deps/v8/src/codegen/source-position.cc | 15 +- deps/v8/src/codegen/source-position.h | 11 +- deps/v8/src/codegen/x64/assembler-x64-inl.h | 62 +- deps/v8/src/codegen/x64/assembler-x64.cc | 199 +- deps/v8/src/codegen/x64/assembler-x64.h | 201 +- .../x64/interface-descriptors-x64-inl.h | 3 + .../v8/src/codegen/x64/macro-assembler-x64.cc | 1117 ++- deps/v8/src/codegen/x64/macro-assembler-x64.h | 248 +- deps/v8/src/codegen/x64/register-x64.h | 8 + deps/v8/src/common/assert-scope.cc | 10 +- deps/v8/src/common/assert-scope.h | 6 + deps/v8/src/common/globals.h | 137 +- deps/v8/src/common/message-template.h | 21 +- deps/v8/src/common/ptr-compr-inl.h | 148 +- deps/v8/src/common/ptr-compr.cc | 19 + deps/v8/src/common/ptr-compr.h | 61 +- deps/v8/src/compiler/OWNERS | 1 + deps/v8/src/compiler/access-builder.cc | 57 +- deps/v8/src/compiler/access-builder.h | 12 + deps/v8/src/compiler/access-info.cc | 177 +- deps/v8/src/compiler/access-info.h | 90 +- deps/v8/src/compiler/all-nodes.cc | 14 +- deps/v8/src/compiler/all-nodes.h | 8 +- deps/v8/src/compiler/allocation-builder.h | 7 +- deps/v8/src/compiler/backend/OWNERS | 2 - .../backend/arm/code-generator-arm.cc | 351 +- .../backend/arm/instruction-codes-arm.h | 4 + .../backend/arm/instruction-scheduler-arm.cc | 4 + .../backend/arm/instruction-selector-arm.cc | 18 +- .../backend/arm64/code-generator-arm64.cc | 679 +- .../backend/arm64/instruction-codes-arm64.h | 6 +- .../arm64/instruction-scheduler-arm64.cc | 9 +- .../arm64/instruction-selector-arm64.cc | 136 +- .../v8/src/compiler/backend/bitcast-elider.cc | 57 +- deps/v8/src/compiler/backend/bitcast-elider.h | 9 +- .../compiler/backend/code-generator-impl.h | 8 +- .../v8/src/compiler/backend/code-generator.cc | 148 +- deps/v8/src/compiler/backend/code-generator.h | 20 +- deps/v8/src/compiler/backend/frame-elider.cc | 12 + deps/v8/src/compiler/backend/gap-resolver.cc | 286 +- deps/v8/src/compiler/backend/gap-resolver.h | 36 +- .../backend/ia32/code-generator-ia32.cc | 237 +- .../backend/ia32/instruction-codes-ia32.h | 3 + .../ia32/instruction-scheduler-ia32.cc | 3 + .../backend/ia32/instruction-selector-ia32.cc | 44 +- .../src/compiler/backend/instruction-codes.h | 12 +- .../compiler/backend/instruction-scheduler.h | 2 +- .../compiler/backend/instruction-selector.cc | 165 +- .../compiler/backend/instruction-selector.h | 13 +- deps/v8/src/compiler/backend/instruction.cc | 50 +- deps/v8/src/compiler/backend/instruction.h | 30 +- .../v8/src/compiler/backend/jump-threading.cc | 10 +- .../backend/loong64/code-generator-loong64.cc | 196 +- .../loong64/instruction-selector-loong64.cc | 36 +- .../backend/mips64/code-generator-mips64.cc | 612 +- .../mips64/instruction-scheduler-mips64.cc | 2 +- .../mips64/instruction-selector-mips64.cc | 32 +- .../backend/ppc/code-generator-ppc.cc | 639 +- .../backend/ppc/instruction-codes-ppc.h | 3 +- .../backend/ppc/instruction-scheduler-ppc.cc | 3 +- .../backend/ppc/instruction-selector-ppc.cc | 4 +- .../compiler/backend/register-allocator.cc | 6 +- .../backend/riscv/code-generator-riscv.cc | 294 +- .../backend/riscv/instruction-codes-riscv.h | 3 +- .../riscv/instruction-scheduler-riscv.cc | 5 +- .../riscv/instruction-selector-riscv32.cc | 2 +- .../riscv/instruction-selector-riscv64.cc | 10 +- .../backend/s390/code-generator-s390.cc | 181 +- .../backend/s390/instruction-codes-s390.h | 3 +- .../s390/instruction-scheduler-s390.cc | 3 +- .../backend/s390/instruction-selector-s390.cc | 4 +- .../backend/x64/code-generator-x64.cc | 2308 ++++-- .../backend/x64/instruction-codes-x64.h | 167 +- .../backend/x64/instruction-scheduler-x64.cc | 163 +- .../backend/x64/instruction-selector-x64.cc | 624 +- .../src/compiler/basic-block-instrumentor.cc | 11 +- deps/v8/src/compiler/branch-elimination.cc | 88 + deps/v8/src/compiler/branch-elimination.h | 1 + deps/v8/src/compiler/bytecode-analysis.cc | 69 +- .../v8/src/compiler/bytecode-graph-builder.cc | 59 +- deps/v8/src/compiler/code-assembler.cc | 12 +- deps/v8/src/compiler/code-assembler.h | 20 +- .../src/compiler/common-operator-reducer.cc | 41 +- .../v8/src/compiler/common-operator-reducer.h | 11 +- deps/v8/src/compiler/common-operator.cc | 23 + deps/v8/src/compiler/common-operator.h | 7 + .../src/compiler/compilation-dependencies.cc | 260 +- .../src/compiler/compilation-dependencies.h | 9 +- .../src/compiler/constant-folding-reducer.cc | 6 +- deps/v8/src/compiler/csa-load-elimination.cc | 10 +- .../src/compiler/decompression-optimizer.cc | 7 + .../src/compiler/effect-control-linearizer.cc | 493 +- .../src/compiler/escape-analysis-reducer.cc | 16 +- deps/v8/src/compiler/fast-api-calls.cc | 12 +- deps/v8/src/compiler/globals.h | 2 + deps/v8/src/compiler/graph-assembler.cc | 50 +- deps/v8/src/compiler/graph-assembler.h | 71 +- deps/v8/src/compiler/graph-reducer.h | 6 +- deps/v8/src/compiler/graph-visualizer.cc | 31 +- deps/v8/src/compiler/graph.cc | 8 +- deps/v8/src/compiler/graph.h | 8 + deps/v8/src/compiler/heap-refs.cc | 756 +- deps/v8/src/compiler/heap-refs.h | 428 +- deps/v8/src/compiler/int64-lowering.cc | 178 +- deps/v8/src/compiler/int64-lowering.h | 33 +- deps/v8/src/compiler/js-call-reducer.cc | 437 +- deps/v8/src/compiler/js-call-reducer.h | 3 +- .../src/compiler/js-context-specialization.cc | 70 +- deps/v8/src/compiler/js-create-lowering.cc | 351 +- deps/v8/src/compiler/js-create-lowering.h | 8 +- deps/v8/src/compiler/js-generic-lowering.cc | 95 +- deps/v8/src/compiler/js-graph.cc | 41 +- deps/v8/src/compiler/js-graph.h | 11 +- deps/v8/src/compiler/js-heap-broker.cc | 115 +- deps/v8/src/compiler/js-heap-broker.h | 90 +- deps/v8/src/compiler/js-inlining-heuristic.cc | 80 +- deps/v8/src/compiler/js-inlining-heuristic.h | 6 +- deps/v8/src/compiler/js-inlining.cc | 32 +- deps/v8/src/compiler/js-inlining.h | 2 +- deps/v8/src/compiler/js-intrinsic-lowering.cc | 19 + deps/v8/src/compiler/js-intrinsic-lowering.h | 1 + .../js-native-context-specialization.cc | 1466 ++-- .../js-native-context-specialization.h | 20 +- deps/v8/src/compiler/js-operator.cc | 40 +- deps/v8/src/compiler/js-operator.h | 86 +- deps/v8/src/compiler/js-type-hint-lowering.cc | 77 +- deps/v8/src/compiler/js-typed-lowering.cc | 118 +- deps/v8/src/compiler/js-typed-lowering.h | 2 + deps/v8/src/compiler/late-escape-analysis.cc | 1 + deps/v8/src/compiler/linear-scheduler.cc | 4 +- deps/v8/src/compiler/linkage.h | 3 +- deps/v8/src/compiler/load-elimination.cc | 1 + deps/v8/src/compiler/load-elimination.h | 2 +- deps/v8/src/compiler/loop-analysis.cc | 57 +- deps/v8/src/compiler/loop-analysis.h | 6 +- deps/v8/src/compiler/loop-peeling.cc | 10 +- .../v8/src/compiler/machine-graph-verifier.cc | 53 +- deps/v8/src/compiler/machine-graph-verifier.h | 2 + deps/v8/src/compiler/machine-graph.cc | 6 +- deps/v8/src/compiler/machine-graph.h | 3 + .../src/compiler/machine-operator-reducer.cc | 483 +- .../src/compiler/machine-operator-reducer.h | 28 +- deps/v8/src/compiler/machine-operator.cc | 108 +- deps/v8/src/compiler/machine-operator.h | 24 + deps/v8/src/compiler/map-inference.cc | 3 +- deps/v8/src/compiler/memory-lowering.cc | 109 +- deps/v8/src/compiler/memory-optimizer.cc | 7 +- deps/v8/src/compiler/memory-optimizer.h | 2 +- deps/v8/src/compiler/node-matchers.h | 39 +- deps/v8/src/compiler/node-properties.cc | 82 +- deps/v8/src/compiler/node-properties.h | 10 +- deps/v8/src/compiler/opcodes.h | 547 +- deps/v8/src/compiler/operation-typer.cc | 142 +- deps/v8/src/compiler/operation-typer.h | 5 + deps/v8/src/compiler/operator-properties.cc | 5 +- deps/v8/src/compiler/pipeline.cc | 545 +- deps/v8/src/compiler/processed-feedback.h | 14 +- .../src/compiler/property-access-builder.cc | 26 +- .../v8/src/compiler/property-access-builder.h | 10 +- deps/v8/src/compiler/raw-machine-assembler.h | 8 +- .../v8/src/compiler/redundancy-elimination.cc | 84 +- deps/v8/src/compiler/redundancy-elimination.h | 8 +- deps/v8/src/compiler/representation-change.cc | 45 +- deps/v8/src/compiler/revectorizer.cc | 964 +++ deps/v8/src/compiler/revectorizer.h | 212 + deps/v8/src/compiler/schedule.cc | 18 +- deps/v8/src/compiler/scheduler.cc | 41 +- .../compiler/simplified-lowering-verifier.cc | 5 +- deps/v8/src/compiler/simplified-lowering.cc | 267 +- .../compiler/simplified-operator-reducer.cc | 2 +- deps/v8/src/compiler/simplified-operator.cc | 584 +- deps/v8/src/compiler/simplified-operator.h | 107 +- .../src/compiler/store-store-elimination.cc | 13 +- deps/v8/src/compiler/turbofan-disabled.cc | 25 + deps/v8/src/compiler/turbofan-enabled.cc | 27 + deps/v8/src/compiler/turbofan.h | 39 + deps/v8/src/compiler/turboshaft/assembler.cc | 16 + deps/v8/src/compiler/turboshaft/assembler.h | 1649 ++++- .../turboshaft/assert-types-reducer.h | 153 + .../turboshaft/branch-elimination-reducer.h | 489 ++ .../dead-code-elimination-reducer.h | 467 ++ .../turboshaft/decompression-optimization.cc | 2 +- .../turboshaft/define-assembler-macros.inc | 54 + deps/v8/src/compiler/turboshaft/deopt-data.h | 11 +- deps/v8/src/compiler/turboshaft/fast-hash.h | 9 +- .../src/compiler/turboshaft/graph-builder.cc | 520 +- .../src/compiler/turboshaft/graph-builder.h | 6 +- .../compiler/turboshaft/graph-visualizer.cc | 24 +- .../compiler/turboshaft/graph-visualizer.h | 3 + deps/v8/src/compiler/turboshaft/graph.cc | 24 +- deps/v8/src/compiler/turboshaft/graph.h | 273 +- deps/v8/src/compiler/turboshaft/index.h | 223 + .../late-escape-analysis-reducer.cc | 101 + .../turboshaft/late-escape-analysis-reducer.h | 67 + .../compiler/turboshaft/layered-hash-map.h | 194 + .../turboshaft/machine-lowering-reducer.h | 685 ++ .../turboshaft/machine-optimization-reducer.h | 144 +- .../turboshaft/memory-optimization.cc | 166 + .../compiler/turboshaft/memory-optimization.h | 269 + .../compiler/turboshaft/operation-matching.h | 25 +- deps/v8/src/compiler/turboshaft/operations.cc | 221 +- deps/v8/src/compiler/turboshaft/operations.h | 1129 ++- .../compiler/turboshaft/optimization-phase.h | 594 +- .../compiler/turboshaft/recreate-schedule.cc | 141 +- .../compiler/turboshaft/recreate-schedule.h | 2 + .../src/compiler/turboshaft/reducer-traits.h | 81 + .../src/compiler/turboshaft/representations.h | 137 +- .../turboshaft/select-lowering-reducer.h | 21 +- deps/v8/src/compiler/turboshaft/sidetable.h | 32 +- .../src/compiler/turboshaft/snapshot-table.h | 190 +- .../turboshaft/tag-untag-lowering-reducer.h | 58 + .../turboshaft/type-inference-analysis.h | 524 ++ .../turboshaft/type-inference-reducer.h | 517 ++ .../v8/src/compiler/turboshaft/type-parser.cc | 33 + deps/v8/src/compiler/turboshaft/type-parser.h | 124 + .../turboshaft/typed-optimizations-reducer.h | 138 + deps/v8/src/compiler/turboshaft/typer.cc | 99 + deps/v8/src/compiler/turboshaft/typer.h | 1561 ++++ deps/v8/src/compiler/turboshaft/types.cc | 715 ++ deps/v8/src/compiler/turboshaft/types.h | 916 +++ .../turboshaft/undef-assembler-macros.inc | 33 + .../turboshaft/uniform-reducer-adapter.h | 160 + deps/v8/src/compiler/turboshaft/utils.h | 19 + .../turboshaft/value-numbering-reducer.h | 12 +- .../compiler/turboshaft/variable-reducer.h | 308 + deps/v8/src/compiler/type-cache.h | 6 +- deps/v8/src/compiler/typed-optimization.cc | 48 +- deps/v8/src/compiler/typer.cc | 62 +- deps/v8/src/compiler/types.cc | 24 +- deps/v8/src/compiler/types.h | 21 +- deps/v8/src/compiler/use-info.h | 8 +- deps/v8/src/compiler/verifier.cc | 72 +- deps/v8/src/compiler/wasm-call-descriptors.cc | 57 + deps/v8/src/compiler/wasm-call-descriptors.h | 67 + .../src/compiler/wasm-compiler-definitions.h | 2 + deps/v8/src/compiler/wasm-compiler.cc | 1120 +-- deps/v8/src/compiler/wasm-compiler.h | 66 +- deps/v8/src/compiler/wasm-gc-lowering.cc | 673 +- deps/v8/src/compiler/wasm-gc-lowering.h | 18 +- .../src/compiler/wasm-gc-operator-reducer.cc | 126 +- .../src/compiler/wasm-gc-operator-reducer.h | 3 + deps/v8/src/compiler/wasm-graph-assembler.cc | 129 +- deps/v8/src/compiler/wasm-graph-assembler.h | 41 +- deps/v8/src/compiler/wasm-inlining.cc | 169 +- deps/v8/src/compiler/wasm-inlining.h | 4 +- deps/v8/src/compiler/wasm-load-elimination.cc | 526 ++ deps/v8/src/compiler/wasm-load-elimination.h | 155 + deps/v8/src/compiler/wasm-typer.cc | 171 +- deps/v8/src/compiler/wasm-typer.h | 1 - deps/v8/src/d8/d8-console.cc | 81 + deps/v8/src/d8/d8-console.h | 13 + deps/v8/src/d8/d8-test.cc | 176 +- deps/v8/src/d8/d8.cc | 464 +- deps/v8/src/d8/d8.h | 40 +- deps/v8/src/debug/debug-coverage.cc | 2 +- deps/v8/src/debug/debug-evaluate.cc | 120 +- deps/v8/src/debug/debug-frames.cc | 3 +- deps/v8/src/debug/debug-interface.cc | 22 +- deps/v8/src/debug/debug-interface.h | 27 +- deps/v8/src/debug/debug-scopes.cc | 27 +- deps/v8/src/debug/debug-scopes.h | 2 - .../v8/src/debug/debug-stack-trace-iterator.h | 2 +- deps/v8/src/debug/debug-wasm-objects.cc | 4 + deps/v8/src/debug/debug.cc | 147 +- deps/v8/src/debug/debug.h | 6 +- deps/v8/src/debug/liveedit.cc | 10 +- .../src/debug/wasm/gdb-server/gdb-server.cc | 2 +- .../wasm/gdb-server/wasm-module-debug.cc | 8 +- .../debug/wasm/gdb-server/wasm-module-debug.h | 2 +- deps/v8/src/deoptimizer/deoptimize-reason.h | 2 + deps/v8/src/deoptimizer/deoptimizer.cc | 230 +- deps/v8/src/deoptimizer/deoptimizer.h | 25 +- deps/v8/src/deoptimizer/translated-state.cc | 292 +- deps/v8/src/deoptimizer/translation-array.cc | 475 +- deps/v8/src/deoptimizer/translation-array.h | 116 +- deps/v8/src/deoptimizer/translation-opcode.h | 24 +- deps/v8/src/diagnostics/arm64/disasm-arm64.cc | 266 +- deps/v8/src/diagnostics/disassembler.cc | 16 +- deps/v8/src/diagnostics/etw-jit-win.cc | 1 + deps/v8/src/diagnostics/gdb-jit.cc | 4 +- deps/v8/src/diagnostics/gdb-jit.h | 4 +- deps/v8/src/diagnostics/objects-debug.cc | 161 +- deps/v8/src/diagnostics/objects-printer.cc | 191 +- deps/v8/src/diagnostics/perf-jit.cc | 100 +- deps/v8/src/diagnostics/perf-jit.h | 10 +- deps/v8/src/diagnostics/riscv/disasm-riscv.cc | 2 +- .../src/diagnostics/unwinding-info-win64.cc | 2 +- deps/v8/src/diagnostics/x64/disasm-x64.cc | 3 +- .../src/execution/arm/frame-constants-arm.cc | 6 + .../src/execution/arm/frame-constants-arm.h | 2 +- deps/v8/src/execution/arm/simulator-arm.cc | 4 + .../execution/arm64/frame-constants-arm64.cc | 10 + .../execution/arm64/frame-constants-arm64.h | 2 +- .../src/execution/arm64/pointer-auth-arm64.cc | 1 + .../v8/src/execution/arm64/simulator-arm64.cc | 359 + deps/v8/src/execution/arm64/simulator-arm64.h | 8 + deps/v8/src/execution/execution.cc | 9 +- deps/v8/src/execution/execution.h | 2 +- deps/v8/src/execution/frames-inl.h | 90 +- deps/v8/src/execution/frames.cc | 911 ++- deps/v8/src/execution/frames.h | 174 +- deps/v8/src/execution/futex-emulation.cc | 6 +- .../execution/ia32/frame-constants-ia32.cc | 6 + .../src/execution/ia32/frame-constants-ia32.h | 2 +- deps/v8/src/execution/interrupts-scope.cc | 9 - deps/v8/src/execution/interrupts-scope.h | 38 +- deps/v8/src/execution/isolate-data.h | 28 +- deps/v8/src/execution/isolate-inl.h | 6 +- deps/v8/src/execution/isolate-utils-inl.h | 4 +- deps/v8/src/execution/isolate.cc | 663 +- deps/v8/src/execution/isolate.h | 161 +- .../loong64/frame-constants-loong64.cc | 6 + .../loong64/frame-constants-loong64.h | 2 +- .../execution/loong64/simulator-loong64.cc | 4 + deps/v8/src/execution/messages.cc | 10 +- deps/v8/src/execution/microtask-queue.cc | 5 +- .../mips64/frame-constants-mips64.cc | 6 + .../execution/mips64/frame-constants-mips64.h | 2 +- .../src/execution/mips64/simulator-mips64.cc | 4 + .../src/execution/ppc/frame-constants-ppc.cc | 6 + .../src/execution/ppc/frame-constants-ppc.h | 13 +- deps/v8/src/execution/ppc/simulator-ppc.cc | 4 + deps/v8/src/execution/protectors.h | 9 + .../execution/riscv/frame-constants-riscv.cc | 6 + .../execution/riscv/frame-constants-riscv.h | 2 +- .../v8/src/execution/riscv/simulator-riscv.cc | 38 +- deps/v8/src/execution/riscv/simulator-riscv.h | 1 + .../execution/s390/frame-constants-s390.cc | 6 + .../src/execution/s390/frame-constants-s390.h | 8 +- deps/v8/src/execution/s390/simulator-s390.cc | 4 + deps/v8/src/execution/simulator.h | 5 +- deps/v8/src/execution/stack-guard.cc | 6 +- deps/v8/src/execution/stack-guard.h | 6 +- deps/v8/src/execution/thread-local-top.cc | 2 - deps/v8/src/execution/thread-local-top.h | 6 +- deps/v8/src/execution/tiering-manager.cc | 35 +- deps/v8/src/execution/tiering-manager.h | 2 +- deps/v8/src/execution/vm-state-inl.h | 7 +- deps/v8/src/execution/vm-state.h | 18 +- .../src/execution/x64/frame-constants-x64.cc | 8 + .../src/execution/x64/frame-constants-x64.h | 8 +- deps/v8/src/extensions/gc-extension.cc | 3 + .../v8/src/extensions/statistics-extension.cc | 4 +- deps/v8/src/flags/flag-definitions.h | 297 +- deps/v8/src/flags/flags.cc | 88 +- deps/v8/src/flags/flags.h | 1 + deps/v8/src/handles/global-handles.cc | 111 +- deps/v8/src/handles/global-handles.h | 19 +- deps/v8/src/handles/handles.cc | 6 +- deps/v8/src/handles/traced-handles.cc | 252 +- deps/v8/src/handles/traced-handles.h | 25 +- deps/v8/src/heap/OWNERS | 1 + deps/v8/src/heap/array-buffer-sweeper.cc | 44 +- deps/v8/src/heap/array-buffer-sweeper.h | 11 +- deps/v8/src/heap/base-space.h | 7 +- .../heap/base/asm/arm/push_registers_asm.cc | 39 + .../heap/base/asm/arm/save_registers_asm.cc | 36 - .../heap/base/asm/arm64/push_registers_asm.cc | 62 + .../heap/base/asm/arm64/push_registers_masm.S | 32 + .../heap/base/asm/arm64/save_registers_asm.cc | 50 - .../heap/base/asm/arm64/save_registers_masm.S | 24 - .../heap/base/asm/ia32/push_registers_asm.cc | 53 + .../base/asm/ia32/push_registers_masm.asm | 48 + .../heap/base/asm/ia32/save_registers_asm.cc | 48 - .../base/asm/ia32/save_registers_masm.asm | 36 - .../base/asm/loong64/push_registers_asm.cc | 48 + .../base/asm/loong64/save_registers_asm.cc | 40 - .../base/asm/mips64/push_registers_asm.cc | 49 + .../base/asm/mips64/save_registers_asm.cc | 41 - .../heap/base/asm/ppc/push_registers_asm.cc | 97 + .../heap/base/asm/ppc/save_registers_asm.cc | 110 - .../heap/base/asm/riscv/push_registers_asm.cc | 93 + .../heap/base/asm/riscv/save_registers_asm.cc | 68 - .../heap/base/asm/s390/push_registers_asm.cc | 37 + .../heap/base/asm/s390/save_registers_asm.cc | 32 - .../heap/base/asm/x64/push_registers_asm.cc | 106 + .../heap/base/asm/x64/push_registers_masm.asm | 57 + .../heap/base/asm/x64/save_registers_asm.cc | 94 - .../heap/base/asm/x64/save_registers_masm.asm | 43 - deps/v8/src/heap/base/basic-slot-set.h | 5 + deps/v8/src/heap/base/stack.cc | 188 +- deps/v8/src/heap/base/stack.h | 122 +- deps/v8/src/heap/base/worklist.cc | 13 +- deps/v8/src/heap/base/worklist.h | 22 +- deps/v8/src/heap/basic-memory-chunk.cc | 17 +- deps/v8/src/heap/basic-memory-chunk.h | 8 + deps/v8/src/heap/code-range.cc | 234 +- deps/v8/src/heap/code-range.h | 10 +- deps/v8/src/heap/combined-heap.cc | 3 +- deps/v8/src/heap/combined-heap.h | 1 - deps/v8/src/heap/concurrent-allocator-inl.h | 1 + deps/v8/src/heap/concurrent-allocator.cc | 24 +- deps/v8/src/heap/concurrent-allocator.h | 9 +- deps/v8/src/heap/concurrent-marking.cc | 76 +- .../v8/src/heap/conservative-stack-visitor.cc | 150 +- deps/v8/src/heap/conservative-stack-visitor.h | 20 +- deps/v8/src/heap/cppgc-js/cpp-heap.cc | 312 +- deps/v8/src/heap/cppgc-js/cpp-heap.h | 65 +- .../src/heap/cppgc-js/cpp-marking-state-inl.h | 11 +- deps/v8/src/heap/cppgc-js/cpp-marking-state.h | 2 +- deps/v8/src/heap/cppgc-js/cpp-snapshot.cc | 17 +- .../cppgc-js/cross-heap-remembered-set.cc | 36 + .../heap/cppgc-js/cross-heap-remembered-set.h | 54 + .../cppgc-js/unified-heap-marking-state-inl.h | 33 +- .../cppgc-js/unified-heap-marking-state.cc | 8 +- .../cppgc-js/unified-heap-marking-state.h | 5 +- .../cppgc-js/unified-heap-marking-visitor.cc | 26 +- .../cppgc-js/unified-heap-marking-visitor.h | 29 +- .../v8/src/heap/cppgc-js/wrappable-info-inl.h | 50 + deps/v8/src/heap/cppgc-js/wrappable-info.h | 34 + deps/v8/src/heap/cppgc/DEPS | 5 + deps/v8/src/heap/cppgc/concurrent-marker.cc | 14 - deps/v8/src/heap/cppgc/gc-info.cc | 32 +- deps/v8/src/heap/cppgc/globals.h | 2 +- deps/v8/src/heap/cppgc/heap-base.cc | 44 +- deps/v8/src/heap/cppgc/heap-base.h | 13 +- deps/v8/src/heap/cppgc/heap.cc | 11 +- deps/v8/src/heap/cppgc/marker.cc | 31 +- deps/v8/src/heap/cppgc/marking-state.cc | 47 + deps/v8/src/heap/cppgc/marking-state.h | 113 +- deps/v8/src/heap/cppgc/marking-verifier.cc | 6 +- deps/v8/src/heap/cppgc/marking-verifier.h | 2 +- deps/v8/src/heap/cppgc/marking-visitor.cc | 2 +- deps/v8/src/heap/cppgc/marking-worklists.cc | 3 +- deps/v8/src/heap/cppgc/marking-worklists.h | 18 +- deps/v8/src/heap/cppgc/member-storage.cc | 9 +- deps/v8/src/heap/cppgc/object-allocator.cc | 33 +- deps/v8/src/heap/cppgc/object-allocator.h | 43 +- deps/v8/src/heap/cppgc/pointer-policies.cc | 2 +- deps/v8/src/heap/cppgc/stats-collector.cc | 10 +- deps/v8/src/heap/cppgc/stats-collector.h | 9 +- deps/v8/src/heap/cppgc/sweeper.cc | 59 +- deps/v8/src/heap/cppgc/write-barrier.cc | 49 + deps/v8/src/heap/embedder-tracing-inl.h | 46 - deps/v8/src/heap/embedder-tracing.cc | 211 - deps/v8/src/heap/embedder-tracing.h | 240 - deps/v8/src/heap/evacuation-verifier-inl.h | 4 +- deps/v8/src/heap/evacuation-verifier.cc | 25 +- deps/v8/src/heap/evacuation-verifier.h | 8 +- deps/v8/src/heap/factory-base.cc | 59 +- deps/v8/src/heap/factory-base.h | 15 +- deps/v8/src/heap/factory.cc | 539 +- deps/v8/src/heap/factory.h | 73 +- deps/v8/src/heap/free-list.h | 1 + deps/v8/src/heap/gc-tracer.cc | 102 +- deps/v8/src/heap/gc-tracer.h | 6 +- .../src/heap/global-handle-marking-visitor.h | 36 - deps/v8/src/heap/heap-allocator.cc | 5 - deps/v8/src/heap/heap-inl.h | 52 +- deps/v8/src/heap/heap-verifier.cc | 465 +- deps/v8/src/heap/heap-verifier.h | 24 +- deps/v8/src/heap/heap-write-barrier-inl.h | 147 +- deps/v8/src/heap/heap-write-barrier.cc | 110 +- deps/v8/src/heap/heap-write-barrier.h | 56 +- deps/v8/src/heap/heap.cc | 1355 ++-- deps/v8/src/heap/heap.h | 377 +- deps/v8/src/heap/incremental-marking-job.cc | 1 - deps/v8/src/heap/incremental-marking.cc | 222 +- deps/v8/src/heap/incremental-marking.h | 3 +- deps/v8/src/heap/large-spaces.cc | 133 +- deps/v8/src/heap/large-spaces.h | 5 +- deps/v8/src/heap/local-heap.cc | 57 +- deps/v8/src/heap/local-heap.h | 3 + deps/v8/src/heap/mark-compact-inl.h | 94 +- deps/v8/src/heap/mark-compact.cc | 2238 +++--- deps/v8/src/heap/mark-compact.h | 155 +- deps/v8/src/heap/marking-barrier-inl.h | 88 +- deps/v8/src/heap/marking-barrier.cc | 203 +- deps/v8/src/heap/marking-barrier.h | 39 +- deps/v8/src/heap/marking-state-inl.h | 6 - deps/v8/src/heap/marking-state.h | 4 +- deps/v8/src/heap/marking-visitor-inl.h | 139 +- deps/v8/src/heap/marking-visitor.h | 49 +- deps/v8/src/heap/marking-worklist-inl.h | 11 - deps/v8/src/heap/marking-worklist.cc | 9 +- deps/v8/src/heap/marking-worklist.h | 10 - deps/v8/src/heap/memory-allocator.cc | 94 +- deps/v8/src/heap/memory-allocator.h | 51 +- deps/v8/src/heap/memory-chunk-layout.cc | 17 + deps/v8/src/heap/memory-chunk-layout.h | 12 +- deps/v8/src/heap/memory-chunk.cc | 34 +- deps/v8/src/heap/memory-chunk.h | 15 +- deps/v8/src/heap/memory-reducer.cc | 144 +- deps/v8/src/heap/memory-reducer.h | 73 +- deps/v8/src/heap/new-spaces-inl.h | 2 +- deps/v8/src/heap/new-spaces.cc | 214 +- deps/v8/src/heap/new-spaces.h | 90 +- deps/v8/src/heap/object-stats.cc | 37 +- deps/v8/src/heap/object-stats.h | 4 +- deps/v8/src/heap/objects-visiting-inl.h | 13 +- deps/v8/src/heap/objects-visiting.cc | 36 +- deps/v8/src/heap/objects-visiting.h | 10 +- deps/v8/src/heap/paged-spaces-inl.h | 4 +- deps/v8/src/heap/paged-spaces.cc | 262 +- deps/v8/src/heap/paged-spaces.h | 41 +- deps/v8/src/heap/parked-scope.h | 26 + deps/v8/src/heap/pretenuring-handler-inl.h | 10 +- deps/v8/src/heap/pretenuring-handler.cc | 63 +- deps/v8/src/heap/pretenuring-handler.h | 12 +- deps/v8/src/heap/read-only-heap-inl.h | 27 +- deps/v8/src/heap/read-only-heap.cc | 18 +- deps/v8/src/heap/read-only-heap.h | 18 +- deps/v8/src/heap/read-only-spaces.cc | 117 +- deps/v8/src/heap/read-only-spaces.h | 13 +- deps/v8/src/heap/remembered-set-inl.h | 24 +- deps/v8/src/heap/remembered-set.h | 31 +- deps/v8/src/heap/safepoint.cc | 48 +- deps/v8/src/heap/safepoint.h | 9 +- deps/v8/src/heap/scavenger-inl.h | 74 +- deps/v8/src/heap/scavenger.cc | 84 +- deps/v8/src/heap/scavenger.h | 9 +- deps/v8/src/heap/setup-heap-internal.cc | 405 +- deps/v8/src/heap/slot-set.h | 16 + deps/v8/src/heap/spaces.cc | 33 +- deps/v8/src/heap/spaces.h | 21 +- deps/v8/src/heap/stress-marking-observer.cc | 6 +- deps/v8/src/heap/stress-marking-observer.h | 5 +- deps/v8/src/heap/sweeper.cc | 762 +- deps/v8/src/heap/sweeper.h | 133 +- ...r.cc => traced-handles-marking-visitor.cc} | 20 +- .../src/heap/traced-handles-marking-visitor.h | 40 + deps/v8/src/heap/weak-object-worklists.h | 2 +- deps/v8/src/ic/accessor-assembler.cc | 197 +- deps/v8/src/ic/accessor-assembler.h | 20 +- deps/v8/src/ic/binary-op-assembler.cc | 253 +- deps/v8/src/ic/handler-configuration-inl.h | 8 +- deps/v8/src/ic/handler-configuration.cc | 17 +- deps/v8/src/ic/handler-configuration.h | 12 +- deps/v8/src/ic/ic-inl.h | 2 +- deps/v8/src/ic/ic.cc | 47 +- deps/v8/src/ic/keyed-store-generic.cc | 29 +- deps/v8/src/ic/stub-cache.cc | 19 - deps/v8/src/ic/stub-cache.h | 4 - deps/v8/src/ic/unary-op-assembler.cc | 3 +- deps/v8/src/init/bootstrapper.cc | 184 +- deps/v8/src/init/heap-symbols.h | 83 +- deps/v8/src/init/isolate-allocator.cc | 13 +- deps/v8/src/init/setup-isolate-deserialize.cc | 22 +- deps/v8/src/init/setup-isolate-full.cc | 27 +- deps/v8/src/init/setup-isolate.h | 12 +- deps/v8/src/inspector/BUILD.gn | 4 + deps/v8/src/inspector/crc32.cc | 85 + deps/v8/src/inspector/crc32.h | 16 + deps/v8/src/inspector/string-16.cc | 18 +- deps/v8/src/inspector/string-16.h | 1 + .../src/inspector/v8-debugger-agent-impl.cc | 200 +- .../v8/src/inspector/v8-debugger-agent-impl.h | 14 +- deps/v8/src/inspector/v8-debugger-barrier.cc | 19 + deps/v8/src/inspector/v8-debugger-barrier.h | 28 + deps/v8/src/inspector/v8-debugger.cc | 170 +- deps/v8/src/inspector/v8-debugger.h | 19 +- deps/v8/src/inspector/v8-inspector-impl.cc | 25 +- deps/v8/src/inspector/v8-inspector-impl.h | 6 +- .../inspector/v8-inspector-session-impl.cc | 17 +- .../src/inspector/v8-inspector-session-impl.h | 9 +- .../v8/src/inspector/v8-runtime-agent-impl.cc | 51 +- deps/v8/src/inspector/v8-runtime-agent-impl.h | 8 +- deps/v8/src/inspector/v8-stack-trace-impl.cc | 18 + deps/v8/src/inspector/v8-stack-trace-impl.h | 2 + deps/v8/src/inspector/value-mirror.cc | 12 +- .../src/interpreter/bytecode-array-builder.cc | 5 +- .../src/interpreter/bytecode-array-builder.h | 5 +- deps/v8/src/interpreter/bytecode-flags.cc | 13 + deps/v8/src/interpreter/bytecode-flags.h | 2 + deps/v8/src/interpreter/bytecode-generator.cc | 178 +- deps/v8/src/interpreter/bytecode-generator.h | 27 +- deps/v8/src/interpreter/bytecodes.h | 3 +- .../src/interpreter/interpreter-assembler.cc | 10 +- .../src/interpreter/interpreter-generator.cc | 13 +- deps/v8/src/interpreter/interpreter.cc | 16 +- deps/v8/src/interpreter/interpreter.h | 6 +- deps/v8/src/json/json-parser.cc | 258 +- deps/v8/src/json/json-parser.h | 29 +- deps/v8/src/json/json-stringifier.cc | 7 +- .../libplatform/tracing/tracing-controller.cc | 11 +- deps/v8/src/logging/code-events.h | 46 +- deps/v8/src/logging/counters-definitions.h | 15 +- deps/v8/src/logging/local-logger.cc | 3 +- deps/v8/src/logging/local-logger.h | 2 +- deps/v8/src/logging/log-file.cc | 1 + deps/v8/src/logging/log.cc | 281 +- deps/v8/src/logging/log.h | 44 +- deps/v8/src/logging/runtime-call-stats.h | 22 +- deps/v8/src/maglev/DEPS | 6 - .../maglev/arm64/maglev-assembler-arm64-inl.h | 794 ++ .../maglev/arm64/maglev-assembler-arm64.cc | 756 ++ deps/v8/src/maglev/arm64/maglev-ir-arm64.cc | 2305 ++++++ deps/v8/src/maglev/maglev-assembler-inl.h | 210 +- deps/v8/src/maglev/maglev-assembler.cc | 345 +- deps/v8/src/maglev/maglev-assembler.h | 341 +- deps/v8/src/maglev/maglev-basic-block.h | 47 +- deps/v8/src/maglev/maglev-code-gen-state.h | 5 + deps/v8/src/maglev/maglev-code-generator.cc | 577 +- deps/v8/src/maglev/maglev-code-generator.h | 4 + deps/v8/src/maglev/maglev-compilation-info.cc | 1 + deps/v8/src/maglev/maglev-compilation-unit.cc | 7 +- deps/v8/src/maglev/maglev-compiler.cc | 202 +- deps/v8/src/maglev/maglev-compiler.h | 4 +- .../maglev/maglev-concurrent-dispatcher.cc | 32 +- .../src/maglev/maglev-concurrent-dispatcher.h | 4 +- deps/v8/src/maglev/maglev-graph-builder.cc | 3054 ++++++-- deps/v8/src/maglev/maglev-graph-builder.h | 931 ++- deps/v8/src/maglev/maglev-graph-printer.cc | 62 +- deps/v8/src/maglev/maglev-graph-processor.h | 12 +- deps/v8/src/maglev/maglev-graph-verifier.h | 303 +- deps/v8/src/maglev/maglev-graph.h | 76 +- .../maglev/maglev-interpreter-frame-state.cc | 484 +- .../maglev/maglev-interpreter-frame-state.h | 494 +- deps/v8/src/maglev/maglev-ir-inl.h | 82 +- deps/v8/src/maglev/maglev-ir.cc | 6066 +++++++-------- deps/v8/src/maglev/maglev-ir.h | 2723 +++++-- .../maglev-phi-representation-selector.cc | 318 + .../maglev-phi-representation-selector.h | 128 + deps/v8/src/maglev/maglev-regalloc.cc | 437 +- deps/v8/src/maglev/maglev-regalloc.h | 9 +- deps/v8/src/maglev/maglev-vreg-allocator.h | 55 - deps/v8/src/maglev/maglev.cc | 10 +- deps/v8/src/maglev/maglev.h | 4 +- .../src/maglev/x64/maglev-assembler-x64-inl.h | 648 ++ .../v8/src/maglev/x64/maglev-assembler-x64.cc | 659 ++ deps/v8/src/maglev/x64/maglev-ir-x64.cc | 2327 ++++++ deps/v8/src/numbers/conversions.cc | 123 +- deps/v8/src/numbers/conversions.h | 5 + deps/v8/src/objects/all-objects-inl.h | 2 + deps/v8/src/objects/backing-store.cc | 16 +- deps/v8/src/objects/backing-store.h | 4 + deps/v8/src/objects/bigint.cc | 177 +- deps/v8/src/objects/bigint.h | 37 +- deps/v8/src/objects/call-site-info-inl.h | 21 +- deps/v8/src/objects/code-inl.h | 1541 ++-- deps/v8/src/objects/code.cc | 315 +- deps/v8/src/objects/code.h | 805 +- deps/v8/src/objects/code.tq | 2 +- .../v8/src/objects/compilation-cache-table.cc | 4 +- deps/v8/src/objects/compressed-slots-inl.h | 32 +- deps/v8/src/objects/contexts-inl.h | 20 +- deps/v8/src/objects/contexts.cc | 24 +- deps/v8/src/objects/contexts.h | 17 +- deps/v8/src/objects/contexts.tq | 4 + deps/v8/src/objects/data-handler.tq | 11 +- deps/v8/src/objects/descriptor-array.h | 1 - deps/v8/src/objects/dictionary-inl.h | 26 +- deps/v8/src/objects/dictionary.h | 32 +- deps/v8/src/objects/elements-kind.h | 14 + deps/v8/src/objects/elements.cc | 9 +- deps/v8/src/objects/feedback-vector-inl.h | 29 +- deps/v8/src/objects/feedback-vector.cc | 54 +- deps/v8/src/objects/feedback-vector.h | 19 +- deps/v8/src/objects/feedback-vector.tq | 4 +- deps/v8/src/objects/field-index-inl.h | 4 + deps/v8/src/objects/field-index.h | 1 + deps/v8/src/objects/fixed-array-inl.h | 6 +- deps/v8/src/objects/fixed-array.h | 16 +- deps/v8/src/objects/free-space-inl.h | 32 +- deps/v8/src/objects/free-space.h | 14 +- deps/v8/src/objects/free-space.tq | 2 +- deps/v8/src/objects/hash-table-inl.h | 13 +- deps/v8/src/objects/hash-table.h | 50 + deps/v8/src/objects/heap-object.h | 21 +- deps/v8/src/objects/instance-type-inl.h | 203 +- deps/v8/src/objects/instance-type.h | 38 +- deps/v8/src/objects/intl-objects.cc | 30 +- deps/v8/src/objects/js-array-buffer-inl.h | 29 +- deps/v8/src/objects/js-array-buffer.cc | 22 +- deps/v8/src/objects/js-array-buffer.h | 35 +- deps/v8/src/objects/js-array-buffer.tq | 7 +- deps/v8/src/objects/js-array.tq | 27 +- .../objects/js-atomics-synchronization-inl.h | 1 + .../src/objects/js-atomics-synchronization.h | 11 +- .../src/objects/js-atomics-synchronization.tq | 2 +- deps/v8/src/objects/js-date-time-format.cc | 6 +- deps/v8/src/objects/js-duration-format.cc | 44 +- deps/v8/src/objects/js-function-inl.h | 44 +- deps/v8/src/objects/js-function.cc | 53 +- deps/v8/src/objects/js-function.h | 25 +- deps/v8/src/objects/js-function.tq | 3 +- deps/v8/src/objects/js-iterator-helpers-inl.h | 31 + deps/v8/src/objects/js-iterator-helpers.h | 88 + deps/v8/src/objects/js-iterator-helpers.tq | 18 + deps/v8/src/objects/js-locale.cc | 2 +- deps/v8/src/objects/js-number-format.cc | 56 +- deps/v8/src/objects/js-objects-inl.h | 26 +- deps/v8/src/objects/js-objects.cc | 275 +- deps/v8/src/objects/js-objects.h | 25 +- deps/v8/src/objects/js-objects.tq | 2 +- deps/v8/src/objects/js-raw-json.cc | 2 +- deps/v8/src/objects/js-regexp-inl.h | 4 +- deps/v8/src/objects/js-regexp.cc | 9 +- deps/v8/src/objects/js-regexp.h | 8 +- deps/v8/src/objects/js-shared-array-inl.h | 1 + deps/v8/src/objects/js-shared-array.h | 16 +- deps/v8/src/objects/js-shared-array.tq | 2 +- deps/v8/src/objects/js-struct-inl.h | 2 + deps/v8/src/objects/js-struct.cc | 49 + deps/v8/src/objects/js-struct.h | 16 +- deps/v8/src/objects/js-struct.tq | 9 +- deps/v8/src/objects/js-temporal-objects.cc | 21 +- deps/v8/src/objects/keys.cc | 41 +- deps/v8/src/objects/lookup-inl.h | 8 +- deps/v8/src/objects/lookup.cc | 79 +- deps/v8/src/objects/lookup.h | 4 +- deps/v8/src/objects/map-inl.h | 36 +- deps/v8/src/objects/map.cc | 56 +- deps/v8/src/objects/map.h | 15 +- deps/v8/src/objects/maybe-object-inl.h | 2 +- deps/v8/src/objects/module.cc | 2 +- deps/v8/src/objects/object-list-macros.h | 43 +- .../objects/objects-body-descriptors-inl.h | 73 +- deps/v8/src/objects/objects-definitions.h | 11 +- deps/v8/src/objects/objects-inl.h | 163 +- deps/v8/src/objects/objects.cc | 434 +- deps/v8/src/objects/objects.h | 71 +- deps/v8/src/objects/ordered-hash-table.cc | 2 +- deps/v8/src/objects/property-array-inl.h | 16 +- .../src/objects/property-descriptor-object.tq | 142 + deps/v8/src/objects/property-descriptor.cc | 39 +- deps/v8/src/objects/prototype-info-inl.h | 6 + deps/v8/src/objects/prototype-info.h | 2 + deps/v8/src/objects/scope-info.cc | 16 +- deps/v8/src/objects/scope-info.h | 5 +- deps/v8/src/objects/scope-info.tq | 4 +- deps/v8/src/objects/script-inl.h | 53 +- deps/v8/src/objects/script.h | 24 +- deps/v8/src/objects/script.tq | 12 +- .../v8/src/objects/shared-function-info-inl.h | 32 +- deps/v8/src/objects/shared-function-info.cc | 10 +- deps/v8/src/objects/shared-function-info.h | 8 +- deps/v8/src/objects/shared-function-info.tq | 3 +- deps/v8/src/objects/simd.cc | 9 +- deps/v8/src/objects/slots-inl.h | 59 +- deps/v8/src/objects/source-text-module.cc | 3 +- deps/v8/src/objects/string-comparator.cc | 5 +- .../src/objects/string-forwarding-table-inl.h | 11 +- .../v8/src/objects/string-forwarding-table.cc | 105 +- deps/v8/src/objects/string-forwarding-table.h | 3 +- deps/v8/src/objects/string-inl.h | 86 +- deps/v8/src/objects/string-table.cc | 20 +- deps/v8/src/objects/string.cc | 108 +- deps/v8/src/objects/string.h | 37 +- deps/v8/src/objects/string.tq | 39 +- deps/v8/src/objects/swiss-name-dictionary.h | 4 + deps/v8/src/objects/synthetic-module.cc | 3 +- deps/v8/src/objects/tagged-field-inl.h | 5 +- deps/v8/src/objects/tagged-field.h | 2 +- deps/v8/src/objects/tagged-impl-inl.h | 11 +- deps/v8/src/objects/tagged-impl.cc | 9 +- deps/v8/src/objects/tagged-impl.h | 16 +- deps/v8/src/objects/tagged-value-inl.h | 4 +- deps/v8/src/objects/transitions.cc | 31 +- deps/v8/src/objects/turboshaft-types-inl.h | 33 + deps/v8/src/objects/turboshaft-types.h | 115 + deps/v8/src/objects/turboshaft-types.tq | 234 + deps/v8/src/objects/type-hints.cc | 2 + deps/v8/src/objects/type-hints.h | 1 + deps/v8/src/objects/value-serializer.cc | 215 +- deps/v8/src/objects/value-serializer.h | 14 +- deps/v8/src/objects/visitors.h | 50 +- deps/v8/src/parsing/parse-info.cc | 17 +- deps/v8/src/parsing/parse-info.h | 13 +- deps/v8/src/parsing/parser-base.h | 53 +- deps/v8/src/parsing/parser.cc | 42 +- .../pending-compilation-error-handler.cc | 9 +- .../pending-compilation-error-handler.h | 2 + deps/v8/src/parsing/preparser.h | 2 +- deps/v8/src/parsing/scanner-inl.h | 29 +- deps/v8/src/parsing/scanner.h | 8 +- deps/v8/src/profiler/allocation-tracker.cc | 2 +- deps/v8/src/profiler/cpu-profiler-inl.h | 41 +- deps/v8/src/profiler/cpu-profiler.cc | 5 +- deps/v8/src/profiler/cpu-profiler.h | 30 +- .../src/profiler/heap-snapshot-generator.cc | 204 +- .../v8/src/profiler/heap-snapshot-generator.h | 19 +- deps/v8/src/profiler/profile-generator.cc | 23 +- deps/v8/src/profiler/profile-generator.h | 20 +- deps/v8/src/profiler/profiler-listener.cc | 40 +- deps/v8/src/profiler/profiler-listener.h | 12 +- .../v8/src/profiler/sampling-heap-profiler.cc | 9 +- deps/v8/src/profiler/symbolizer.cc | 9 +- deps/v8/src/profiler/symbolizer.h | 12 +- deps/v8/src/profiler/tick-sample.cc | 12 +- deps/v8/src/profiler/tracing-cpu-profiler.cc | 19 + deps/v8/src/profiler/tracing-cpu-profiler.h | 11 + deps/v8/src/profiler/weak-code-registry.h | 5 +- .../regexp/arm/regexp-macro-assembler-arm.cc | 195 +- .../regexp/arm/regexp-macro-assembler-arm.h | 59 +- .../arm64/regexp-macro-assembler-arm64.cc | 138 +- .../arm64/regexp-macro-assembler-arm64.h | 64 +- .../experimental/experimental-compiler.cc | 21 +- .../src/regexp/experimental/experimental.cc | 6 +- .../ia32/regexp-macro-assembler-ia32.cc | 148 +- .../regexp/ia32/regexp-macro-assembler-ia32.h | 68 +- .../loong64/regexp-macro-assembler-loong64.cc | 189 +- .../loong64/regexp-macro-assembler-loong64.h | 59 +- .../mips64/regexp-macro-assembler-mips64.cc | 208 +- .../mips64/regexp-macro-assembler-mips64.h | 58 +- .../regexp/ppc/regexp-macro-assembler-ppc.cc | 167 +- .../regexp/ppc/regexp-macro-assembler-ppc.h | 64 +- deps/v8/src/regexp/regexp-ast.cc | 67 + deps/v8/src/regexp/regexp-ast.h | 102 +- deps/v8/src/regexp/regexp-compiler-tonode.cc | 279 +- deps/v8/src/regexp/regexp-compiler.cc | 4 +- deps/v8/src/regexp/regexp-error.h | 4 +- deps/v8/src/regexp/regexp-macro-assembler.cc | 10 +- deps/v8/src/regexp/regexp-macro-assembler.h | 6 +- deps/v8/src/regexp/regexp-parser.cc | 996 ++- deps/v8/src/regexp/regexp.cc | 25 +- .../riscv/regexp-macro-assembler-riscv.cc | 167 +- .../riscv/regexp-macro-assembler-riscv.h | 63 +- .../s390/regexp-macro-assembler-s390.cc | 169 +- .../regexp/s390/regexp-macro-assembler-s390.h | 54 +- .../regexp/x64/regexp-macro-assembler-x64.cc | 190 +- .../regexp/x64/regexp-macro-assembler-x64.h | 101 +- deps/v8/src/roots/roots-inl.h | 53 +- deps/v8/src/roots/roots.cc | 28 + deps/v8/src/roots/roots.h | 68 +- deps/v8/src/roots/static-roots.h | 1543 ++++ deps/v8/src/runtime/runtime-bigint.cc | 19 + deps/v8/src/runtime/runtime-classes.cc | 10 +- deps/v8/src/runtime/runtime-compiler.cc | 68 +- deps/v8/src/runtime/runtime-date.cc | 3 +- deps/v8/src/runtime/runtime-debug.cc | 13 +- deps/v8/src/runtime/runtime-internal.cc | 21 +- deps/v8/src/runtime/runtime-object.cc | 334 +- deps/v8/src/runtime/runtime-regexp.cc | 47 +- deps/v8/src/runtime/runtime-scopes.cc | 2 +- deps/v8/src/runtime/runtime-shadow-realm.cc | 12 + deps/v8/src/runtime/runtime-strings.cc | 59 +- deps/v8/src/runtime/runtime-test-wasm.cc | 81 +- deps/v8/src/runtime/runtime-test.cc | 89 +- deps/v8/src/runtime/runtime-trace.cc | 4 +- deps/v8/src/runtime/runtime-utils.h | 2 +- deps/v8/src/runtime/runtime-wasm.cc | 149 +- deps/v8/src/runtime/runtime.h | 62 +- deps/v8/src/sandbox/external-pointer-inl.h | 87 +- .../src/sandbox/external-pointer-table-inl.h | 13 +- deps/v8/src/sandbox/sandbox.cc | 164 +- deps/v8/src/sandbox/sandbox.h | 18 +- deps/v8/src/sanitizer/OWNERS | 3 - deps/v8/src/snapshot/code-serializer.cc | 52 +- deps/v8/src/snapshot/code-serializer.h | 6 +- deps/v8/src/snapshot/context-serializer.cc | 26 +- deps/v8/src/snapshot/deserializer.cc | 846 ++- deps/v8/src/snapshot/deserializer.h | 53 +- .../v8/src/snapshot/embedded/embedded-data.cc | 62 +- deps/v8/src/snapshot/embedded/embedded-data.h | 16 +- .../embedded/embedded-file-writer-interface.h | 2 +- .../snapshot/embedded/embedded-file-writer.cc | 5 +- .../platform-embedded-file-writer-aix.cc | 2 +- .../platform-embedded-file-writer-generic.cc | 2 +- .../platform-embedded-file-writer-mac.cc | 2 +- deps/v8/src/snapshot/mksnapshot.cc | 10 +- .../v8/src/snapshot/read-only-deserializer.cc | 54 +- deps/v8/src/snapshot/read-only-deserializer.h | 2 + deps/v8/src/snapshot/read-only-serializer.cc | 99 +- deps/v8/src/snapshot/roots-serializer.h | 2 + .../v8/src/snapshot/serializer-deserializer.h | 3 +- deps/v8/src/snapshot/serializer-inl.h | 14 +- deps/v8/src/snapshot/serializer.cc | 160 +- deps/v8/src/snapshot/serializer.h | 33 +- .../src/snapshot/shared-heap-deserializer.cc | 2 +- .../v8/src/snapshot/shared-heap-serializer.cc | 2 +- deps/v8/src/snapshot/snapshot.cc | 4 +- deps/v8/src/snapshot/startup-deserializer.cc | 1 + deps/v8/src/snapshot/startup-serializer.cc | 5 +- deps/v8/src/snapshot/static-roots-gen.cc | 327 + deps/v8/src/snapshot/static-roots-gen.h | 22 + deps/v8/src/strings/string-builder-inl.h | 30 +- deps/v8/src/strings/string-builder.cc | 23 +- deps/v8/src/strings/unicode.cc | 31 + deps/v8/src/strings/unicode.h | 16 +- deps/v8/src/torque/ast.h | 21 +- deps/v8/src/torque/cc-generator.cc | 7 +- deps/v8/src/torque/cfg.cc | 2 +- deps/v8/src/torque/constants.h | 3 + deps/v8/src/torque/csa-generator.cc | 7 +- deps/v8/src/torque/declarable.h | 12 +- deps/v8/src/torque/declaration-visitor.cc | 30 +- deps/v8/src/torque/declarations.cc | 11 +- deps/v8/src/torque/declarations.h | 3 +- deps/v8/src/torque/implementation-visitor.cc | 103 +- deps/v8/src/torque/instructions.cc | 6 +- deps/v8/src/torque/instructions.h | 10 +- deps/v8/src/torque/torque-parser.cc | 24 +- deps/v8/src/torque/types.h | 2 + deps/v8/src/tracing/DEPS | 3 +- deps/v8/src/tracing/trace-categories.cc | 3 +- deps/v8/src/tracing/trace-categories.h | 16 +- deps/v8/src/tracing/trace-event.h | 7 +- .../src/tracing/tracing-category-observer.cc | 20 + .../src/tracing/tracing-category-observer.h | 14 +- deps/v8/src/trap-handler/OWNERS | 8 +- .../src/trap-handler/handler-inside-posix.cc | 9 +- .../v8/src/trap-handler/handler-inside-win.cc | 5 +- .../trap-handler/handler-outside-simulator.cc | 22 +- .../src/trap-handler/trap-handler-simulator.h | 20 +- deps/v8/src/utils/allocation.cc | 8 +- deps/v8/src/utils/allocation.h | 12 +- deps/v8/src/utils/ostreams.h | 23 +- deps/v8/src/wasm/DEPS | 4 + .../wasm/baseline/arm/liftoff-assembler-arm.h | 189 +- .../baseline/arm64/liftoff-assembler-arm64.h | 460 +- .../baseline/ia32/liftoff-assembler-ia32.h | 176 +- .../v8/src/wasm/baseline/liftoff-assembler.cc | 456 +- deps/v8/src/wasm/baseline/liftoff-assembler.h | 228 +- deps/v8/src/wasm/baseline/liftoff-compiler.cc | 1597 ++-- deps/v8/src/wasm/baseline/liftoff-compiler.h | 2 +- deps/v8/src/wasm/baseline/liftoff-register.h | 57 +- .../loong64/liftoff-assembler-loong64.h | 492 +- .../mips64/liftoff-assembler-mips64.h | 551 +- .../wasm/baseline/ppc/liftoff-assembler-ppc.h | 701 +- .../baseline/riscv/liftoff-assembler-riscv.h | 98 +- .../riscv/liftoff-assembler-riscv32.h | 273 +- .../riscv/liftoff-assembler-riscv64.h | 212 +- .../baseline/s390/liftoff-assembler-s390.h | 363 +- .../wasm/baseline/x64/liftoff-assembler-x64.h | 190 +- deps/v8/src/wasm/c-api.cc | 47 +- deps/v8/src/wasm/canonical-types.cc | 51 +- deps/v8/src/wasm/canonical-types.h | 17 +- deps/v8/src/wasm/code-space-access.cc | 53 +- deps/v8/src/wasm/code-space-access.h | 21 +- deps/v8/src/wasm/compilation-environment.h | 29 +- .../src/wasm/constant-expression-interface.cc | 53 +- deps/v8/src/wasm/constant-expression.cc | 7 +- deps/v8/src/wasm/decoder.h | 242 +- deps/v8/src/wasm/function-body-decoder-impl.h | 1169 ++- deps/v8/src/wasm/function-body-decoder.cc | 24 +- deps/v8/src/wasm/function-body-decoder.h | 13 +- deps/v8/src/wasm/function-compiler.cc | 51 +- deps/v8/src/wasm/function-compiler.h | 24 +- deps/v8/src/wasm/graph-builder-interface.cc | 554 +- deps/v8/src/wasm/graph-builder-interface.h | 17 + deps/v8/src/wasm/jump-table-assembler.cc | 126 +- deps/v8/src/wasm/jump-table-assembler.h | 10 + deps/v8/src/wasm/module-compiler.cc | 1204 ++- deps/v8/src/wasm/module-compiler.h | 42 +- deps/v8/src/wasm/module-decoder-impl.h | 868 +-- deps/v8/src/wasm/module-decoder.cc | 298 +- deps/v8/src/wasm/module-decoder.h | 67 +- deps/v8/src/wasm/module-instantiate.cc | 283 +- deps/v8/src/wasm/module-instantiate.h | 15 +- deps/v8/src/wasm/stacks.cc | 16 +- deps/v8/src/wasm/stacks.h | 2 +- deps/v8/src/wasm/streaming-decoder.cc | 157 +- deps/v8/src/wasm/streaming-decoder.h | 19 +- deps/v8/src/wasm/struct-types.h | 99 +- deps/v8/src/wasm/sync-streaming-decoder.cc | 2 +- deps/v8/src/wasm/value-type.cc | 20 +- deps/v8/src/wasm/value-type.h | 37 +- deps/v8/src/wasm/wasm-code-manager.cc | 641 +- deps/v8/src/wasm/wasm-code-manager.h | 172 +- deps/v8/src/wasm/wasm-constants.h | 1 + deps/v8/src/wasm/wasm-debug.cc | 17 +- deps/v8/src/wasm/wasm-disassembler.cc | 129 +- deps/v8/src/wasm/wasm-engine.cc | 178 +- deps/v8/src/wasm/wasm-engine.h | 47 +- deps/v8/src/wasm/wasm-feature-flags.h | 44 +- deps/v8/src/wasm/wasm-features.cc | 12 + deps/v8/src/wasm/wasm-js.cc | 173 +- deps/v8/src/wasm/wasm-js.h | 14 +- deps/v8/src/wasm/wasm-limits.h | 10 +- deps/v8/src/wasm/wasm-module-builder.cc | 30 +- deps/v8/src/wasm/wasm-module-builder.h | 10 +- deps/v8/src/wasm/wasm-module.cc | 25 +- deps/v8/src/wasm/wasm-module.h | 200 +- deps/v8/src/wasm/wasm-objects-inl.h | 12 +- deps/v8/src/wasm/wasm-objects.cc | 658 +- deps/v8/src/wasm/wasm-objects.h | 57 +- deps/v8/src/wasm/wasm-objects.tq | 18 +- deps/v8/src/wasm/wasm-opcodes.cc | 16 +- deps/v8/src/wasm/wasm-opcodes.h | 21 +- deps/v8/src/wasm/wasm-result.h | 11 + deps/v8/src/wasm/wasm-serialization.cc | 71 +- deps/v8/src/wasm/wasm-subtyping.cc | 235 +- deps/v8/src/wasm/wasm-subtyping.h | 28 +- deps/v8/src/wasm/wasm-tier.h | 4 +- deps/v8/src/web-snapshot/web-snapshot.cc | 4289 ----------- deps/v8/src/web-snapshot/web-snapshot.h | 669 -- deps/v8/src/zone/type-stats.cc | 5 +- deps/v8/src/zone/zone-containers.h | 562 +- deps/v8/src/zone/zone.cc | 25 +- deps/v8/src/zone/zone.h | 25 +- deps/v8/test/BUILD.gn | 14 + deps/v8/test/OWNERS | 1 + deps/v8/test/benchmarks/benchmarks.status | 3 + deps/v8/test/benchmarks/cpp/BUILD.gn | 13 + deps/v8/test/benchmarks/cpp/dtoa.cc | 1069 +++ deps/v8/test/cctest/BUILD.gn | 123 +- deps/v8/test/cctest/cctest.cc | 30 +- deps/v8/test/cctest/cctest.h | 32 +- deps/v8/test/cctest/cctest.status | 28 +- deps/v8/test/cctest/compiler/codegen-tester.h | 14 +- .../test/cctest/compiler/function-tester.cc | 18 +- .../v8/test/cctest/compiler/function-tester.h | 2 + .../test/cctest/compiler/serializer-tester.h | 2 +- .../compiler/test-basic-block-profiler.cc | 26 +- .../cctest/compiler/test-code-assembler.cc | 19 +- .../cctest/compiler/test-code-generator.cc | 594 +- .../test-concurrent-shared-function-info.cc | 8 +- .../test/cctest/compiler/test-gap-resolver.cc | 128 +- .../cctest/compiler/test-js-constant-cache.cc | 29 +- .../test-js-context-specialization.cc | 30 +- .../cctest/compiler/test-js-typed-lowering.cc | 2 + .../compiler/test-machine-operator-reducer.cc | 40 +- .../cctest/compiler/test-multiple-return.cc | 24 +- deps/v8/test/cctest/compiler/test-operator.cc | 2 +- .../compiler/test-representation-change.cc | 2 + .../test/cctest/compiler/test-run-machops.cc | 94 +- .../cctest/compiler/test-run-native-calls.cc | 36 +- deps/v8/test/cctest/heap/heap-tester.h | 1 - deps/v8/test/cctest/heap/heap-utils.cc | 2 - deps/v8/test/cctest/heap/heap-utils.h | 28 +- .../cctest/heap/test-array-buffer-tracker.cc | 8 + .../cctest/heap/test-concurrent-allocation.cc | 44 +- .../cctest/heap/test-concurrent-marking.cc | 15 +- .../heap/test-external-string-tracker.cc | 12 +- deps/v8/test/cctest/heap/test-heap.cc | 467 +- .../cctest/heap/test-invalidated-slots.cc | 32 - deps/v8/test/cctest/heap/test-mark-compact.cc | 33 - deps/v8/test/cctest/heap/test-spaces.cc | 40 +- deps/v8/test/cctest/heap/test-unmapper.cc | 1 + .../test/cctest/heap/test-weak-references.cc | 13 +- .../v8/test/cctest/heap/test-write-barrier.cc | 4 +- .../v8/test/cctest/setup-isolate-for-tests.cc | 20 +- deps/v8/test/cctest/setup-isolate-for-tests.h | 9 +- .../v8/test/cctest/test-accessor-assembler.cc | 22 +- deps/v8/test/cctest/test-accessors.cc | 2 +- deps/v8/test/cctest/test-api-array-buffer.cc | 65 + deps/v8/test/cctest/test-api-typed-array.cc | 5 +- deps/v8/test/cctest/test-api.cc | 660 +- deps/v8/test/cctest/test-api.h | 8 + deps/v8/test/cctest/test-assembler-arm64.cc | 897 ++- deps/v8/test/cctest/test-assembler-mips64.cc | 16 +- deps/v8/test/cctest/test-assembler-riscv32.cc | 6 +- deps/v8/test/cctest/test-assembler-riscv64.cc | 42 +- .../test/cctest/test-code-stub-assembler.cc | 324 +- deps/v8/test/cctest/test-cpu-profiler.cc | 143 +- deps/v8/test/cctest/test-debug-helper.cc | 9 +- deps/v8/test/cctest/test-debug.cc | 94 +- deps/v8/test/cctest/test-descriptor-array.cc | 6 +- .../test/cctest/test-disasm-regex-helper.cc | 6 +- .../test/cctest/test-field-type-tracking.cc | 14 +- deps/v8/test/cctest/test-heap-profiler.cc | 36 +- deps/v8/test/cctest/test-js-to-wasm.cc | 54 +- deps/v8/test/cctest/test-js-weak-refs.cc | 11 + deps/v8/test/cctest/test-lockers.cc | 2 + .../cctest/test-macro-assembler-loong64.cc | 4 +- deps/v8/test/cctest/test-profile-generator.cc | 163 +- deps/v8/test/cctest/test-ptr-compr-cage.cc | 28 +- deps/v8/test/cctest/test-regexp.cc | 249 + deps/v8/test/cctest/test-serialize.cc | 161 +- deps/v8/test/cctest/test-shared-strings.cc | 734 +- deps/v8/test/cctest/test-strings.cc | 44 +- .../cctest/test-swiss-name-dictionary-csa.cc | 33 +- .../test/cctest/test-sync-primitives-arm64.cc | 4 +- .../test/cctest/test-unwinder-code-pages.cc | 29 +- deps/v8/test/cctest/torque/test-torque.cc | 183 +- deps/v8/test/cctest/wasm/test-c-wasm-entry.cc | 2 +- deps/v8/test/cctest/wasm/test-gc.cc | 185 +- deps/v8/test/cctest/wasm/test-grow-memory.cc | 3 +- .../cctest/wasm/test-jump-table-assembler.cc | 5 +- .../cctest/wasm/test-liftoff-for-fuzzing.cc | 34 +- .../cctest/wasm/test-liftoff-inspection.cc | 6 +- deps/v8/test/cctest/wasm/test-run-wasm-64.cc | 333 +- .../test/cctest/wasm/test-run-wasm-asmjs.cc | 76 +- .../test/cctest/wasm/test-run-wasm-atomics.cc | 174 +- .../cctest/wasm/test-run-wasm-atomics64.cc | 288 +- .../cctest/wasm/test-run-wasm-bulk-memory.cc | 298 +- .../cctest/wasm/test-run-wasm-exceptions.cc | 353 +- .../cctest/wasm/test-run-wasm-interpreter.cc | 192 +- deps/v8/test/cctest/wasm/test-run-wasm-js.cc | 37 +- .../cctest/wasm/test-run-wasm-memory64.cc | 12 +- .../test/cctest/wasm/test-run-wasm-module.cc | 30 +- .../cctest/wasm/test-run-wasm-relaxed-simd.cc | 200 +- .../wasm/test-run-wasm-sign-extension.cc | 10 +- .../cctest/wasm/test-run-wasm-simd-liftoff.cc | 96 +- .../v8/test/cctest/wasm/test-run-wasm-simd.cc | 1519 ++-- .../cctest/wasm/test-run-wasm-wrappers.cc | 8 +- deps/v8/test/cctest/wasm/test-run-wasm.cc | 1436 ++-- .../cctest/wasm/test-streaming-compilation.cc | 22 +- .../test/cctest/wasm/test-wasm-breakpoints.cc | 67 +- .../wasm/test-wasm-import-wrapper-cache.cc | 2 +- deps/v8/test/cctest/wasm/test-wasm-metrics.cc | 9 - .../cctest/wasm/test-wasm-serialization.cc | 90 +- .../cctest/wasm/test-wasm-shared-engine.cc | 7 +- deps/v8/test/cctest/wasm/test-wasm-stack.cc | 15 +- .../cctest/wasm/test-wasm-trap-position.cc | 16 +- deps/v8/test/cctest/wasm/wasm-run-utils.cc | 105 +- deps/v8/test/cctest/wasm/wasm-run-utils.h | 56 +- deps/v8/test/cctest/wasm/wasm-simd-utils.cc | 206 +- deps/v8/test/common/call-tester.h | 11 +- deps/v8/test/common/code-assembler-tester.h | 7 +- deps/v8/test/common/types-fuzz.h | 7 +- deps/v8/test/common/wasm/wasm-interpreter.cc | 77 +- deps/v8/test/common/wasm/wasm-interpreter.h | 2 +- deps/v8/test/common/wasm/wasm-macro-gen.h | 16 + .../v8/test/common/wasm/wasm-module-runner.cc | 28 +- deps/v8/test/common/wasm/wasm-module-runner.h | 17 +- .../wasm/debug-enabled-tier-down-wasm.js | 38 +- deps/v8/test/debugger/testcfg.py | 2 +- deps/v8/test/debugging/testcfg.py | 6 +- deps/v8/test/fuzzer/multi-return.cc | 9 +- deps/v8/test/fuzzer/regexp-builtins.cc | 3 + deps/v8/test/fuzzer/wasm-async.cc | 38 +- deps/v8/test/fuzzer/wasm-code.cc | 14 +- deps/v8/test/fuzzer/wasm-compile.cc | 226 +- deps/v8/test/fuzzer/wasm-fuzzer-common.cc | 210 +- deps/v8/test/fuzzer/wasm-fuzzer-common.h | 49 +- deps/v8/test/fuzzer/wasm-streaming.cc | 26 +- deps/v8/test/fuzzer/wasm.cc | 39 +- deps/v8/test/fuzzer/wasm/regress-1404619.wasm | Bin 0 -> 38 bytes .../fuzzer/wasm_async/regress-1405322.wasm | Bin 0 -> 58 bytes .../break-on-exception-async-gen-expected.txt | 45 + .../debugger/break-on-exception-async-gen.js | 118 + ...private-class-member-conflict-expected.txt | 55 + ...all-frame-private-class-member-conflict.js | 12 + ...ll-frame-private-class-member-expected.txt | 231 + ...rivate-class-member-in-module-expected.txt | 16 + ...ll-frame-private-class-member-in-module.js | 32 + ...e-private-class-member-static-expected.txt | 231 + ...-call-frame-private-class-member-static.js | 12 + ...me-private-class-member-super-expected.txt | 0 ...uate-on-call-frame-private-class-member.js | 12 + ...rumentation-multiple-sessions-expected.txt | 64 + .../instrumentation-multiple-sessions.js | 292 + ...t-preview-internal-properties-expected.txt | 5 + .../pause-on-instrumentation-expected.txt | 6 + .../debugger/pause-on-instrumentation.js | 25 +- .../debugger/restore-breakpoint-expected.txt | 73 + .../inspector/debugger/restore-breakpoint.js | 47 +- .../debugger/session-stop-expected.txt | 20 + .../test/inspector/debugger/session-stop.js | 86 + .../set-script-source-es-module-expected.txt | 9 + .../debugger/set-script-source-es-module.js | 37 + .../set-script-source-top-frame-expected.txt | 2 +- .../debugger/suspended-generator-scopes.js | 2 - .../debugger/wasm-gc-anyref-expected.txt | 19 +- .../test/inspector/debugger/wasm-gc-anyref.js | 40 +- .../debugger/wasm-scope-info-expected.txt | 114 +- .../inspector/debugger/wasm-step-a-lot.js | 2 +- deps/v8/test/inspector/inspector-test.cc | 28 + deps/v8/test/inspector/isolate-data.cc | 29 +- deps/v8/test/inspector/isolate-data.h | 13 +- .../private-class-member-inspector-test.js | 167 + deps/v8/test/inspector/protocol-test.js | 13 +- .../regress/regress-crbug-1220203.js | 7 +- .../regress/regress-crbug-1246896.js | 2 - .../regress-crbug-1270780-expected.txt | 22 + .../regress/regress-crbug-1270780.js | 107 + .../regress-crbug-1401674-expected.txt | 5 + .../regress/regress-crbug-1401674.js | 38 + .../call-function-on-async-expected.txt | 43 +- .../runtime/call-function-on-async.js | 45 +- .../runtime/console-spec-expected.txt | 2 +- ...estroyed-on-context-collected-expected.txt | 1 + ...private-class-member-conflict-expected.txt | 55 + .../evaluate-private-class-member-conflict.js | 12 + ...evaluate-private-class-member-expected.txt | 231 + ...e-private-class-member-static-expected.txt | 231 + .../evaluate-private-class-member-static.js | 12 + .../runtime/evaluate-private-class-member.js | 12 + ...-thrown-breakpoint-conditions-expected.txt | 24 + .../exception-thrown-breakpoint-conditions.js | 71 + .../test/inspector/runtime/function-scopes.js | 2 - .../runtime/get-properties-expected.txt | 6 + .../get-properties-on-proxy-expected.txt | 8 +- ...al-properties-prototype-chain-expected.txt | 61 + .../internal-properties-prototype-chain.js | 39 + .../inspector/runtime/internal-properties.js | 2 - .../runtime/remote-object-expected.txt | 108 +- .../test/inspector/runtime/remote-object.js | 19 + .../run-if-waiting-for-debugger-expected.txt | 12 + .../runtime/run-if-waiting-for-debugger.js | 35 + .../runtime/terminate-execution-expected.txt | 2 +- .../inspector/runtime/terminate-execution.js | 14 +- .../sessions/create-session-expected.txt | 3 + deps/v8/test/inspector/tasks.cc | 84 + deps/v8/test/inspector/tasks.h | 28 +- deps/v8/test/inspector/testcfg.py | 10 +- deps/v8/test/inspector/wasm-inspector-test.js | 6 +- deps/v8/test/intl/assert.js | 14 + .../date-format/en-format-range-to-parts.js | 6 +- deps/v8/test/intl/date-format/format-range.js | 24 +- deps/v8/test/intl/intl.status | 4 +- deps/v8/test/intl/locale/locale-collations.js | 1 + .../intl/number-format/unified/style-unit.js | 4 +- deps/v8/test/intl/regress-9912.js | 6 +- .../intl/relative-time-format/format-en.js | 218 +- deps/v8/test/intl/testcfg.py | 2 +- .../v8/test/js-perf-test/BigInt/add-no-opt.js | 75 - deps/v8/test/js-perf-test/BigInt/add.js | 24 - .../test/js-perf-test/BigInt/bigint-util.js | 5 +- .../test/js-perf-test/BigInt/exponentiate.js | 48 - deps/v8/test/js-perf-test/BigInt/shift.js | 47 - deps/v8/test/js-perf-test/BigInt/subtract.js | 24 - deps/v8/test/js-perf-test/JSTests1.json | 49 - deps/v8/test/js-perf-test/JSTests2.json | 5 +- ...ct-prior-octal-escape-use-strict-before.js | 9 + ...t-prior-octal-escape-use-strict-before.out | 9 + .../message/fail/strict-prior-octal-escape.js | 9 + .../fail/strict-prior-octal-escape.out | 9 + .../fail/strict-prior-octal-literal.js | 9 + .../fail/strict-prior-octal-literal.out | 9 + .../test/message/fail/var-prior-conflict.js | 9 + .../test/message/fail/var-prior-conflict.out | 9 + deps/v8/test/message/message.status | 7 + deps/v8/test/message/testcfg.py | 2 +- deps/v8/test/mjsunit/array-reverse.js | 2 + deps/v8/test/mjsunit/array-tostring.js | 9 +- deps/v8/test/mjsunit/asm/regress-1395401.js | 16 + deps/v8/test/mjsunit/code-stats-flag.js | 7 + .../mjsunit/compiler/bigint-bitwise-and.js | 1 + .../mjsunit/compiler/bigint-bitwise-or.js | 31 + .../mjsunit/compiler/bigint-bitwise-xor.js | 31 + .../test/mjsunit/compiler/bigint-compare.js | 61 + .../mjsunit/compiler/bigint-constructor.js | 107 + deps/v8/test/mjsunit/compiler/bigint-equal.js | 44 + .../mjsunit/compiler/bigint-shift-left.js | 110 + .../mjsunit/compiler/bigint-shift-right.js | 140 + .../test/mjsunit/compiler/bigint64-array.js | 71 + .../compiler/fast-api-calls-pointer.js | 140 + .../compiler/fast-api-clamp-annotations.js | 1 + .../mjsunit/compiler/regress-crbug-1399490.js | 24 + .../mjsunit/compiler/regress-crbug-1399626.js | 19 + .../mjsunit/compiler/regress-crbug-1399627.js | 18 + .../mjsunit/compiler/regress-crbug-1408013.js | 13 + .../typedarray-resizablearraybuffer.js | 77 + deps/v8/test/mjsunit/const-dict-tracking.js | 734 -- deps/v8/test/mjsunit/const-field-tracking.js | 235 - .../mjsunit/dataview-resizablearraybuffer.js | 29 + .../array-concat-arraylike-string-length.js | 2 +- .../mjsunit/es6/array-concat-arraylike.js | 2 +- .../mjsunit/es6/array-concat-holey-array.js | 4 +- .../array-concat-sloppy-arguments-holey.js | 2 +- ...rray-concat-sloppy-arguments-with-dupes.js | 2 +- .../es6/array-concat-sloppy-arguments.js | 2 +- .../es6/array-concat-spreadable-function.js | 2 +- ...ay-concat-spreadable-nonarraylike-proxy.js | 4 +- .../es6/array-concat-spreadable-regexp.js | 2 +- .../array-concat-spreadable-sparse-object.js | 2 +- .../es6/array-concat-strict-arguments.js | 2 +- deps/v8/test/mjsunit/es6/array-from.js | 21 + deps/v8/test/mjsunit/es6/array-of.js | 16 + .../v8/test/mjsunit/es6/array-spread-holey.js | 2 +- .../test/mjsunit/es6/block-sloppy-function.js | 3 +- .../test/mjsunit/es6/typedarray-tostring.js | 6 +- .../harmony/array-prototype-groupby.js | 2 +- .../harmony/array-prototype-groupbytomap.js | 2 +- .../test/mjsunit/harmony/array-to-reversed.js | 30 + .../test/mjsunit/harmony/array-to-sorted.js | 19 +- .../mjsunit/harmony/arraybuffer-transfer.js | 257 +- .../test/mjsunit/harmony/iterator-helpers.js | 40 + .../json-parse-with-source-snapshot.js | 92 + .../mjsunit/harmony/json-parse-with-source.js | 6 +- .../harmony/public-instance-class-fields.js | 10 + .../harmony/public-static-class-fields.js | 40 + .../mjsunit/harmony/regexp-unicode-sets.js | 123 +- .../harmony/regress/regress-crbug-1410963.js | 8 + .../harmony/shadowrealm-callsite-throw.js | 114 + .../mjsunit/harmony/shadowrealm-evaluate.js | 21 +- .../harmony/shadowrealm-importvalue.js | 12 +- .../shadowrealm-skip-3-throw-object.mjs | 2 + .../harmony/shadowrealm-wrapped-function.js | 23 + .../string-iswellformed-external-uncached.js | 42 + .../string-iswellformed-flat-indirect.js | 35 + .../weakrefs/cleanup-from-different-realm.js | 45 +- .../weakrefs/cleanup-is-not-a-microtask.js | 85 +- .../weakrefs/cleanup-on-detached-realm.js | 81 +- .../cleanup-proxy-from-different-realm.js | 48 +- .../test/mjsunit/harmony/weakrefs/cleanup.js | 90 +- .../mjsunit/harmony/weakrefs/cleanupsome-2.js | 50 +- .../weakrefs/cleanupsome-after-unregister.js | 58 +- .../mjsunit/harmony/weakrefs/cleanupsome.js | 60 +- .../finalizationregistry-and-weakref.js | 71 +- ...nregistry-independent-lifetime-multiple.js | 66 +- ...nalizationregistry-independent-lifetime.js | 48 +- ...nalizationregistry-keeps-holdings-alive.js | 80 +- ...ry-scheduled-for-cleanup-multiple-times.js | 111 +- .../multiple-dirty-finalization-groups.js | 57 +- .../weakrefs/reentrant-gc-from-cleanup.js | 33 +- ...ress-finalizationregistry-dirty-enqueue.js | 64 +- .../weakrefs/symbol-as-weakref-target-gc.js | 43 +- .../symbol-in-finalizationregistry.js | 30 + .../mjsunit/harmony/weakrefs/two-weakrefs.js | 27 +- .../harmony/weakrefs/undefined-holdings.js | 53 +- .../weakrefs/unregister-after-cleanup.js | 72 +- .../weakrefs/unregister-before-cleanup.js | 62 +- .../weakrefs/unregister-called-twice.js | 72 +- .../weakrefs/unregister-inside-cleanup.js | 67 +- .../weakrefs/unregister-inside-cleanup2.js | 81 +- .../weakrefs/unregister-inside-cleanup3.js | 84 +- .../harmony/weakrefs/unregister-many.js | 85 +- ...register-when-cleanup-already-scheduled.js | 62 +- .../harmony/weakrefs/weak-cell-basics.js | 62 +- .../harmony/weakrefs/weak-unregistertoken.js | 27 +- .../weakrefs/weakref-creation-keeps-alive.js | 21 +- .../weakrefs/weakref-deref-keeps-alive.js | 33 +- deps/v8/test/mjsunit/ic-megadom-2.js | 2 +- deps/v8/test/mjsunit/ic-megadom-3.js | 2 +- deps/v8/test/mjsunit/ic-megadom.js | 2 +- .../test/mjsunit/interrupt-budget-override.js | 2 +- .../test/mjsunit/keyed-store-array-literal.js | 2 +- deps/v8/test/mjsunit/maglev/add-smi.js | 5 +- .../maglev/continuation-after-inlined.js | 29 + deps/v8/test/mjsunit/maglev/exceptions.js | 39 +- .../maglev/inline-fresh-parent-deopt-frame.js | 22 + .../v8/test/mjsunit/maglev/inline-phi-leak.js | 24 + deps/v8/test/mjsunit/maglev/lots-of-args.js | 46 + deps/v8/test/mjsunit/maglev/math-round.js | 23 + deps/v8/test/mjsunit/maglev/negate.js | 67 + .../mjsunit/maglev/nested-continuations.js | 35 + .../test/mjsunit/maglev/omit-default-ctors.js | 2 +- .../mjsunit/maglev/polymorphic-load-number.js | 18 + .../v8/test/mjsunit/maglev/regress-1403324.js | 29 + .../v8/test/mjsunit/maglev/regress-1405092.js | 29 + .../v8/test/mjsunit/maglev/regress-1406456.js | 17 + .../v8/test/mjsunit/maglev/regress-1407606.js | 18 + .../v8/test/mjsunit/maglev/regress-1411075.js | 17 + .../mjsunit/maglev/regress/regress-1383712.js | 26 + .../mjsunit/maglev/regress/regress-1392936.js | 16 + .../mjsunit/maglev/regress/regress-1394279.js | 21 + .../mjsunit/maglev/regress/regress-1403575.js | 14 + .../mjsunit/maglev/regress/regress-1405651.js | 51 + .../mjsunit/maglev/regress/regress-1407959.js | 27 + .../maglev/regress/regress-crbug-1392061.js | 37 + .../maglev/regress/regress-crbug-1394036.js | 19 + .../maglev/regress/regress-crbug-1403280.js | 14 + .../maglev/regress/regress-crbug-1403323.js | 15 + .../maglev/regress/regress-crbug-1403399.js | 36 + .../maglev/regress/regress-crbug-1403470.js | 14 + .../maglev/regress/regress-crbug-1403749.js | 25 + .../maglev/regress/regress-crbug-1405445.js | 16 + .../maglev/regress/regress-crbug-1416693.js | 22 + .../maglev/regress/regress-crbug-1416795.js | 18 + .../maglev/regress/regress-crbug-1417386.js | 27 + .../mjsunit/maglev/resumable-loop-context.js | 19 + deps/v8/test/mjsunit/maglev/resumable.js | 17 + .../mjsunit/maglev/shift-right-logical-smi.js | 6 +- .../mjsunit/maglev/shift-right-logical.js | 6 +- .../maglev/typedarray-resizablearraybuffer.js | 815 ++ .../mjsunit/maglev/unused-checkedsmitag.js | 22 + deps/v8/test/mjsunit/mjsunit-assert-equals.js | 6 +- deps/v8/test/mjsunit/mjsunit.js | 2 + deps/v8/test/mjsunit/mjsunit.status | 118 +- deps/v8/test/mjsunit/never-optimize.js | 2 +- .../test/mjsunit/optimized-string-includes.js | 18 +- .../mjsunit/rab-gsab-transfer-to-worker.js | 232 + deps/v8/test/mjsunit/regress-1400809.js | 11 + deps/v8/test/mjsunit/regress-crbug-1359991.js | 2 +- deps/v8/test/mjsunit/regress-v8-13459.js | 111 + .../mjsunit/regress/asm/regress-1402270.js | 16 + .../test/mjsunit/regress/regress-1320641.js | 16 + deps/v8/test/mjsunit/regress/regress-13652.js | 28 + .../test/mjsunit/regress/regress-1383362.js | 17 + .../test/mjsunit/regress/regress-1385368.js | 10 + .../test/mjsunit/regress/regress-1393865.js | 28 + .../test/mjsunit/regress/regress-1393942.js | 26 + .../test/mjsunit/regress/regress-1394663.js | 10 + .../test/mjsunit/regress/regress-1400053.js | 24 + .../test/mjsunit/regress/regress-1400056.js | 24 + .../test/mjsunit/regress/regress-1400897.js | 29 + .../test/mjsunit/regress/regress-1404607.js | 18 + .../test/mjsunit/regress/regress-1404863.js | 18 + .../test/mjsunit/regress/regress-1407070.js | 11 + .../test/mjsunit/regress/regress-1407349.js | 17 + .../test/mjsunit/regress/regress-1408086.js | 16 + .../test/mjsunit/regress/regress-1408400.js | 16 + .../test/mjsunit/regress/regress-1408606.js | 18 + .../test/mjsunit/regress/regress-1409058.js | 9 + .../test/mjsunit/regress/regress-1412629.js | 18 + .../test/mjsunit/regress/regress-1412975.js | 16 + .../test/mjsunit/regress/regress-1414200.js | 19 + .../test/mjsunit/regress/regress-1416520.js | 14 + .../test/mjsunit/regress/regress-1416697.js | 44 + .../test/mjsunit/regress/regress-1416830.js | 20 + .../v8/test/mjsunit/regress/regress-165637.js | 2 +- .../v8/test/mjsunit/regress/regress-633998.js | 4 +- .../v8/test/mjsunit/regress/regress-804177.js | 2 +- .../regress/regress-chromium-1409294.js | 23 + .../mjsunit/regress/regress-crbug-1381404.js | 9 + .../mjsunit/regress/regress-crbug-1383883.js | 27 + .../mjsunit/regress/regress-crbug-1383976.js | 24 + .../regress/regress-crbug-1384474-variant2.js | 13 + .../regress/regress-crbug-1384474-variant3.js | 14 + .../mjsunit/regress/regress-crbug-1384474.js | 12 + .../mjsunit/regress/regress-crbug-1392577.js | 14 + .../mjsunit/regress/regress-crbug-1393375.js | 14 + .../mjsunit/regress/regress-crbug-1394741.js | 23 + .../mjsunit/regress/regress-crbug-1395117.js | 14 + .../mjsunit/regress/regress-crbug-1399695.js | 13 + .../mjsunit/regress/regress-crbug-1399799.js | 45 + .../mjsunit/regress/regress-crbug-1402139.js | 13 + .../mjsunit/regress/regress-crbug-1404820.js | 21 + .../mjsunit/regress/regress-crbug-1406774.js | 23 + .../mjsunit/regress/regress-crbug-1407080.js | 7 + .../mjsunit/regress/regress-crbug-1407384.js | 22 + .../mjsunit/regress/regress-crbug-1408310.js | 23 + .../mjsunit/regress/regress-crbug-1412938.js | 12 + .../mjsunit/regress/regress-crbug-1415249.js | 30 + .../mjsunit/regress/regress-crbug-1415581.js | 10 + .../mjsunit/regress/regress-crbug-1416248.js | 11 + .../mjsunit/regress/regress-crbug-1416395.js | 9 + .../mjsunit/regress/regress-crbug-1417882.js | 18 + .../test/mjsunit/regress/regress-v8-13410.js | 15 + .../wasm/export-wrapper-canonical-types.js | 69 + .../mjsunit/regress/wasm/regress-1179065.js | 9 +- .../mjsunit/regress/wasm/regress-12874.js | 6 +- .../mjsunit/regress/wasm/regress-12945.js | 2 + .../mjsunit/regress/wasm/regress-13230.js | 2 +- .../mjsunit/regress/wasm/regress-13290.js | 2 +- .../mjsunit/regress/wasm/regress-13700.js | 31 + .../mjsunit/regress/wasm/regress-13715.js | 32 + .../mjsunit/regress/wasm/regress-13732.js | 13 + .../mjsunit/regress/wasm/regress-1388938.js | 16 + .../mjsunit/regress/wasm/regress-1388942.js | 17 + .../mjsunit/regress/wasm/regress-1395604.js | 34 + .../mjsunit/regress/wasm/regress-1403398.js | 119 + .../mjsunit/regress/wasm/regress-1408337.js | 24 + .../mjsunit/regress/wasm/regress-1412940.js | 40 + .../mjsunit/regress/wasm/regress-1416758.js | 25 + .../mjsunit/regress/wasm/regress-1417516.js | 37 + .../mjsunit/regress/wasm/regress-1417908.js | 32 + .../mjsunit/regress/wasm/regress-1418706.js | 17 + .../regress/wasm/regress-crbug-1407594.js | 64 + .../regress-struct-set-into-unreachable.js | 46 + .../cannot-redefine-properties.js | 40 + .../test/mjsunit/shared-memory/condition.js | 7 + .../mjsunit/shared-memory/mutex-lock-twice.js | 19 + deps/v8/test/mjsunit/shared-memory/mutex.js | 7 + .../shared-memory/non-instance-prototype.js | 42 + .../mjsunit/shared-memory/private-field.js | 25 + .../mjsunit/shared-memory/private-name.js | 13 + .../shared-memory/shared-array-surface.js | 14 +- .../shared-string-copy-on-share-large.js | 53 + .../shared-string-copy-on-share.js | 62 + .../shared-memory/shared-struct-surface.js | 59 + .../shared-value-barrier-optimization.js | 29 + .../shared-memory/shrink-large-object.js | 17 + deps/v8/test/mjsunit/testcfg.py | 9 +- .../test/mjsunit/tools/processor-bigint.mjs | 59 + deps/v8/test/mjsunit/tools/tickprocessor.mjs | 4 +- .../test/mjsunit/turboshaft/type-inference.js | 118 + .../mjsunit/turboshaft/typed-optimizations.js | 51 + ...rray-resizablearraybuffer-array-methods.js | 11 +- .../typedarray-resizablearraybuffer.js | 606 +- .../test/mjsunit/wasm/array-copy-benchmark.js | 2 +- .../mjsunit/wasm/array-init-from-segment.js | 87 +- deps/v8/test/mjsunit/wasm/bit-shift-right.js | 2 +- .../mjsunit/wasm/bounds-check-turbofan.js | 8 +- deps/v8/test/mjsunit/wasm/call-ref.js | 83 +- deps/v8/test/mjsunit/wasm/call_indirect.js | 4 - deps/v8/test/mjsunit/wasm/code-flushing.js | 40 + .../test/mjsunit/wasm/code-space-overflow.js | 44 + ...ustion.js => committed-code-exhaustion.js} | 2 +- ...own-to-liftoff.js => enter-debug-state.js} | 31 +- .../mjsunit/wasm/externref-globals-liftoff.js | 7 - .../v8/test/mjsunit/wasm/externref-liftoff.js | 8 - .../mjsunit/wasm/gc-cast-type-inference.js | 172 + .../v8/test/mjsunit/wasm/gc-casts-from-any.js | 417 +- .../v8/test/mjsunit/wasm/gc-casts-subtypes.js | 557 +- .../wasm/gc-js-interop-async-debugger.js | 11 + .../mjsunit/wasm/gc-js-interop-collections.js | 6 +- .../wasm/gc-js-interop-global-constructors.js | 35 +- .../mjsunit/wasm/gc-js-interop-helpers.js | 1 - .../mjsunit/wasm/gc-js-interop-import.mjs | 1 - .../mjsunit/wasm/gc-js-interop-objects.js | 37 +- .../test/mjsunit/wasm/gc-js-interop-wasm.js | 2 +- deps/v8/test/mjsunit/wasm/gc-js-interop.js | 20 +- deps/v8/test/mjsunit/wasm/gc-nominal.js | 59 - deps/v8/test/mjsunit/wasm/gc-null-traps.js | 100 + deps/v8/test/mjsunit/wasm/gc-optimizations.js | 54 +- deps/v8/test/mjsunit/wasm/i31ref.js | 85 + deps/v8/test/mjsunit/wasm/inlining.js | 62 + deps/v8/test/mjsunit/wasm/load-immutable.js | 2 +- .../wasm/log-code-after-post-message.js | 44 + .../test/mjsunit/wasm/max-wasm-functions.js | 16 + deps/v8/test/mjsunit/wasm/memory64.js | 68 +- deps/v8/test/mjsunit/wasm/multi-value.js | 1 - .../test/mjsunit/wasm/origin-trial-flags.js | 46 + .../mjsunit/wasm/reference-globals-import.js | 49 +- .../v8/test/mjsunit/wasm/reference-globals.js | 61 +- .../wasm/reference-table-js-interop.js | 28 +- deps/v8/test/mjsunit/wasm/reference-tables.js | 92 +- deps/v8/test/mjsunit/wasm/return-calls-eh.js | 113 + .../wasm/runtime-type-canonicalization.js | 1 - .../test/mjsunit/wasm/speculative-inlining.js | 12 +- .../mjsunit/wasm/streaming-error-position.js | 80 +- .../test/mjsunit/wasm/stringrefs-exec-gc.js | 52 +- deps/v8/test/mjsunit/wasm/stringrefs-exec.js | 155 +- .../mjsunit/wasm/stringrefs-regressions.js | 4 +- deps/v8/test/mjsunit/wasm/stringrefs-valid.js | 31 +- .../mjsunit/wasm/stringview-valuestack.js | 73 + .../test/mjsunit/wasm/table-access-liftoff.js | 7 - .../test/mjsunit/wasm/table-grow-from-wasm.js | 2 +- .../v8/test/mjsunit/wasm/table-numeric-ops.js | 144 + .../mjsunit/wasm/type-based-optimizations.js | 2 + .../wasm/wasm-gc-externalize-internalize.js | 7 +- deps/v8/test/mjsunit/wasm/wasm-gc-inlining.js | 86 + .../test/mjsunit/wasm/wasm-gc-js-roundtrip.js | 55 +- .../test/mjsunit/wasm/wasm-module-builder.js | 133 +- .../test/mjsunit/wasm/wrapper-compilation.js | 33 + .../web-snapshot/web-snapshot-array-buffer.js | 85 - .../web-snapshot/web-snapshot-array.js | 133 - .../mjsunit/web-snapshot/web-snapshot-base.js | 147 - .../web-snapshot/web-snapshot-bigint.js | 122 - .../web-snapshot/web-snapshot-builtin.js | 39 - .../web-snapshot-circular-reference.js | 20 - .../web-snapshot/web-snapshot-class.js | 177 - .../web-snapshot/web-snapshot-data-view.js | 127 - .../web-snapshot/web-snapshot-externals.js | 80 - .../web-snapshot-function-context.js | 444 -- .../web-snapshot/web-snapshot-function.js | 270 - .../web-snapshot/web-snapshot-helpers.js | 25 - .../web-snapshot/web-snapshot-holey-array.js | 49 - .../web-snapshot/web-snapshot-object.js | 204 - .../web-snapshot/web-snapshot-prototype.js | 105 - .../web-snapshot/web-snapshot-sparse-array.js | 99 - .../web-snapshot/web-snapshot-symbol.js | 47 - .../web-snapshot/web-snapshot-typed-array.js | 439 -- deps/v8/test/test262/test262.status | 556 +- deps/v8/test/test262/testcfg.py | 4 +- deps/v8/test/unittests/BUILD.gn | 263 +- .../test/unittests/api/api-wasm-unittest.cc | 50 + .../unittests/api/deserialize-unittest.cc | 105 +- .../test/unittests/api/exception-unittest.cc | 2 + .../test/unittests/api/v8-script-unittest.cc | 71 + .../assembler/disasm-arm64-unittest.cc | 147 + .../assembler/disasm-ia32-unittest.cc | 8 +- .../assembler/disasm-riscv-unittest.cc | 2 +- .../assembler/disasm-x64-unittest.cc | 12 +- ...est.cc => macro-assembler-arm-unittest.cc} | 34 +- .../macro-assembler-arm64-unittest.cc | 325 +- ...st.cc => macro-assembler-ia32-unittest.cc} | 16 +- ...cc => macro-assembler-loong64-unittest.cc} | 16 +- ....cc => macro-assembler-mips64-unittest.cc} | 16 +- ...est.cc => macro-assembler-ppc-unittest.cc} | 75 +- ...t.cc => macro-assembler-riscv-unittest.cc} | 16 +- ...st.cc => macro-assembler-s390-unittest.cc} | 16 +- .../assembler/macro-assembler-x64-unittest.cc | 58 +- .../turbo-assembler-arm64-unittest.cc | 254 - .../assembler/turbo-assembler-x64-unittest.cc | 65 - .../test/unittests/base/ieee754-unittest.cc | 245 +- .../v8/test/unittests/base/vector-unittest.cc | 27 +- .../unittests/codegen/code-layout-unittest.cc | 21 +- .../unittests/codegen/code-pages-unittest.cc | 60 +- .../unittests/codegen/factory-unittest.cc | 3 +- .../compiler/bytecode-analysis-unittest.cc | 23 +- .../test/unittests/compiler/codegen-tester.h | 14 +- .../constant-folding-reducer-unittest.cc | 8 +- .../compiler/csa-load-elimination-unittest.cc | 3 +- .../unittests/compiler/function-tester.cc | 22 +- .../test/unittests/compiler/function-tester.h | 4 +- .../compiler/graph-reducer-unittest.h | 1 + .../test/unittests/compiler/graph-unittest.cc | 1 + .../test/unittests/compiler/graph-unittest.h | 1 + .../compiler/int64-lowering-unittest.cc | 74 +- .../compiler/js-call-reducer-unittest.cc | 14 +- .../compiler/js-create-lowering-unittest.cc | 17 +- .../compiler/js-typed-lowering-unittest.cc | 2 +- .../machine-operator-reducer-unittest.cc | 372 +- .../unittests/compiler/node-test-utils.cc | 1 + .../test/unittests/compiler/node-test-utils.h | 2 + .../redundancy-elimination-unittest.cc | 26 +- .../test/unittests/compiler/revec-unittest.cc | 233 + .../unittests/compiler/run-deopt-unittest.cc | 3 +- .../compiler/run-tail-calls-unittest.cc | 9 +- .../turboshaft/snapshot-table-unittest.cc | 324 +- .../turboshaft/turboshaft-typer-unittest.cc | 263 + .../turboshaft/turboshaft-types-unittest.cc | 787 ++ .../test/unittests/compiler/typer-unittest.cc | 12 +- .../deoptimizer/deoptimization-unittest.cc | 17 - .../conservative-stack-visitor-unittest.cc | 14 +- .../embedder-roots-handler-unittest.cc | 283 + .../heap/cppgc-js/unified-heap-unittest.cc | 347 +- .../heap/cppgc-js/unified-heap-utils.cc | 25 + .../heap/cppgc-js/unified-heap-utils.h | 9 +- .../cppgc-js/young-unified-heap-unittest.cc | 401 + .../heap/cppgc/concurrent-sweeper-unittest.cc | 41 + .../unittests/heap/cppgc/logging-unittest.cc | 2 +- .../heap/cppgc/marking-verifier-unittest.cc | 4 +- .../unittests/heap/cppgc/member-unittest.cc | 4 +- .../unittests/heap/cppgc/test-platform.cc | 3 +- .../heap/embedder-tracing-unittest.cc | 1212 --- .../test/unittests/heap/gc-tracer-unittest.cc | 19 +- .../unittests/heap/global-handles-unittest.cc | 47 +- deps/v8/test/unittests/heap/heap-unittest.cc | 15 +- deps/v8/test/unittests/heap/heap-utils.cc | 11 + deps/v8/test/unittests/heap/heap-utils.h | 30 +- .../unittests/heap/local-heap-unittest.cc | 18 +- ...rking-inner-pointer-resolution-unittest.cc | 157 +- .../heap/marking-worklist-unittest.cc | 46 +- .../unittests/heap/memory-reducer-unittest.cc | 247 +- .../unittests/heap/shared-heap-unittest.cc | 23 +- .../unittests/inspector/inspector-unittest.cc | 48 +- .../bytecode-array-builder-unittest.cc | 3 +- .../ObjectLiterals.golden | 4 +- .../PrivateAccessorAccess.golden | 28 +- .../PrivateClassFields.golden | 9 +- .../PrivateMethodAccess.golden | 20 +- .../PublicClassFields.golden | 9 +- .../StaticClassFields.golden | 33 +- .../StaticPrivateMethodAccess.golden | 30 +- .../interpreter/interpreter-unittest.cc | 28 +- .../unittests/libplatform/tracing-unittest.cc | 13 +- .../v8/test/unittests/logging/log-unittest.cc | 9 +- .../objects/concurrent-string-unittest.cc | 4 - .../test/unittests/objects/roots-unittest.cc | 11 + .../objects/value-serializer-unittest.cc | 130 +- .../unittests/objects/weakmaps-unittest.cc | 6 + .../test/unittests/parser/decls-unittest.cc | 2 - .../test/unittests/parser/parsing-unittest.cc | 12 +- .../test/unittests/regexp/regexp-unittest.cc | 75 +- deps/v8/test/unittests/test-utils.cc | 20 +- deps/v8/test/unittests/test-utils.h | 33 +- deps/v8/test/unittests/testcfg.py | 16 +- .../test/unittests/torque/torque-unittest.cc | 2 +- deps/v8/test/unittests/unittests.status | 11 +- .../unittests/utils/identity-map-unittest.cc | 1 + .../test/unittests/wasm/decoder-unittest.cc | 137 +- .../wasm/function-body-decoder-unittest.cc | 199 +- .../unittests/wasm/leb-helper-unittest.cc | 5 +- .../wasm/loop-assignment-analysis-unittest.cc | 29 +- .../wasm/memory-protection-unittest.cc | 66 +- .../wasm/module-decoder-memory64-unittest.cc | 8 +- .../unittests/wasm/module-decoder-unittest.cc | 356 +- .../wasm/streaming-decoder-unittest.cc | 80 +- .../unittests/wasm/struct-types-unittest.cc | 70 + .../test/unittests/wasm/subtyping-unittest.cc | 157 +- ....cc => trap-handler-x64-arm64-unittest.cc} | 145 +- .../wasm-disassembler-unittest-gc.wasm.inc | 135 + .../wasm-disassembler-unittest-gc.wat.inc | 107 + .../wasm-disassembler-unittest-mvp.wat.inc | 1 - ...sassembler-unittest-too-many-ends.wasm.inc | 31 + ...isassembler-unittest-too-many-ends.wat.inc | 9 + .../wasm/wasm-disassembler-unittest.cc | 38 +- .../web-snapshot/web-snapshot-unittest.cc | 1135 --- .../unittests/zone/zone-vector-unittest.cc | 373 + deps/v8/test/wasm-api-tests/callbacks.cc | 2 - deps/v8/test/wasm-api-tests/finalize.cc | 7 +- deps/v8/test/wasm-api-tests/serialize.cc | 2 - deps/v8/test/wasm-api-tests/table.cc | 2 +- deps/v8/test/wasm-api-tests/traps.cc | 9 +- deps/v8/test/wasm-api-tests/wasm-api-test.h | 4 +- deps/v8/test/wasm-js/tests.tar.gz.sha1 | 2 +- deps/v8/test/wasm-js/wasm-js.status | 8 +- .../v8/test/wasm-spec-tests/tests.tar.gz.sha1 | 2 +- .../wasm-spec-tests/wasm-spec-tests.status | 31 +- deps/v8/test/webkit/testcfg.py | 2 +- deps/v8/third_party/glibc/LICENSE | 502 ++ deps/v8/third_party/glibc/METADATA | 18 + deps/v8/third_party/glibc/README.v8 | 8 + .../src/sysdeps/ieee754/dbl-64/branred.c | 143 + .../src/sysdeps/ieee754/dbl-64/branred.h | 79 + .../glibc/src/sysdeps/ieee754/dbl-64/dla.h | 38 + .../glibc/src/sysdeps/ieee754/dbl-64/endian.h | 21 + .../glibc/src/sysdeps/ieee754/dbl-64/mydefs.h | 34 + .../glibc/src/sysdeps/ieee754/dbl-64/s_sin.c | 312 + .../src/sysdeps/ieee754/dbl-64/sincostab.c | 913 +++ .../glibc/src/sysdeps/ieee754/dbl-64/trig.h | 14 + .../glibc/src/sysdeps/ieee754/dbl-64/usncs.h | 47 + .../jinja2/Jinja2-2.11.3.tar.gz.md5 | 1 - .../jinja2/Jinja2-2.11.3.tar.gz.sha512 | 1 - deps/v8/third_party/jinja2/README.chromium | 10 +- deps/v8/third_party/jinja2/README.rst | 26 +- deps/v8/third_party/jinja2/__init__.py | 71 +- deps/v8/third_party/jinja2/_compat.py | 132 - deps/v8/third_party/jinja2/_identifier.py | 2 +- deps/v8/third_party/jinja2/async_utils.py | 84 + deps/v8/third_party/jinja2/asyncfilters.py | 158 - deps/v8/third_party/jinja2/asyncsupport.py | 264 - deps/v8/third_party/jinja2/bccache.py | 190 +- deps/v8/third_party/jinja2/compiler.py | 1202 +-- deps/v8/third_party/jinja2/constants.py | 3 +- deps/v8/third_party/jinja2/debug.py | 199 +- deps/v8/third_party/jinja2/defaults.py | 18 +- deps/v8/third_party/jinja2/environment.py | 1095 ++- deps/v8/third_party/jinja2/exceptions.py | 103 +- deps/v8/third_party/jinja2/ext.py | 497 +- deps/v8/third_party/jinja2/filters.py | 1080 ++- deps/v8/third_party/jinja2/idtracking.py | 176 +- deps/v8/third_party/jinja2/jinja2.gni | 4 +- deps/v8/third_party/jinja2/lexer.py | 442 +- deps/v8/third_party/jinja2/loaders.py | 425 +- deps/v8/third_party/jinja2/meta.py | 62 +- deps/v8/third_party/jinja2/nativetypes.py | 70 +- deps/v8/third_party/jinja2/nodes.py | 502 +- deps/v8/third_party/jinja2/optimizer.py | 18 +- deps/v8/third_party/jinja2/parser.py | 341 +- ...iled-template-deterministic-for-pyth.patch | 30 - deps/v8/third_party/jinja2/py.typed | 0 deps/v8/third_party/jinja2/runtime.py | 816 +- deps/v8/third_party/jinja2/sandbox.py | 264 +- deps/v8/third_party/jinja2/tests.py | 114 +- deps/v8/third_party/jinja2/utils.py | 594 +- deps/v8/third_party/jinja2/visitor.py | 35 +- deps/v8/third_party/zlib/CMakeLists.txt | 234 + .../zlib/contrib/optimizations/chunkcopy.h | 2 +- .../contrib/optimizations/insert_string.h | 5 +- deps/v8/third_party/zlib/google/OWNERS | 2 - deps/v8/third_party/zlib/google/zip.cc | 2 +- deps/v8/third_party/zlib/google/zip.h | 2 +- deps/v8/third_party/zlib/google/zip_reader.cc | 18 +- deps/v8/third_party/zlib/google/zip_reader.h | 2 +- .../zlib/google/zip_reader_unittest.cc | 2 +- .../third_party/zlib/google/zip_unittest.cc | 2 +- .../zlib/patches/0010-cmake-enable-simd.patch | 96 + deps/v8/third_party/zlib/zconf.h.cmakein | 549 ++ deps/v8/third_party/zlib/zlib.3 | 149 + deps/v8/third_party/zlib/zlib.pc.cmakein | 13 + deps/v8/tools/.vpython3 | 91 + deps/v8/tools/BUILD.gn | 6 +- deps/v8/tools/PRESUBMIT.py | 17 +- deps/v8/tools/bazel/bazel.sha1 | 2 +- deps/v8/tools/builtins-pgo/arm64.profile | 6403 ---------------- .../tools/builtins-pgo/download_profiles.py | 151 + .../builtins-pgo/download_profiles_test.py | 62 + deps/v8/tools/builtins-pgo/generate.py | 3 +- deps/v8/tools/builtins-pgo/profile_only.py | 83 + deps/v8/tools/builtins-pgo/x64.profile | 6559 +++++++++-------- .../builtins-pgo/{arm.profile => x86.profile} | 6471 ++++++++-------- deps/v8/tools/callstats.html | 2 - deps/v8/tools/callstats_groups.py | 1 - .../foozzie/testdata/failure_output.txt | 2 +- .../foozzie/testdata/failure_output_arch.txt | 2 +- .../testdata/failure_output_second.txt | 2 +- .../foozzie/testdata/smoke_test_output.txt | 2 +- .../tools/clusterfuzz/foozzie/v8_foozzie.py | 18 +- .../foozzie/v8_fuzz_experiments.json | 9 +- .../clusterfuzz/foozzie/v8_fuzz_flags.json | 4 +- .../clusterfuzz/js_fuzzer/gen_exceptions.sh | 0 .../js_fuzzer/generated/exceptions.js | 553 +- .../mutators/function_call_mutator.js | 11 +- .../clusterfuzz/js_fuzzer/script_mutator.js | 32 +- .../clusterfuzz/js_fuzzer/source_helpers.js | 16 +- .../test/test_mutate_function_calls.js | 17 +- .../js_fuzzer/test/test_mutation_order.js | 56 + .../mutate_function_call_maglev_expected.js | 23 + .../test_data/mutation_order/input.js | 23 + .../mutation_order/output_expected.js | 119 + .../test_data/spidermonkey/test/load.js | 3 + .../spidermonkey/test/load_expected.js | 1 + .../clusterfuzz/js_fuzzer/tools/run_one.py | 5 +- .../trials/clusterfuzz_trials_config.json | 13 +- deps/v8/tools/codemap.mjs | 18 +- .../debug_helper/debug-helper-internal.cc | 5 +- .../tools/debug_helper/gen-heap-constants.py | 5 +- .../debug_helper/get-object-properties.cc | 33 +- deps/v8/tools/dev/gen-static-roots.py | 126 + deps/v8/tools/dev/gm.py | 6 + deps/v8/tools/dev/update-compile-commands.py | 21 +- deps/v8/tools/dev/update-vscode.sh | 26 +- deps/v8/tools/gcmole/BUILD.gn | 86 +- deps/v8/tools/gcmole/PRESUBMIT.py | 32 + deps/v8/tools/gcmole/gcmole-test.cc | 10 + deps/v8/tools/gcmole/gcmole.py | 590 +- deps/v8/tools/gcmole/gcmole_args.py | 59 + deps/v8/tools/gcmole/gcmole_test.py | 433 ++ deps/v8/tools/gcmole/run-gcmole.py | 25 +- deps/v8/tools/gcmole/test-expectations.txt | 203 +- deps/v8/tools/gcmole/testdata/v8/BUILD.gn | 35 + .../v8/out/obj/v8_base_without_compiler.ninja | 7 + .../gcmole/testdata/v8/test/cctest/BUILD.gn | 12 + deps/v8/tools/gdbinit | 7 +- deps/v8/tools/gen-postmortem-metadata.py | 670 +- .../tools/generate-header-include-checks.py | 2 + deps/v8/tools/heap-stats/categories.js | 2 +- deps/v8/tools/logreader.mjs | 27 +- deps/v8/tools/profile.mjs | 12 +- deps/v8/tools/profview/profile-utils.js | 12 +- deps/v8/tools/profview/profview.js | 8 +- deps/v8/tools/release/auto_roll.py | 9 - deps/v8/tools/release/test_scripts.py | 5 - deps/v8/tools/run_perf.py | 32 +- deps/v8/tools/system-analyzer/log/tick.mjs | 2 +- deps/v8/tools/system-analyzer/processor.mjs | 70 +- deps/v8/tools/system-analyzer/view/helper.mjs | 4 +- .../view/property-link-table.mjs | 4 +- .../system-analyzer/view/script-panel.mjs | 170 +- deps/v8/tools/testrunner/base_runner.py | 53 +- deps/v8/tools/testrunner/build_config.py | 57 +- deps/v8/tools/testrunner/local/command.py | 63 +- deps/v8/tools/testrunner/local/statusfile.py | 13 +- deps/v8/tools/testrunner/local/testsuite.py | 17 +- .../tools/testrunner/local/testsuite_test.py | 6 +- deps/v8/tools/testrunner/local/variants.py | 130 +- deps/v8/tools/testrunner/num_fuzzer.py | 3 +- deps/v8/tools/testrunner/objects/testcase.py | 118 +- .../tools/testrunner/objects/testcase_test.py | 74 + deps/v8/tools/testrunner/standard_runner.py | 3 +- .../tools/testrunner/standard_runner_test.py | 50 +- deps/v8/tools/testrunner/test_config.py | 6 + .../testdata/expected_test_results1.json | 246 +- .../testdata/expected_test_results2.json | 156 +- .../testroot1/out/build/v8_build_config.json | 14 +- .../testroot2/out/build/v8_build_config.json | 14 +- .../testroot3/out/build/v8_build_config.json | 14 +- .../out.gn/build/v8_build_config.json | 14 +- .../testroot6/out/build/v8_build_config.json | 14 +- deps/v8/tools/testrunner/testproc/base.py | 10 +- .../tools/testrunner/testproc/expectation.py | 2 +- deps/v8/tools/testrunner/testproc/fuzzer.py | 18 +- .../tools/testrunner/testproc/indicators.py | 13 +- deps/v8/tools/testrunner/testproc/progress.py | 5 +- deps/v8/tools/testrunner/testproc/rerun.py | 2 +- deps/v8/tools/testrunner/testproc/resultdb.py | 61 +- deps/v8/tools/testrunner/testproc/seed.py | 2 +- deps/v8/tools/testrunner/testproc/shard.py | 2 +- .../testproc/stack_utils/__init__.py | 3 + .../testproc/stack_utils/clusterfuzz_fakes.py | 30 + .../stack_utils/stack_analyzer_util.py | 107 + .../stack_utils/stack_analyzer_util_test.py | 65 + .../analyze_crash/code_kind.expected.json | 4 + .../testdata/analyze_crash/code_kind.txt | 20 + .../analyze_crash/data_race_1.expected.json | 4 + .../testdata/analyze_crash/data_race_1.txt | 91 + .../analyze_crash/data_race_2.expected.json | 4 + .../testdata/analyze_crash/data_race_2.txt | 118 + .../data_race_clusterfuzz.expected.json | 4 + .../analyze_crash/data_race_clusterfuzz.txt | 50 + .../deserialization.expected.json | 4 + .../analyze_crash/deserialization.txt | 43 + .../analyze_crash/fata_js_oom.expected.json | 4 + .../testdata/analyze_crash/fata_js_oom.txt | 48 + .../has_optimized_code.expected.json | 4 + .../analyze_crash/has_optimized_code.txt | 30 + .../analyze_crash/heap_limit.expected.json | 4 + .../testdata/analyze_crash/heap_limit.txt | 33 + .../is_main_thread_barrier.expected.json | 4 + .../analyze_crash/is_main_thread_barrier.txt | 30 + .../is_main_thread_barrier_2.expected.json | 4 + .../is_main_thread_barrier_2.txt | 26 + .../analyze_crash/js_func_ref.expected.json | 4 + .../testdata/analyze_crash/js_func_ref.txt | 55 + .../analyze_crash/marking_state.expected.json | 4 + .../testdata/analyze_crash/marking_state.txt | 37 + .../maybe_is_cleared.expected.json | 4 + .../analyze_crash/maybe_is_cleared.txt | 21 + .../missing_deoptimization.expected.json | 4 + .../analyze_crash/missing_deoptimization.txt | 24 + .../analyze_crash/seg_map_err.expected.json | 4 + .../testdata/analyze_crash/seg_map_err.txt | 13 + .../segmentation_error.expected.json | 4 + .../analyze_crash/segmentation_error.txt | 9 + .../segmentation_fault.expected.json | 4 + .../analyze_crash/segmentation_fault.txt | 15 + .../analyze_crash/stack_frame.expected.json | 4 + .../testdata/analyze_crash/stack_frame.txt | 60 + .../static_assertion_1.expected.json | 4 + .../analyze_crash/static_assertion_1.txt | 37 + .../static_assertion_2.expected.json | 4 + .../analyze_crash/static_assertion_2.txt | 37 + .../storage_is_populated.expected.json | 4 + .../analyze_crash/storage_is_populated.txt | 35 + .../topmost_optimized_code.expected.json | 4 + .../analyze_crash/topmost_optimized_code.txt | 24 + .../type_assertion_1.expected.json | 4 + .../analyze_crash/type_assertion_1.txt | 1 + .../type_assertion_2.expected.json | 4 + .../analyze_crash/type_assertion_2.txt | 5 + .../unreachable_code.expected.json | 4 + .../analyze_crash/unreachable_code.txt | 28 + .../custom_analyzer/data_race_1.expected | 3 + .../testdata/custom_analyzer/data_race_1.txt | 91 + .../custom_analyzer/data_race_2.expected | 3 + .../testdata/custom_analyzer/data_race_2.txt | 118 + .../custom_analyzer/data_race_3.expected | 3 + .../testdata/custom_analyzer/data_race_3.txt | 50 + .../custom_analyzer/data_race_4.expected | 3 + .../testdata/custom_analyzer/data_race_4.txt | 190 + .../custom_analyzer/data_race_5.expected | 3 + .../testdata/custom_analyzer/data_race_5.txt | 198 + .../custom_analyzer/data_race_6.expected | 3 + .../testdata/custom_analyzer/data_race_6.txt | 112 + .../custom_analyzer/data_race_8.expected | 3 + .../testdata/custom_analyzer/data_race_8.txt | 510 ++ .../custom_analyzer/data_race_9.expected | 3 + .../testdata/custom_analyzer/data_race_9.txt | 128 + deps/v8/tools/testrunner/testproc/util.py | 27 +- deps/v8/tools/testrunner/testproc/variant.py | 7 +- .../testrunner/utils/augmented_options.py | 5 + deps/v8/tools/testrunner/utils/test_utils.py | 24 +- .../tools/torque/vim-torque/syntax/torque.vim | 2 +- deps/v8/tools/try_perf.py | 1 - .../css/turbo-visualizer-ranges.css | 238 +- .../tools/turbolizer/css/turbo-visualizer.css | 11 +- .../tools/turbolizer/src/common/constants.ts | 5 + deps/v8/tools/turbolizer/src/common/util.ts | 4 + .../turbolizer/src/phases/schedule-phase.ts | 22 +- .../turbolizer/src/phases/sequence-phase.ts | 57 +- deps/v8/tools/turbolizer/src/resizer.ts | 23 +- .../tools/turbolizer/src/views/range-view.ts | 886 ++- .../turbolizer/src/views/schedule-view.ts | 14 +- .../turbolizer/src/views/sequence-view.ts | 53 +- .../tools/turbolizer/src/views/text-view.ts | 20 + deps/v8/tools/turbolizer/tslint.json | 1 - deps/v8/tools/ubsan/ignorelist.txt | 3 + deps/v8/tools/v8_presubmit.py | 48 +- deps/v8/tools/v8heapconst.py | 930 +-- deps/v8/tools/v8windbg/src/cur-isolate.cc | 49 +- deps/v8/tools/v8windbg/src/cur-isolate.h | 4 +- deps/v8/tools/v8windbg/test/v8windbg-test.cc | 43 +- deps/v8/tools/wasm/module-inspector.cc | 143 +- deps/v8/tools/whitespace.txt | 6 +- 2203 files changed, 148751 insertions(+), 90145 deletions(-) create mode 100644 deps/v8/src/base/ios-headers.h delete mode 100644 deps/v8/src/base/platform/platform-macos.cc create mode 100644 deps/v8/src/builtins/builtins-object-gen.h delete mode 100644 deps/v8/src/builtins/builtins-web-snapshots.cc create mode 100644 deps/v8/src/builtins/iterator-helpers.tq create mode 100644 deps/v8/src/builtins/string-iswellformed.tq create mode 100644 deps/v8/src/builtins/string-towellformed.tq rename deps/v8/src/codegen/{turbo-assembler.cc => macro-assembler-base.cc} (84%) rename deps/v8/src/codegen/{turbo-assembler.h => macro-assembler-base.h} (81%) create mode 100644 deps/v8/src/common/ptr-compr.cc create mode 100644 deps/v8/src/compiler/revectorizer.cc create mode 100644 deps/v8/src/compiler/revectorizer.h create mode 100644 deps/v8/src/compiler/turbofan-disabled.cc create mode 100644 deps/v8/src/compiler/turbofan-enabled.cc create mode 100644 deps/v8/src/compiler/turbofan.h create mode 100644 deps/v8/src/compiler/turboshaft/assembler.cc create mode 100644 deps/v8/src/compiler/turboshaft/assert-types-reducer.h create mode 100644 deps/v8/src/compiler/turboshaft/branch-elimination-reducer.h create mode 100644 deps/v8/src/compiler/turboshaft/dead-code-elimination-reducer.h create mode 100644 deps/v8/src/compiler/turboshaft/define-assembler-macros.inc create mode 100644 deps/v8/src/compiler/turboshaft/index.h create mode 100644 deps/v8/src/compiler/turboshaft/late-escape-analysis-reducer.cc create mode 100644 deps/v8/src/compiler/turboshaft/late-escape-analysis-reducer.h create mode 100644 deps/v8/src/compiler/turboshaft/layered-hash-map.h create mode 100644 deps/v8/src/compiler/turboshaft/machine-lowering-reducer.h create mode 100644 deps/v8/src/compiler/turboshaft/memory-optimization.cc create mode 100644 deps/v8/src/compiler/turboshaft/memory-optimization.h create mode 100644 deps/v8/src/compiler/turboshaft/reducer-traits.h create mode 100644 deps/v8/src/compiler/turboshaft/tag-untag-lowering-reducer.h create mode 100644 deps/v8/src/compiler/turboshaft/type-inference-analysis.h create mode 100644 deps/v8/src/compiler/turboshaft/type-inference-reducer.h create mode 100644 deps/v8/src/compiler/turboshaft/type-parser.cc create mode 100644 deps/v8/src/compiler/turboshaft/type-parser.h create mode 100644 deps/v8/src/compiler/turboshaft/typed-optimizations-reducer.h create mode 100644 deps/v8/src/compiler/turboshaft/typer.cc create mode 100644 deps/v8/src/compiler/turboshaft/typer.h create mode 100644 deps/v8/src/compiler/turboshaft/types.cc create mode 100644 deps/v8/src/compiler/turboshaft/types.h create mode 100644 deps/v8/src/compiler/turboshaft/undef-assembler-macros.inc create mode 100644 deps/v8/src/compiler/turboshaft/uniform-reducer-adapter.h create mode 100644 deps/v8/src/compiler/turboshaft/variable-reducer.h create mode 100644 deps/v8/src/compiler/wasm-call-descriptors.cc create mode 100644 deps/v8/src/compiler/wasm-call-descriptors.h create mode 100644 deps/v8/src/compiler/wasm-load-elimination.cc create mode 100644 deps/v8/src/compiler/wasm-load-elimination.h create mode 100644 deps/v8/src/heap/base/asm/arm/push_registers_asm.cc delete mode 100644 deps/v8/src/heap/base/asm/arm/save_registers_asm.cc create mode 100644 deps/v8/src/heap/base/asm/arm64/push_registers_asm.cc create mode 100644 deps/v8/src/heap/base/asm/arm64/push_registers_masm.S delete mode 100644 deps/v8/src/heap/base/asm/arm64/save_registers_asm.cc delete mode 100644 deps/v8/src/heap/base/asm/arm64/save_registers_masm.S create mode 100644 deps/v8/src/heap/base/asm/ia32/push_registers_asm.cc create mode 100644 deps/v8/src/heap/base/asm/ia32/push_registers_masm.asm delete mode 100644 deps/v8/src/heap/base/asm/ia32/save_registers_asm.cc delete mode 100644 deps/v8/src/heap/base/asm/ia32/save_registers_masm.asm create mode 100644 deps/v8/src/heap/base/asm/loong64/push_registers_asm.cc delete mode 100644 deps/v8/src/heap/base/asm/loong64/save_registers_asm.cc create mode 100644 deps/v8/src/heap/base/asm/mips64/push_registers_asm.cc delete mode 100644 deps/v8/src/heap/base/asm/mips64/save_registers_asm.cc create mode 100644 deps/v8/src/heap/base/asm/ppc/push_registers_asm.cc delete mode 100644 deps/v8/src/heap/base/asm/ppc/save_registers_asm.cc create mode 100644 deps/v8/src/heap/base/asm/riscv/push_registers_asm.cc delete mode 100644 deps/v8/src/heap/base/asm/riscv/save_registers_asm.cc create mode 100644 deps/v8/src/heap/base/asm/s390/push_registers_asm.cc delete mode 100644 deps/v8/src/heap/base/asm/s390/save_registers_asm.cc create mode 100644 deps/v8/src/heap/base/asm/x64/push_registers_asm.cc create mode 100644 deps/v8/src/heap/base/asm/x64/push_registers_masm.asm delete mode 100644 deps/v8/src/heap/base/asm/x64/save_registers_asm.cc delete mode 100644 deps/v8/src/heap/base/asm/x64/save_registers_masm.asm create mode 100644 deps/v8/src/heap/cppgc-js/cross-heap-remembered-set.cc create mode 100644 deps/v8/src/heap/cppgc-js/cross-heap-remembered-set.h create mode 100644 deps/v8/src/heap/cppgc-js/wrappable-info-inl.h create mode 100644 deps/v8/src/heap/cppgc-js/wrappable-info.h delete mode 100644 deps/v8/src/heap/embedder-tracing-inl.h delete mode 100644 deps/v8/src/heap/embedder-tracing.cc delete mode 100644 deps/v8/src/heap/embedder-tracing.h delete mode 100644 deps/v8/src/heap/global-handle-marking-visitor.h rename deps/v8/src/heap/{global-handle-marking-visitor.cc => traced-handles-marking-visitor.cc} (72%) create mode 100644 deps/v8/src/heap/traced-handles-marking-visitor.h create mode 100644 deps/v8/src/inspector/crc32.cc create mode 100644 deps/v8/src/inspector/crc32.h create mode 100644 deps/v8/src/inspector/v8-debugger-barrier.cc create mode 100644 deps/v8/src/inspector/v8-debugger-barrier.h create mode 100644 deps/v8/src/maglev/arm64/maglev-assembler-arm64-inl.h create mode 100644 deps/v8/src/maglev/arm64/maglev-assembler-arm64.cc create mode 100644 deps/v8/src/maglev/arm64/maglev-ir-arm64.cc create mode 100644 deps/v8/src/maglev/maglev-phi-representation-selector.cc create mode 100644 deps/v8/src/maglev/maglev-phi-representation-selector.h delete mode 100644 deps/v8/src/maglev/maglev-vreg-allocator.h create mode 100644 deps/v8/src/maglev/x64/maglev-assembler-x64-inl.h create mode 100644 deps/v8/src/maglev/x64/maglev-assembler-x64.cc create mode 100644 deps/v8/src/maglev/x64/maglev-ir-x64.cc create mode 100644 deps/v8/src/objects/js-iterator-helpers-inl.h create mode 100644 deps/v8/src/objects/js-iterator-helpers.h create mode 100644 deps/v8/src/objects/js-iterator-helpers.tq create mode 100644 deps/v8/src/objects/js-struct.cc create mode 100644 deps/v8/src/objects/turboshaft-types-inl.h create mode 100644 deps/v8/src/objects/turboshaft-types.h create mode 100644 deps/v8/src/objects/turboshaft-types.tq create mode 100644 deps/v8/src/roots/static-roots.h delete mode 100644 deps/v8/src/sanitizer/OWNERS create mode 100644 deps/v8/src/snapshot/static-roots-gen.cc create mode 100644 deps/v8/src/snapshot/static-roots-gen.h delete mode 100644 deps/v8/src/web-snapshot/web-snapshot.cc delete mode 100644 deps/v8/src/web-snapshot/web-snapshot.h create mode 100644 deps/v8/test/benchmarks/cpp/dtoa.cc create mode 100644 deps/v8/test/cctest/test-regexp.cc create mode 100644 deps/v8/test/fuzzer/wasm/regress-1404619.wasm create mode 100644 deps/v8/test/fuzzer/wasm_async/regress-1405322.wasm create mode 100644 deps/v8/test/inspector/debugger/break-on-exception-async-gen-expected.txt create mode 100644 deps/v8/test/inspector/debugger/break-on-exception-async-gen.js create mode 100644 deps/v8/test/inspector/debugger/evaluate-on-call-frame-private-class-member-conflict-expected.txt create mode 100644 deps/v8/test/inspector/debugger/evaluate-on-call-frame-private-class-member-conflict.js create mode 100644 deps/v8/test/inspector/debugger/evaluate-on-call-frame-private-class-member-expected.txt create mode 100644 deps/v8/test/inspector/debugger/evaluate-on-call-frame-private-class-member-in-module-expected.txt create mode 100644 deps/v8/test/inspector/debugger/evaluate-on-call-frame-private-class-member-in-module.js create mode 100644 deps/v8/test/inspector/debugger/evaluate-on-call-frame-private-class-member-static-expected.txt create mode 100644 deps/v8/test/inspector/debugger/evaluate-on-call-frame-private-class-member-static.js create mode 100644 deps/v8/test/inspector/debugger/evaluate-on-call-frame-private-class-member-super-expected.txt create mode 100644 deps/v8/test/inspector/debugger/evaluate-on-call-frame-private-class-member.js create mode 100644 deps/v8/test/inspector/debugger/instrumentation-multiple-sessions-expected.txt create mode 100644 deps/v8/test/inspector/debugger/instrumentation-multiple-sessions.js create mode 100644 deps/v8/test/inspector/debugger/session-stop-expected.txt create mode 100644 deps/v8/test/inspector/debugger/session-stop.js create mode 100644 deps/v8/test/inspector/debugger/set-script-source-es-module-expected.txt create mode 100644 deps/v8/test/inspector/debugger/set-script-source-es-module.js create mode 100644 deps/v8/test/inspector/private-class-member-inspector-test.js create mode 100644 deps/v8/test/inspector/regress/regress-crbug-1270780-expected.txt create mode 100644 deps/v8/test/inspector/regress/regress-crbug-1270780.js create mode 100644 deps/v8/test/inspector/regress/regress-crbug-1401674-expected.txt create mode 100644 deps/v8/test/inspector/regress/regress-crbug-1401674.js create mode 100644 deps/v8/test/inspector/runtime/evaluate-private-class-member-conflict-expected.txt create mode 100644 deps/v8/test/inspector/runtime/evaluate-private-class-member-conflict.js create mode 100644 deps/v8/test/inspector/runtime/evaluate-private-class-member-expected.txt create mode 100644 deps/v8/test/inspector/runtime/evaluate-private-class-member-static-expected.txt create mode 100644 deps/v8/test/inspector/runtime/evaluate-private-class-member-static.js create mode 100644 deps/v8/test/inspector/runtime/evaluate-private-class-member.js create mode 100644 deps/v8/test/inspector/runtime/exception-thrown-breakpoint-conditions-expected.txt create mode 100644 deps/v8/test/inspector/runtime/exception-thrown-breakpoint-conditions.js create mode 100644 deps/v8/test/inspector/runtime/internal-properties-prototype-chain-expected.txt create mode 100644 deps/v8/test/inspector/runtime/internal-properties-prototype-chain.js create mode 100644 deps/v8/test/inspector/runtime/run-if-waiting-for-debugger-expected.txt create mode 100644 deps/v8/test/inspector/runtime/run-if-waiting-for-debugger.js delete mode 100644 deps/v8/test/js-perf-test/BigInt/add-no-opt.js delete mode 100644 deps/v8/test/js-perf-test/BigInt/exponentiate.js create mode 100644 deps/v8/test/message/fail/strict-prior-octal-escape-use-strict-before.js create mode 100644 deps/v8/test/message/fail/strict-prior-octal-escape-use-strict-before.out create mode 100644 deps/v8/test/message/fail/strict-prior-octal-escape.js create mode 100644 deps/v8/test/message/fail/strict-prior-octal-escape.out create mode 100644 deps/v8/test/message/fail/strict-prior-octal-literal.js create mode 100644 deps/v8/test/message/fail/strict-prior-octal-literal.out create mode 100644 deps/v8/test/message/fail/var-prior-conflict.js create mode 100644 deps/v8/test/message/fail/var-prior-conflict.out create mode 100644 deps/v8/test/mjsunit/asm/regress-1395401.js create mode 100644 deps/v8/test/mjsunit/code-stats-flag.js create mode 100644 deps/v8/test/mjsunit/compiler/bigint-bitwise-or.js create mode 100644 deps/v8/test/mjsunit/compiler/bigint-bitwise-xor.js create mode 100644 deps/v8/test/mjsunit/compiler/bigint-compare.js create mode 100644 deps/v8/test/mjsunit/compiler/bigint-constructor.js create mode 100644 deps/v8/test/mjsunit/compiler/bigint-equal.js create mode 100644 deps/v8/test/mjsunit/compiler/bigint-shift-left.js create mode 100644 deps/v8/test/mjsunit/compiler/bigint-shift-right.js create mode 100644 deps/v8/test/mjsunit/compiler/bigint64-array.js create mode 100644 deps/v8/test/mjsunit/compiler/fast-api-calls-pointer.js create mode 100644 deps/v8/test/mjsunit/compiler/regress-crbug-1399490.js create mode 100644 deps/v8/test/mjsunit/compiler/regress-crbug-1399626.js create mode 100644 deps/v8/test/mjsunit/compiler/regress-crbug-1399627.js create mode 100644 deps/v8/test/mjsunit/compiler/regress-crbug-1408013.js delete mode 100644 deps/v8/test/mjsunit/const-dict-tracking.js delete mode 100644 deps/v8/test/mjsunit/const-field-tracking.js create mode 100644 deps/v8/test/mjsunit/harmony/iterator-helpers.js create mode 100644 deps/v8/test/mjsunit/harmony/json-parse-with-source-snapshot.js create mode 100644 deps/v8/test/mjsunit/harmony/regress/regress-crbug-1410963.js create mode 100644 deps/v8/test/mjsunit/harmony/shadowrealm-callsite-throw.js create mode 100644 deps/v8/test/mjsunit/harmony/shadowrealm-skip-3-throw-object.mjs create mode 100644 deps/v8/test/mjsunit/harmony/string-iswellformed-external-uncached.js create mode 100644 deps/v8/test/mjsunit/harmony/string-iswellformed-flat-indirect.js create mode 100644 deps/v8/test/mjsunit/harmony/weakrefs/symbol-in-finalizationregistry.js create mode 100644 deps/v8/test/mjsunit/maglev/continuation-after-inlined.js create mode 100644 deps/v8/test/mjsunit/maglev/inline-fresh-parent-deopt-frame.js create mode 100644 deps/v8/test/mjsunit/maglev/inline-phi-leak.js create mode 100644 deps/v8/test/mjsunit/maglev/lots-of-args.js create mode 100644 deps/v8/test/mjsunit/maglev/math-round.js create mode 100644 deps/v8/test/mjsunit/maglev/negate.js create mode 100644 deps/v8/test/mjsunit/maglev/nested-continuations.js create mode 100644 deps/v8/test/mjsunit/maglev/polymorphic-load-number.js create mode 100644 deps/v8/test/mjsunit/maglev/regress-1403324.js create mode 100644 deps/v8/test/mjsunit/maglev/regress-1405092.js create mode 100644 deps/v8/test/mjsunit/maglev/regress-1406456.js create mode 100644 deps/v8/test/mjsunit/maglev/regress-1407606.js create mode 100644 deps/v8/test/mjsunit/maglev/regress-1411075.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-1383712.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-1392936.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-1394279.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-1403575.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-1405651.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-1407959.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-crbug-1392061.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-crbug-1394036.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-crbug-1403280.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-crbug-1403323.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-crbug-1403399.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-crbug-1403470.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-crbug-1403749.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-crbug-1405445.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-crbug-1416693.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-crbug-1416795.js create mode 100644 deps/v8/test/mjsunit/maglev/regress/regress-crbug-1417386.js create mode 100644 deps/v8/test/mjsunit/maglev/resumable-loop-context.js create mode 100644 deps/v8/test/mjsunit/maglev/resumable.js create mode 100644 deps/v8/test/mjsunit/maglev/typedarray-resizablearraybuffer.js create mode 100644 deps/v8/test/mjsunit/maglev/unused-checkedsmitag.js create mode 100644 deps/v8/test/mjsunit/rab-gsab-transfer-to-worker.js create mode 100644 deps/v8/test/mjsunit/regress-1400809.js create mode 100644 deps/v8/test/mjsunit/regress-v8-13459.js create mode 100644 deps/v8/test/mjsunit/regress/asm/regress-1402270.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1320641.js create mode 100644 deps/v8/test/mjsunit/regress/regress-13652.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1383362.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1385368.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1393865.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1393942.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1394663.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1400053.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1400056.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1400897.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1404607.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1404863.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1407070.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1407349.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1408086.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1408400.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1408606.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1409058.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1412629.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1412975.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1414200.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1416520.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1416697.js create mode 100644 deps/v8/test/mjsunit/regress/regress-1416830.js create mode 100644 deps/v8/test/mjsunit/regress/regress-chromium-1409294.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1381404.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1383883.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1383976.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1384474-variant2.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1384474-variant3.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1384474.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1392577.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1393375.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1394741.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1395117.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1399695.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1399799.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1402139.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1404820.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1406774.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1407080.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1407384.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1408310.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1412938.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1415249.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1415581.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1416248.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1416395.js create mode 100644 deps/v8/test/mjsunit/regress/regress-crbug-1417882.js create mode 100644 deps/v8/test/mjsunit/regress/regress-v8-13410.js create mode 100644 deps/v8/test/mjsunit/regress/wasm/export-wrapper-canonical-types.js create mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-13700.js create mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-13715.js create mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-13732.js create mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-1388938.js create mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-1388942.js create mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-1395604.js create mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-1403398.js create mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-1408337.js create mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-1412940.js create mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-1416758.js create mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-1417516.js create mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-1417908.js create mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-1418706.js create mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-crbug-1407594.js create mode 100644 deps/v8/test/mjsunit/regress/wasm/regress-struct-set-into-unreachable.js create mode 100644 deps/v8/test/mjsunit/shared-memory/cannot-redefine-properties.js create mode 100644 deps/v8/test/mjsunit/shared-memory/mutex-lock-twice.js create mode 100644 deps/v8/test/mjsunit/shared-memory/non-instance-prototype.js create mode 100644 deps/v8/test/mjsunit/shared-memory/private-field.js create mode 100644 deps/v8/test/mjsunit/shared-memory/private-name.js create mode 100644 deps/v8/test/mjsunit/shared-memory/shared-string-copy-on-share-large.js create mode 100644 deps/v8/test/mjsunit/shared-memory/shared-string-copy-on-share.js create mode 100644 deps/v8/test/mjsunit/shared-memory/shared-value-barrier-optimization.js create mode 100644 deps/v8/test/mjsunit/shared-memory/shrink-large-object.js create mode 100644 deps/v8/test/mjsunit/tools/processor-bigint.mjs create mode 100644 deps/v8/test/mjsunit/turboshaft/type-inference.js create mode 100644 deps/v8/test/mjsunit/turboshaft/typed-optimizations.js create mode 100644 deps/v8/test/mjsunit/wasm/code-flushing.js create mode 100644 deps/v8/test/mjsunit/wasm/code-space-overflow.js rename deps/v8/test/mjsunit/wasm/{code-space-exhaustion.js => committed-code-exhaustion.js} (93%) rename deps/v8/test/mjsunit/wasm/{tier-down-to-liftoff.js => enter-debug-state.js} (64%) delete mode 100644 deps/v8/test/mjsunit/wasm/externref-globals-liftoff.js delete mode 100644 deps/v8/test/mjsunit/wasm/externref-liftoff.js create mode 100644 deps/v8/test/mjsunit/wasm/gc-cast-type-inference.js create mode 100644 deps/v8/test/mjsunit/wasm/gc-js-interop-async-debugger.js create mode 100644 deps/v8/test/mjsunit/wasm/gc-null-traps.js create mode 100644 deps/v8/test/mjsunit/wasm/log-code-after-post-message.js create mode 100644 deps/v8/test/mjsunit/wasm/max-wasm-functions.js create mode 100644 deps/v8/test/mjsunit/wasm/origin-trial-flags.js create mode 100644 deps/v8/test/mjsunit/wasm/return-calls-eh.js create mode 100644 deps/v8/test/mjsunit/wasm/stringview-valuestack.js delete mode 100644 deps/v8/test/mjsunit/wasm/table-access-liftoff.js create mode 100644 deps/v8/test/mjsunit/wasm/table-numeric-ops.js create mode 100644 deps/v8/test/mjsunit/wasm/wasm-gc-inlining.js create mode 100644 deps/v8/test/mjsunit/wasm/wrapper-compilation.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-array-buffer.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-array.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-base.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-bigint.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-builtin.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-circular-reference.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-class.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-data-view.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-externals.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-function-context.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-function.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-helpers.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-holey-array.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-object.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-prototype.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-sparse-array.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-symbol.js delete mode 100644 deps/v8/test/mjsunit/web-snapshot/web-snapshot-typed-array.js rename deps/v8/test/unittests/assembler/{turbo-assembler-arm-unittest.cc => macro-assembler-arm-unittest.cc} (86%) rename deps/v8/test/unittests/assembler/{turbo-assembler-ia32-unittest.cc => macro-assembler-ia32-unittest.cc} (82%) rename deps/v8/test/unittests/assembler/{turbo-assembler-loong64-unittest.cc => macro-assembler-loong64-unittest.cc} (83%) rename deps/v8/test/unittests/assembler/{turbo-assembler-mips64-unittest.cc => macro-assembler-mips64-unittest.cc} (83%) rename deps/v8/test/unittests/assembler/{turbo-assembler-ppc-unittest.cc => macro-assembler-ppc-unittest.cc} (58%) rename deps/v8/test/unittests/assembler/{turbo-assembler-riscv-unittest.cc => macro-assembler-riscv-unittest.cc} (83%) rename deps/v8/test/unittests/assembler/{turbo-assembler-s390-unittest.cc => macro-assembler-s390-unittest.cc} (83%) delete mode 100644 deps/v8/test/unittests/assembler/turbo-assembler-arm64-unittest.cc delete mode 100644 deps/v8/test/unittests/assembler/turbo-assembler-x64-unittest.cc create mode 100644 deps/v8/test/unittests/compiler/revec-unittest.cc create mode 100644 deps/v8/test/unittests/compiler/turboshaft/turboshaft-typer-unittest.cc create mode 100644 deps/v8/test/unittests/compiler/turboshaft/turboshaft-types-unittest.cc create mode 100644 deps/v8/test/unittests/heap/cppgc-js/embedder-roots-handler-unittest.cc create mode 100644 deps/v8/test/unittests/heap/cppgc-js/young-unified-heap-unittest.cc delete mode 100644 deps/v8/test/unittests/heap/embedder-tracing-unittest.cc create mode 100644 deps/v8/test/unittests/wasm/struct-types-unittest.cc rename deps/v8/test/unittests/wasm/{trap-handler-x64-unittest.cc => trap-handler-x64-arm64-unittest.cc} (80%) create mode 100644 deps/v8/test/unittests/wasm/wasm-disassembler-unittest-gc.wasm.inc create mode 100644 deps/v8/test/unittests/wasm/wasm-disassembler-unittest-gc.wat.inc create mode 100644 deps/v8/test/unittests/wasm/wasm-disassembler-unittest-too-many-ends.wasm.inc create mode 100644 deps/v8/test/unittests/wasm/wasm-disassembler-unittest-too-many-ends.wat.inc delete mode 100644 deps/v8/test/unittests/web-snapshot/web-snapshot-unittest.cc create mode 100644 deps/v8/test/unittests/zone/zone-vector-unittest.cc create mode 100644 deps/v8/third_party/glibc/LICENSE create mode 100644 deps/v8/third_party/glibc/METADATA create mode 100644 deps/v8/third_party/glibc/README.v8 create mode 100644 deps/v8/third_party/glibc/src/sysdeps/ieee754/dbl-64/branred.c create mode 100644 deps/v8/third_party/glibc/src/sysdeps/ieee754/dbl-64/branred.h create mode 100644 deps/v8/third_party/glibc/src/sysdeps/ieee754/dbl-64/dla.h create mode 100644 deps/v8/third_party/glibc/src/sysdeps/ieee754/dbl-64/endian.h create mode 100644 deps/v8/third_party/glibc/src/sysdeps/ieee754/dbl-64/mydefs.h create mode 100644 deps/v8/third_party/glibc/src/sysdeps/ieee754/dbl-64/s_sin.c create mode 100644 deps/v8/third_party/glibc/src/sysdeps/ieee754/dbl-64/sincostab.c create mode 100644 deps/v8/third_party/glibc/src/sysdeps/ieee754/dbl-64/trig.h create mode 100644 deps/v8/third_party/glibc/src/sysdeps/ieee754/dbl-64/usncs.h delete mode 100644 deps/v8/third_party/jinja2/Jinja2-2.11.3.tar.gz.md5 delete mode 100644 deps/v8/third_party/jinja2/Jinja2-2.11.3.tar.gz.sha512 delete mode 100644 deps/v8/third_party/jinja2/_compat.py create mode 100644 deps/v8/third_party/jinja2/async_utils.py delete mode 100644 deps/v8/third_party/jinja2/asyncfilters.py delete mode 100644 deps/v8/third_party/jinja2/asyncsupport.py delete mode 100644 deps/v8/third_party/jinja2/patches/0001-jinja2-make-compiled-template-deterministic-for-pyth.patch create mode 100644 deps/v8/third_party/jinja2/py.typed create mode 100644 deps/v8/third_party/zlib/CMakeLists.txt create mode 100644 deps/v8/third_party/zlib/patches/0010-cmake-enable-simd.patch create mode 100644 deps/v8/third_party/zlib/zconf.h.cmakein create mode 100644 deps/v8/third_party/zlib/zlib.3 create mode 100644 deps/v8/third_party/zlib/zlib.pc.cmakein create mode 100644 deps/v8/tools/.vpython3 delete mode 100644 deps/v8/tools/builtins-pgo/arm64.profile create mode 100755 deps/v8/tools/builtins-pgo/download_profiles.py create mode 100644 deps/v8/tools/builtins-pgo/download_profiles_test.py create mode 100755 deps/v8/tools/builtins-pgo/profile_only.py rename deps/v8/tools/builtins-pgo/{arm.profile => x86.profile} (52%) mode change 100644 => 100755 deps/v8/tools/clusterfuzz/js_fuzzer/gen_exceptions.sh create mode 100644 deps/v8/tools/clusterfuzz/js_fuzzer/test/test_mutation_order.js create mode 100644 deps/v8/tools/clusterfuzz/js_fuzzer/test_data/mutate_function_call_maglev_expected.js create mode 100644 deps/v8/tools/clusterfuzz/js_fuzzer/test_data/mutation_order/input.js create mode 100644 deps/v8/tools/clusterfuzz/js_fuzzer/test_data/mutation_order/output_expected.js create mode 100755 deps/v8/tools/dev/gen-static-roots.py create mode 100644 deps/v8/tools/gcmole/PRESUBMIT.py create mode 100644 deps/v8/tools/gcmole/gcmole_args.py create mode 100644 deps/v8/tools/gcmole/gcmole_test.py create mode 100644 deps/v8/tools/gcmole/testdata/v8/BUILD.gn create mode 100644 deps/v8/tools/gcmole/testdata/v8/out/obj/v8_base_without_compiler.ninja create mode 100644 deps/v8/tools/gcmole/testdata/v8/test/cctest/BUILD.gn mode change 100644 => 100755 deps/v8/tools/run_perf.py create mode 100644 deps/v8/tools/testrunner/objects/testcase_test.py create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/__init__.py create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/clusterfuzz_fakes.py create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/stack_analyzer_util.py create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/stack_analyzer_util_test.py create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/code_kind.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/code_kind.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/data_race_1.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/data_race_1.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/data_race_2.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/data_race_2.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/data_race_clusterfuzz.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/data_race_clusterfuzz.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/deserialization.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/deserialization.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/fata_js_oom.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/fata_js_oom.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/has_optimized_code.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/has_optimized_code.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/heap_limit.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/heap_limit.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/is_main_thread_barrier.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/is_main_thread_barrier.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/is_main_thread_barrier_2.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/is_main_thread_barrier_2.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/js_func_ref.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/js_func_ref.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/marking_state.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/marking_state.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/maybe_is_cleared.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/maybe_is_cleared.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/missing_deoptimization.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/missing_deoptimization.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/seg_map_err.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/seg_map_err.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/segmentation_error.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/segmentation_error.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/segmentation_fault.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/segmentation_fault.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/stack_frame.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/stack_frame.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/static_assertion_1.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/static_assertion_1.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/static_assertion_2.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/static_assertion_2.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/storage_is_populated.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/storage_is_populated.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/topmost_optimized_code.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/topmost_optimized_code.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/type_assertion_1.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/type_assertion_1.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/type_assertion_2.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/type_assertion_2.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/unreachable_code.expected.json create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/analyze_crash/unreachable_code.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/custom_analyzer/data_race_1.expected create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/custom_analyzer/data_race_1.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/custom_analyzer/data_race_2.expected create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/custom_analyzer/data_race_2.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/custom_analyzer/data_race_3.expected create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/custom_analyzer/data_race_3.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/custom_analyzer/data_race_4.expected create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/custom_analyzer/data_race_4.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/custom_analyzer/data_race_5.expected create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/custom_analyzer/data_race_5.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/custom_analyzer/data_race_6.expected create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/custom_analyzer/data_race_6.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/custom_analyzer/data_race_8.expected create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/custom_analyzer/data_race_8.txt create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/custom_analyzer/data_race_9.expected create mode 100644 deps/v8/tools/testrunner/testproc/stack_utils/testdata/custom_analyzer/data_race_9.txt diff --git a/deps/v8/.git-blame-ignore-revs b/deps/v8/.git-blame-ignore-revs index 4c53e208e3acec..29372f34c1813d 100644 --- a/deps/v8/.git-blame-ignore-revs +++ b/deps/v8/.git-blame-ignore-revs @@ -18,11 +18,106 @@ # - Because you must use a hash, you need to append to this list in a follow-up # CL to the actual reformatting CL that you are trying to ignore. +# objects.h splitting +0604031eb1d01c52b6c1c9ae3012d80b23d74a68 +09e405453359000d66cc0faaa102854e626bebeb +766ef168fbcac6bd0728cc2c9bb3ae7cbd74278a +b5a2839b927be04bdb50a236071c11764e4d6400 +c911f91b5b6219e038c0117b05a8375bdf3db0b0 +1bb48bf91ba8c887884a0fbd674c91f64964d8a5 +19da9f24df7b59fec72b9dd8a979ad0ce5639c87 +b090d7e7468236ffce0afdb55bb496bf0073f2ee +f40638d148b7a435522d5b714993908061e3b10d +e8a1c25f6afae9b77921abb70fad49da252eb6f0 +6fa8283d0e031c9585d190f751907ed45bf85de0 +9aa861c4bcfed612039259f93c2cd2b01337e99e +8175648018bd9f70af866f9fa433f1d79644d86b +c7b1ceb801ec7f639a093468d8e6424212cc197c +e39d2cbe1b1baa6513ddce2d73c981e335cc34fb +eda00a5c499b7a83479115eb275a816b8a2ed104 +68deca9b418976ca8b3375e81058a9e0a815357f +0525e17847f39f80e3fd163021a58f68d8fcaf06 +81a3c699d6eef936452ac3d10c7c59a2c1e38c0c +01452bedfca2b5447a7f62bda87edbbb76259a6e +1baf1050113a5418696839c273e05ea5ad1b5c4d +4b39fe3d608916b1cfea015de287511a1623fc7f +c6effdbba9b301244475553538f6eb1b3d9670b9 +71e4c573199466ea4541e3d6b307c9b33d7bb785 +efc92f0d4aa77bb90f5b56606b6f0d0819fba4af +a9db2c74b5bae2345ac52be404748954a3b5050d +0a01b6202226bbe99c0b83acf6c5a80344f5fb6a +a6c44361c8f2dc07b935e3f2bb3e0d3ad4f4a383 +10d8aab1de430695a69e9d75af6ea42c2cdc9d6d +dd3c4fca2f0a2761b8b95cd47fcd62836d714890 +e9c932233980866074025e65051003d1f298516c +2b1f79881c3f0b69bfb9274bda57ea50f7304982 +7f031160d71a3d836667dc98288eaff4c94e6f56 +490fabb4578f8a3c4096fdccff688c17ed5ed00d +d953b2ab726acca0b3abe90ce090a16d7ccc2ae3 +bb514c426b9438cfb1149d219ac4ec2d8d1c8458 +dfb453d713d8a05e76f720a6aae2871eec210276 +b490fd66b873c89fca37b21eab58502b6367a864 +9a71683d9c8ff9470eda6be5b2b11babac7b9863 +37945f731c4d800ef788e3c32f8663773a93450e +b90c98fc29a8d896354de4a22c055f6d98376171 +35f3e9d0e654e84646a0b98f29e4a2786cdca4b1 +260eb5bb9b62ea3d5fa6ad0b0e8c2de75d48bad4 +cc2c11441ce352360acce8638a19f58edf361f7d +7be0159e4b1e0b064e215ae4ced34d649cb2552e +95a7cfe0eaabbcff0f730ed60e1805779f6cfe41 +8f54d18ba4ad10770e9537a2803459feccfe79a3 +f44759d9ff52a3e5563e5f2bb23ee2c08222fcfd +09050c8a967f5f2956305e5d016b304d7bf5e669 +c769745d5856a7eb3a0dbe6af5376c7638944364 +a1547aa914aeedd7862f74124c18d2bbaf432c36 +5f950698c0dc7c36b855961feb929022f74102fb +4aedeb1bd50c12ebcd6cf954c4cbef1205fff5ac +7366d8954cb1bd277d3283241da2fae62b886c48 +bc35251f5e55a65c3a4acf7cba52cee505c86a46 +4fb60b215801db70c694a799e735b64bfead59bb +03762b8488de0e393077e3f40fe7b63e675b3af3 +a8a45d875f0a98b192cf0063ceda12aaf75ddfaf +a48e5ab8804e9e97b5ea577d6f2667bacee92eb2 + # Update of quotations in DEPS file. e50b49a0e38b34e2b28e026f4d1c7e0da0c7bb1a # Rewrite code base to use "." instead of "->" to access Object members. 878ccb33bd3cf0e6dc018ff8d15843f585ac07be +# Splitting src/ into subfolders +632239011db501e76475d82ff6492f37fa8c1edc +f455f86d899716df3b9550950ce172f5b867619a +24a51e1eee4e286165dd0bba6afb4c35e8177a25 +f9a88acbc928f0fc5e9a3acbcd3b4ece52355f3d +dec3298d9cfbe95759774a0e00302a08836b5f3d +a0c3797461810e3159662851e64946e17654236e +b72941e8b0d2843adf768442024d8950da798db1 +4c986c625f19e35c95f3492c662822f4695218b4 +0fa243af7096ee5b748b194476be2e4efecaec59 +786ce26341b7ab11b4d42f1c77202530d5138ad2 +a6eeea35cb7ff0c29b6cfdd1c786f382110241ce +be014256adea1552d4a044ef80616cdab6a7d549 +93d3b7173fec7d010539057cdbd78d497f09fa9b +5bfe84a0dab60289b3470c080908ce83ac2212d4 +a7695520556665ba73ab02c497ab73b162a5fb13 +61523c45a335fe3be76498e0b16bf8e7aec0d058 +bf372a73d8a5f4029fc9f4f69b675ef0cad80ada +8ad6b335376c6275ffb3361c662a1a45c853f4fc +06bf8261cf2c94fc071652652600b5790f719c05 +81a0102fe8586071cc68e9595b26c5c1207ee5b3 +5f28539599f6a6a265e18b8c897cc96ccbeec9c4 +3253767622a784866dc34aeb7b5d0f02ebdff61e +9ac8b20086f95f1158a1901eefe12e25fd0333e4 +3cb560adfe26edb586a0e6e655e5a7c4755cad1a +7bbd0bfe5161d57bcf268716ce4d1ce14d6786e6 +c39cabbcbea26891558b81fd2236c38a7aeada08 +a3187716d31a0ab9d7051adde6be9bd2b2c6fec1 + # Move test/mjsunit/regress-*.js => test/mjsunit/regress/ cb67be1a3842fcf6a0da18aee444e3b7ea789e04 + +# [include] Split out v8.h +d1b27019d3bf86360ea838c317f8505fac6d3a7e +44fe02ced6e4c6b49d627807e3b3fd0edbbeb36e +ec06bb6ce5641cf65e400ec55b7421f87d04b999 diff --git a/deps/v8/.gitignore b/deps/v8/.gitignore index f1bd2f33fe771a..f8f487ba3cf41d 100644 --- a/deps/v8/.gitignore +++ b/deps/v8/.gitignore @@ -28,6 +28,7 @@ .clangd .cpplint-cache .cproject +.DS_Store .gclient_entries .gdb_history .idea @@ -67,6 +68,7 @@ /third_party/jsoncpp/source !/third_party/colorama /third_party/colorama/src +!/third_party/glibc !/third_party/googletest /third_party/googletest/src/* !/third_party/googletest/src/googletest diff --git a/deps/v8/AUTHORS b/deps/v8/AUTHORS index 9696fc61d54d8f..515bb0d6ccaf7e 100644 --- a/deps/v8/AUTHORS +++ b/deps/v8/AUTHORS @@ -44,6 +44,7 @@ CodeWeavers, Inc. <*@codeweavers.com> Alibaba, Inc. <*@alibaba-inc.com> SiFive, Inc. <*@sifive.com> +Aapo Alasuutari Aaron Bieber Aaron O'Mullan Abdulla Kamar @@ -152,6 +153,8 @@ Jiawen Geng Jiaxun Yang Joel Stanley Johan Bergstrƶm +Johan Levin +John Paul Adrian Glaubitz Jonathan Liu Juan Arboleda Julien Brianceau @@ -285,3 +288,5 @@ Zheng Liu Zhongping Wang ęŸ³č£äø€ Yang Xiang +Kotaro Ohsugi +Jing Peiyang diff --git a/deps/v8/BUILD.bazel b/deps/v8/BUILD.bazel index 3be7da8f3bb11f..08247f86115254 100644 --- a/deps/v8/BUILD.bazel +++ b/deps/v8/BUILD.bazel @@ -16,7 +16,8 @@ load( "v8_library", "v8_mksnapshot", "v8_string", - "v8_torque", + "v8_torque_definitions", + "v8_torque_initializers", ) load(":bazel/v8-non-pointer-compression.bzl", "v8_binary_non_pointer_compression") @@ -68,6 +69,7 @@ load(":bazel/v8-non-pointer-compression.bzl", "v8_binary_non_pointer_compression # v8_enable_sandbox # cppgc_enable_caged_heap # cppgc_enable_check_assignments_in_prefinalizers +# cppgc_enable_slim_write_barrier # cppgc_enable_object_names # cppgc_enable_pointer_compression # cppgc_enable_verify_heap @@ -132,6 +134,8 @@ v8_flag(name = "v8_enable_snapshot_code_comments") v8_flag(name = "v8_enable_snapshot_native_code_counters") +v8_flag(name = "v8_enable_static_roots") + v8_flag(name = "v8_enable_trace_maps") v8_flag(name = "v8_enable_v8_checks") @@ -144,6 +148,11 @@ v8_flag(name = "v8_enable_verify_predictable") v8_flag(name = "v8_enable_test_features") +v8_flag( + name = "v8_enable_turbofan", + default = True, +) + v8_flag( name = "v8_enable_webassembly", default = True, @@ -316,7 +325,9 @@ v8_config( "v8_enable_slow_dchecks": "ENABLE_SLOW_DCHECKS", "v8_enable_runtime_call_stats": "V8_RUNTIME_CALL_STATS", "v8_enable_snapshot_native_code_counters": "V8_SNAPSHOT_NATIVE_CODE_COUNTERS", + "v8_enable_static_roots": "V8_STATIC_ROOTS", "v8_enable_trace_maps": "V8_TRACE_MAPS", + "v8_enable_turbofan": "V8_ENABLE_TURBOFAN", "v8_enable_v8_checks": "V8_ENABLE_CHECKS", "v8_enable_verify_csa": "ENABLE_VERIFY_CSA", "v8_enable_verify_heap": "VERIFY_HEAP", @@ -325,7 +336,6 @@ v8_config( }, defines = [ "GOOGLE3", - "ENABLE_DEBUGGER_SUPPORT", "V8_ADVANCED_BIGINT_ALGORITHMS", "V8_CONCURRENT_MARKING", ] + select({ @@ -706,7 +716,6 @@ filegroup( "@v8//bazel/config:is_macos": [ "src/base/debug/stack_trace_posix.cc", "src/base/platform/platform-darwin.cc", - "src/base/platform/platform-macos.cc", ], "@v8//bazel/config:is_windows": [ "src/base/win32-headers.h", @@ -816,6 +825,7 @@ filegroup( "src/builtins/internal-coverage.tq", "src/builtins/internal.tq", "src/builtins/iterator.tq", + "src/builtins/iterator-helpers.tq", "src/builtins/math.tq", "src/builtins/number.tq", "src/builtins/object-fromentries.tq", @@ -859,6 +869,7 @@ filegroup( "src/builtins/string-html.tq", "src/builtins/string-includes.tq", "src/builtins/string-indexof.tq", + "src/builtins/string-iswellformed.tq", "src/builtins/string-iterator.tq", "src/builtins/string-match-search.tq", "src/builtins/string-pad.tq", @@ -868,6 +879,7 @@ filegroup( "src/builtins/string-startswith.tq", "src/builtins/string-substr.tq", "src/builtins/string-substring.tq", + "src/builtins/string-towellformed.tq", "src/builtins/string-trim.tq", "src/builtins/symbol.tq", "src/builtins/torque-internal.tq", @@ -924,6 +936,7 @@ filegroup( "src/objects/js-collection.tq", "src/objects/js-function.tq", "src/objects/js-generator.tq", + "src/objects/js-iterator-helpers.tq", "src/objects/js-objects.tq", "src/objects/js-promise.tq", "src/objects/js-proxy.tq", @@ -963,6 +976,7 @@ filegroup( "src/objects/templates.tq", "src/objects/torque-defined-classes.tq", "src/objects/turbofan-types.tq", + "src/objects/turboshaft-types.tq", "test/torque/test-torque.tq", "third_party/v8/builtins/array-sort.tq", ] + select({ @@ -1152,7 +1166,6 @@ filegroup( "src/builtins/builtins-utils-inl.h", "src/builtins/builtins-utils.h", "src/builtins/builtins-weak-refs.cc", - "src/builtins/builtins-web-snapshots.cc", "src/builtins/builtins.cc", "src/builtins/builtins.h", "src/builtins/constants-table-builder.cc", @@ -1231,8 +1244,8 @@ filegroup( "src/codegen/tick-counter.h", "src/codegen/tnode.cc", "src/codegen/tnode.h", - "src/codegen/turbo-assembler.cc", - "src/codegen/turbo-assembler.h", + "src/codegen/macro-assembler-base.cc", + "src/codegen/macro-assembler-base.h", "src/codegen/unoptimized-compilation-info.cc", "src/codegen/unoptimized-compilation-info.h", "src/common/assert-scope.cc", @@ -1245,11 +1258,13 @@ filegroup( "src/common/message-template.h", "src/common/operation.h", "src/common/ptr-compr-inl.h", + "src/common/ptr-compr.cc", "src/common/ptr-compr.h", "src/compiler-dispatcher/lazy-compile-dispatcher.cc", "src/compiler-dispatcher/lazy-compile-dispatcher.h", "src/compiler-dispatcher/optimizing-compile-dispatcher.cc", "src/compiler-dispatcher/optimizing-compile-dispatcher.h", + "src/compiler/turbofan.h", "src/date/date.cc", "src/date/date.h", "src/date/dateparser-inl.h", @@ -1429,6 +1444,8 @@ filegroup( "src/heap/cppgc-js/cpp-marking-state-inl.h", "src/heap/cppgc-js/cpp-snapshot.cc", "src/heap/cppgc-js/cpp-snapshot.h", + "src/heap/cppgc-js/cross-heap-remembered-set.cc", + "src/heap/cppgc-js/cross-heap-remembered-set.h", "src/heap/cppgc-js/unified-heap-marking-state.cc", "src/heap/cppgc-js/unified-heap-marking-state.h", "src/heap/cppgc-js/unified-heap-marking-state-inl.h", @@ -1436,9 +1453,8 @@ filegroup( "src/heap/cppgc-js/unified-heap-marking-verifier.h", "src/heap/cppgc-js/unified-heap-marking-visitor.cc", "src/heap/cppgc-js/unified-heap-marking-visitor.h", - "src/heap/embedder-tracing.cc", - "src/heap/embedder-tracing.h", - "src/heap/embedder-tracing-inl.h", + "src/heap/cppgc-js/wrappable-info.h", + "src/heap/cppgc-js/wrappable-info-inl.h", "src/heap/evacuation-verifier.cc", "src/heap/evacuation-verifier.h", "src/heap/evacuation-verifier-inl.h", @@ -1459,8 +1475,6 @@ filegroup( "src/heap/gc-tracer.cc", "src/heap/gc-tracer-inl.h", "src/heap/gc-tracer.h", - "src/heap/global-handle-marking-visitor.cc", - "src/heap/global-handle-marking-visitor.h", "src/heap/heap-allocator-inl.h", "src/heap/heap-allocator.cc", "src/heap/heap-allocator.h", @@ -1567,6 +1581,8 @@ filegroup( "src/heap/stress-scavenge-observer.h", "src/heap/sweeper.cc", "src/heap/sweeper.h", + "src/heap/traced-handles-marking-visitor.cc", + "src/heap/traced-handles-marking-visitor.h", "src/heap/weak-object-worklists.cc", "src/heap/weak-object-worklists.h", "src/ic/call-optimization.cc", @@ -1662,6 +1678,8 @@ filegroup( "src/numbers/conversions.cc", "src/numbers/conversions.h", "src/numbers/hash-seed-inl.h", + "src/numbers/integer-literal-inl.h", + "src/numbers/integer-literal.h", "src/numbers/math-random.cc", "src/numbers/math-random.h", "src/objects/all-objects-inl.h", @@ -1758,6 +1776,8 @@ filegroup( "src/objects/js-function.h", "src/objects/js-generator-inl.h", "src/objects/js-generator.h", + "src/objects/js-iterator-helpers-inl.h", + "src/objects/js-iterator-helpers.h", "src/objects/js-objects-inl.h", "src/objects/js-objects.cc", "src/objects/js-objects.h", @@ -1777,6 +1797,7 @@ filegroup( "src/objects/js-shadow-realm-inl.h", "src/objects/js-shared-array.h", "src/objects/js-shared-array-inl.h", + "src/objects/js-struct.cc", "src/objects/js-struct.h", "src/objects/js-struct-inl.h", "src/objects/js-temporal-objects.h", @@ -1915,6 +1936,8 @@ filegroup( "src/objects/transitions.h", "src/objects/turbofan-types-inl.h", "src/objects/turbofan-types.h", + "src/objects/turboshaft-types-inl.h", + "src/objects/turboshaft-types.h", "src/objects/type-hints.cc", "src/objects/type-hints.h", "src/objects/value-serializer.cc", @@ -2031,6 +2054,7 @@ filegroup( "src/roots/roots-inl.h", "src/roots/roots.cc", "src/roots/roots.h", + "src/roots/static-roots.h", "src/runtime/runtime-array.cc", "src/runtime/runtime-atomics.cc", "src/runtime/runtime-bigint.cc", @@ -2190,8 +2214,6 @@ filegroup( "src/utils/utils.h", "src/utils/version.cc", "src/utils/version.h", - "src/web-snapshot/web-snapshot.h", - "src/web-snapshot/web-snapshot.cc", "src/zone/accounting-allocator.cc", "src/zone/accounting-allocator.h", "src/zone/compressed-zone-ptr.h", @@ -2233,10 +2255,6 @@ filegroup( "src/codegen/ia32/macro-assembler-ia32.h", "src/codegen/ia32/register-ia32.h", "src/codegen/ia32/reglist-ia32.h", - "src/compiler/backend/ia32/code-generator-ia32.cc", - "src/compiler/backend/ia32/instruction-codes-ia32.h", - "src/compiler/backend/ia32/instruction-scheduler-ia32.cc", - "src/compiler/backend/ia32/instruction-selector-ia32.cc", "src/deoptimizer/ia32/deoptimizer-ia32.cc", "src/diagnostics/ia32/disasm-ia32.cc", "src/diagnostics/ia32/unwinder-ia32.cc", @@ -2263,12 +2281,6 @@ filegroup( "src/codegen/x64/macro-assembler-x64.h", "src/codegen/x64/register-x64.h", "src/codegen/x64/reglist-x64.h", - "src/compiler/backend/x64/code-generator-x64.cc", - "src/compiler/backend/x64/instruction-codes-x64.h", - "src/compiler/backend/x64/instruction-scheduler-x64.cc", - "src/compiler/backend/x64/instruction-selector-x64.cc", - "src/compiler/backend/x64/unwinding-info-writer-x64.cc", - "src/compiler/backend/x64/unwinding-info-writer-x64.h", "src/deoptimizer/x64/deoptimizer-x64.cc", "src/diagnostics/x64/disasm-x64.cc", "src/diagnostics/x64/eh-frame-x64.cc", @@ -2293,12 +2305,6 @@ filegroup( "src/codegen/arm/macro-assembler-arm.h", "src/codegen/arm/register-arm.h", "src/codegen/arm/reglist-arm.h", - "src/compiler/backend/arm/code-generator-arm.cc", - "src/compiler/backend/arm/instruction-codes-arm.h", - "src/compiler/backend/arm/instruction-scheduler-arm.cc", - "src/compiler/backend/arm/instruction-selector-arm.cc", - "src/compiler/backend/arm/unwinding-info-writer-arm.cc", - "src/compiler/backend/arm/unwinding-info-writer-arm.h", "src/deoptimizer/arm/deoptimizer-arm.cc", "src/diagnostics/arm/disasm-arm.cc", "src/diagnostics/arm/eh-frame-arm.cc", @@ -2334,12 +2340,6 @@ filegroup( "src/codegen/arm64/reglist-arm64.h", "src/codegen/arm64/utils-arm64.cc", "src/codegen/arm64/utils-arm64.h", - "src/compiler/backend/arm64/code-generator-arm64.cc", - "src/compiler/backend/arm64/instruction-codes-arm64.h", - "src/compiler/backend/arm64/instruction-scheduler-arm64.cc", - "src/compiler/backend/arm64/instruction-selector-arm64.cc", - "src/compiler/backend/arm64/unwinding-info-writer-arm64.cc", - "src/compiler/backend/arm64/unwinding-info-writer-arm64.h", "src/deoptimizer/arm64/deoptimizer-arm64.cc", "src/diagnostics/arm64/disasm-arm64.cc", "src/diagnostics/arm64/disasm-arm64.h", @@ -2369,12 +2369,6 @@ filegroup( "src/codegen/s390/macro-assembler-s390.h", "src/codegen/s390/register-s390.h", "src/codegen/s390/reglist-s390.h", - "src/compiler/backend/s390/code-generator-s390.cc", - "src/compiler/backend/s390/instruction-codes-s390.h", - "src/compiler/backend/s390/instruction-scheduler-s390.cc", - "src/compiler/backend/s390/instruction-selector-s390.cc", - "src/compiler/backend/s390/unwinding-info-writer-s390.cc", - "src/compiler/backend/s390/unwinding-info-writer-s390.h", "src/deoptimizer/s390/deoptimizer-s390.cc", "src/diagnostics/s390/disasm-s390.cc", "src/diagnostics/s390/eh-frame-s390.cc", @@ -2401,10 +2395,6 @@ filegroup( "src/codegen/riscv64/macro-assembler-riscv64.h", "src/codegen/riscv64/register-riscv64.h", "src/codegen/riscv64/reglist-riscv64.h", - "src/compiler/backend/riscv64/code-generator-riscv64.cc", - "src/compiler/backend/riscv64/instruction-codes-riscv64.h", - "src/compiler/backend/riscv64/instruction-scheduler-riscv64.cc", - "src/compiler/backend/riscv64/instruction-selector-riscv64.cc", "src/deoptimizer/riscv64/deoptimizer-riscv64.cc", "src/diagnostics/riscv64/disasm-riscv64.cc", "src/diagnostics/riscv64/unwinder-riscv64.cc", @@ -2430,12 +2420,6 @@ filegroup( "src/codegen/ppc/macro-assembler-ppc.h", "src/codegen/ppc/register-ppc.h", "src/codegen/ppc/reglist-ppc.h", - "src/compiler/backend/ppc/code-generator-ppc.cc", - "src/compiler/backend/ppc/instruction-codes-ppc.h", - "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", - "src/compiler/backend/ppc/unwinding-info-writer-ppc.h", "src/deoptimizer/ppc/deoptimizer-ppc.cc", "src/diagnostics/ppc/disasm-ppc.cc", "src/diagnostics/ppc/eh-frame-ppc.cc", @@ -2607,7 +2591,6 @@ filegroup( name = "icu/v8_base_without_compiler_files", srcs = [ "src/builtins/builtins-intl.cc", - "src/builtins/builtins-intl-gen.cc", "src/objects/intl-objects.cc", "src/objects/intl-objects.h", "src/objects/js-break-iterator.cc", @@ -2882,18 +2865,32 @@ filegroup( "src/compiler/state-values-utils.h", "src/compiler/store-store-elimination.cc", "src/compiler/store-store-elimination.h", + "src/compiler/turbofan-enabled.cc", + "src/compiler/turbofan.h", + "src/compiler/turboshaft/assembler.cc", "src/compiler/turboshaft/assembler.h", + "src/compiler/turboshaft/assert-types-reducer.h", + "src/compiler/turboshaft/branch-elimination-reducer.h", + "src/compiler/turboshaft/dead-code-elimination-reducer.h", "src/compiler/turboshaft/decompression-optimization.cc", "src/compiler/turboshaft/decompression-optimization.h", + "src/compiler/turboshaft/define-assembler-macros.inc", "src/compiler/turboshaft/deopt-data.h", "src/compiler/turboshaft/fast-hash.h", "src/compiler/turboshaft/graph-builder.cc", "src/compiler/turboshaft/graph-builder.h", "src/compiler/turboshaft/graph.cc", "src/compiler/turboshaft/graph.h", + "src/compiler/turboshaft/index.h", "src/compiler/turboshaft/graph-visualizer.cc", "src/compiler/turboshaft/graph-visualizer.h", + "src/compiler/turboshaft/late-escape-analysis-reducer.h", + "src/compiler/turboshaft/late-escape-analysis-reducer.cc", + "src/compiler/turboshaft/layered-hash-map.h", + "src/compiler/turboshaft/machine-lowering-reducer.h", "src/compiler/turboshaft/machine-optimization-reducer.h", + "src/compiler/turboshaft/memory-optimization.cc", + "src/compiler/turboshaft/memory-optimization.h", "src/compiler/turboshaft/operations.cc", "src/compiler/turboshaft/operations.h", "src/compiler/turboshaft/operation-matching.h", @@ -2901,6 +2898,7 @@ filegroup( "src/compiler/turboshaft/optimization-phase.h", "src/compiler/turboshaft/recreate-schedule.cc", "src/compiler/turboshaft/recreate-schedule.h", + "src/compiler/turboshaft/reducer-traits.h", "src/compiler/turboshaft/representations.cc", "src/compiler/turboshaft/representations.h", "src/compiler/turboshaft/select-lowering-reducer.h", @@ -2908,9 +2906,22 @@ filegroup( "src/compiler/turboshaft/simplify-tf-loops.cc", "src/compiler/turboshaft/simplify-tf-loops.h", "src/compiler/turboshaft/snapshot-table.h", + "src/compiler/turboshaft/tag-untag-lowering-reducer.h", + "src/compiler/turboshaft/type-inference-analysis.h", + "src/compiler/turboshaft/type-inference-reducer.h", + "src/compiler/turboshaft/typer.cc", + "src/compiler/turboshaft/typer.h", + "src/compiler/turboshaft/type-parser.cc", + "src/compiler/turboshaft/type-parser.h", + "src/compiler/turboshaft/typed-optimizations-reducer.h", + "src/compiler/turboshaft/types.cc", + "src/compiler/turboshaft/types.h", + "src/compiler/turboshaft/undef-assembler-macros.inc", + "src/compiler/turboshaft/uniform-reducer-adapter.h", "src/compiler/turboshaft/utils.cc", "src/compiler/turboshaft/utils.h", "src/compiler/turboshaft/value-numbering-reducer.h", + "src/compiler/turboshaft/variable-reducer.h", "src/compiler/type-cache.cc", "src/compiler/type-cache.h", "src/compiler/type-narrowing-reducer.cc", @@ -2930,14 +2941,71 @@ filegroup( "src/compiler/zone-stats.cc", "src/compiler/zone-stats.h", ] + select({ + "@v8//bazel/config:v8_target_ia32": [ + "src/compiler/backend/ia32/code-generator-ia32.cc", + "src/compiler/backend/ia32/instruction-codes-ia32.h", + "src/compiler/backend/ia32/instruction-scheduler-ia32.cc", + "src/compiler/backend/ia32/instruction-selector-ia32.cc", + ], + "@v8//bazel/config:v8_target_x64": [ + "src/compiler/backend/x64/code-generator-x64.cc", + "src/compiler/backend/x64/instruction-codes-x64.h", + "src/compiler/backend/x64/instruction-scheduler-x64.cc", + "src/compiler/backend/x64/instruction-selector-x64.cc", + "src/compiler/backend/x64/unwinding-info-writer-x64.cc", + "src/compiler/backend/x64/unwinding-info-writer-x64.h", + ], + "@v8//bazel/config:v8_target_arm": [ + "src/compiler/backend/arm/code-generator-arm.cc", + "src/compiler/backend/arm/instruction-codes-arm.h", + "src/compiler/backend/arm/instruction-scheduler-arm.cc", + "src/compiler/backend/arm/instruction-selector-arm.cc", + "src/compiler/backend/arm/unwinding-info-writer-arm.cc", + "src/compiler/backend/arm/unwinding-info-writer-arm.h", + ], + "@v8//bazel/config:v8_target_arm64": [ + "src/compiler/backend/arm64/code-generator-arm64.cc", + "src/compiler/backend/arm64/instruction-codes-arm64.h", + "src/compiler/backend/arm64/instruction-scheduler-arm64.cc", + "src/compiler/backend/arm64/instruction-selector-arm64.cc", + "src/compiler/backend/arm64/unwinding-info-writer-arm64.cc", + "src/compiler/backend/arm64/unwinding-info-writer-arm64.h", + ], + "@v8//bazel/config:v8_target_s390x": [ + "src/compiler/backend/s390/code-generator-s390.cc", + "src/compiler/backend/s390/instruction-codes-s390.h", + "src/compiler/backend/s390/instruction-scheduler-s390.cc", + "src/compiler/backend/s390/instruction-selector-s390.cc", + "src/compiler/backend/s390/unwinding-info-writer-s390.cc", + "src/compiler/backend/s390/unwinding-info-writer-s390.h", + ], + "@v8//bazel/config:v8_target_riscv64": [ + "src/compiler/backend/riscv64/code-generator-riscv64.cc", + "src/compiler/backend/riscv64/instruction-codes-riscv64.h", + "src/compiler/backend/riscv64/instruction-scheduler-riscv64.cc", + "src/compiler/backend/riscv64/instruction-selector-riscv64.cc", + ], + "@v8//bazel/config:v8_target_ppc64le": [ + "src/compiler/backend/ppc/code-generator-ppc.cc", + "src/compiler/backend/ppc/instruction-codes-ppc.h", + "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", + "src/compiler/backend/ppc/unwinding-info-writer-ppc.h", + ], + }) + select({ ":is_v8_enable_webassembly": [ "src/compiler/int64-lowering.cc", "src/compiler/int64-lowering.h", + "src/compiler/wasm-call-descriptors.cc", + "src/compiler/wasm-call-descriptors.h", "src/compiler/wasm-compiler-definitions.h", "src/compiler/wasm-compiler.cc", "src/compiler/wasm-compiler.h", "src/compiler/wasm-escape-analysis.cc", "src/compiler/wasm-escape-analysis.h", + "src/compiler/wasm-load-elimination.cc", + "src/compiler/wasm-load-elimination.h", "src/compiler/wasm-loop-peeling.cc", "src/compiler/wasm-loop-peeling.h", "src/compiler/wasm-gc-lowering.cc", @@ -2956,7 +3024,7 @@ filegroup( ) filegroup( - name = "v8_initializers_files", + name = "noicu/v8_initializers_files", srcs = [ "src/builtins/builtins-array-gen.cc", "src/builtins/builtins-array-gen.h", @@ -2990,6 +3058,7 @@ filegroup( "src/builtins/builtins-microtask-queue-gen.cc", "src/builtins/builtins-number-gen.cc", "src/builtins/builtins-object-gen.cc", + "src/builtins/builtins-object-gen.h", "src/builtins/builtins-promise-gen.cc", "src/builtins/builtins-promise-gen.h", "src/builtins/builtins-proxy-gen.cc", @@ -3046,6 +3115,14 @@ filegroup( }), ) +filegroup( + name = "icu/v8_initializers_files", + srcs = [ + "src/builtins/builtins-intl-gen.cc", + ":noicu/v8_initializers_files", + ], +) + filegroup( name = "cppgc_base_files", srcs = [ @@ -3160,16 +3237,16 @@ filegroup( # Note these cannot be v8_target_is_* selects because these contain # inline assembly that runs inside the executable. Since these are # linked directly into mksnapshot, they must use the actual target cpu. - "@v8//bazel/config:is_inline_asm_ia32": ["src/heap/base/asm/ia32/save_registers_asm.cc"], - "@v8//bazel/config:is_inline_asm_x64": ["src/heap/base/asm/x64/save_registers_asm.cc"], - "@v8//bazel/config:is_inline_asm_arm": ["src/heap/base/asm/arm/save_registers_asm.cc"], - "@v8//bazel/config:is_inline_asm_arm64": ["src/heap/base/asm/arm64/save_registers_asm.cc"], - "@v8//bazel/config:is_inline_asm_s390x": ["src/heap/base/asm/s390/save_registers_asm.cc"], - "@v8//bazel/config:is_inline_asm_riscv64": ["src/heap/base/asm/riscv64/save_registers_asm.cc"], - "@v8//bazel/config:is_inline_asm_ppc64le": ["src/heap/base/asm/ppc/save_registers_asm.cc"], - "@v8//bazel/config:is_msvc_asm_ia32": ["src/heap/base/asm/ia32/save_registers_masm.asm"], - "@v8//bazel/config:is_msvc_asm_x64": ["src/heap/base/asm/x64/save_registers_masm.asm"], - "@v8//bazel/config:is_msvc_asm_arm64": ["src/heap/base/asm/arm64/save_registers_masm.S"], + "@v8//bazel/config:is_inline_asm_ia32": ["src/heap/base/asm/ia32/push_registers_asm.cc"], + "@v8//bazel/config:is_inline_asm_x64": ["src/heap/base/asm/x64/push_registers_asm.cc"], + "@v8//bazel/config:is_inline_asm_arm": ["src/heap/base/asm/arm/push_registers_asm.cc"], + "@v8//bazel/config:is_inline_asm_arm64": ["src/heap/base/asm/arm64/push_registers_asm.cc"], + "@v8//bazel/config:is_inline_asm_s390x": ["src/heap/base/asm/s390/push_registers_asm.cc"], + "@v8//bazel/config:is_inline_asm_riscv64": ["src/heap/base/asm/riscv64/push_registers_asm.cc"], + "@v8//bazel/config:is_inline_asm_ppc64le": ["src/heap/base/asm/ppc/push_registers_asm.cc"], + "@v8//bazel/config:is_msvc_asm_ia32": ["src/heap/base/asm/ia32/push_registers_masm.asm"], + "@v8//bazel/config:is_msvc_asm_x64": ["src/heap/base/asm/x64/push_registers_masm.asm"], + "@v8//bazel/config:is_msvc_asm_arm64": ["src/heap/base/asm/arm64/push_registers_masm.S"], }), ) @@ -3215,6 +3292,8 @@ filegroup( "src/snapshot/embedded/platform-embedded-file-writer-mac.h", "src/snapshot/embedded/platform-embedded-file-writer-win.cc", "src/snapshot/embedded/platform-embedded-file-writer-win.h", + "src/snapshot/static-roots-gen.cc", + "src/snapshot/static-roots-gen.h", "src/snapshot/mksnapshot.cc", "src/snapshot/snapshot-empty.cc", ], @@ -3223,6 +3302,8 @@ filegroup( filegroup( name = "v8_inspector_files", srcs = [ + "src/inspector/crc32.cc", + "src/inspector/crc32.h", "src/inspector/custom-preview.cc", "src/inspector/custom-preview.h", "src/inspector/injected-script.cc", @@ -3249,6 +3330,8 @@ filegroup( "src/inspector/v8-debugger.h", "src/inspector/v8-debugger-agent-impl.cc", "src/inspector/v8-debugger-agent-impl.h", + "src/inspector/v8-debugger-barrier.cc", + "src/inspector/v8-debugger-barrier.h", "src/inspector/v8-debugger-id.cc", "src/inspector/v8-debugger-id.h", "src/inspector/v8-debugger-script.cc", @@ -3374,8 +3457,8 @@ filegroup( # TODO(victorgomes): Add support to tools/debug_helper, # which needs class-debug-readers and debug-macros. -v8_torque( - name = "generated_torque_files", +v8_torque_definitions( + name = "generated_torque_definitions", args = select({ ":is_v8_annotate_torque_ir": ["-annotate-ir"], "//conditions:default": [], @@ -3391,12 +3474,8 @@ v8_torque( "class-forward-declarations.h", "class-verifiers.cc", "class-verifiers.h", - "csa-types.h", # "debug-macros.cc", # "debug-macros.h", - "enum-verifiers.cc", - "exported-macros-assembler.cc", - "exported-macros-assembler.h", "factory.cc", "factory.inc", "instance-types.h", @@ -3409,8 +3488,28 @@ v8_torque( noicu_srcs = [":noicu/torque_files"], ) +v8_torque_initializers( + name = "generated_torque_initializers", + args = select({ + ":is_v8_annotate_torque_ir": ["-annotate-ir"], + "//conditions:default": [], + }) + select({ + "@v8//bazel/config:v8_target_is_32_bits": ["-m32"], + "//conditions:default": [], + }), + extras = [ + "csa-types.h", + "enum-verifiers.cc", + "exported-macros-assembler.cc", + "exported-macros-assembler.h", + ], + icu_srcs = [":icu/torque_files"], + noicu_srcs = [":noicu/torque_files"], +) + py_binary( name = "code_generator", + python_version = "PY3", srcs = [ "third_party/inspector_protocol/code_generator.py", "third_party/inspector_protocol/pdl.py", @@ -3476,8 +3575,6 @@ filegroup( name = "v8_common_libshared_files", srcs = [ ":torque_runtime_support_files", - ":v8_compiler_files", - ":v8_initializers_files", ":v8_libplatform_files", ":v8_libsampler_files", ":v8_shared_internal_headers", @@ -3547,14 +3644,16 @@ v8_mksnapshot( # NOTE: This allow headers to be accessed without the icu/noicu prefixes. cc_library( - name = "icu/generated_torque_headers", - hdrs = [":icu/generated_torque_files"], + name = "icu/generated_torque_definitions_headers", + hdrs = [":icu/generated_torque_definitions"], + copts = ["-Wno-implicit-fallthrough"], strip_include_prefix = "icu", ) cc_library( - name = "noicu/generated_torque_headers", - hdrs = [":noicu/generated_torque_files"], + name = "noicu/generated_torque_definitions_headers", + hdrs = [":noicu/generated_torque_definitions"], + copts = ["-Wno-implicit-fallthrough"], strip_include_prefix = "noicu", ) @@ -3564,6 +3663,7 @@ v8_library( ":v8_libbase_files", ":v8_shared_internal_headers", ], + copts = ["-Wno-implicit-fallthrough"], ) cc_library( @@ -3572,6 +3672,7 @@ cc_library( "src/torque/kythe-data.h", "src/torque/torque-compiler.h", ], + copts = ["-Wno-implicit-fallthrough"], include_prefix = "third_party/v8", includes = ["."], ) @@ -3581,7 +3682,7 @@ cc_library( srcs = [ ":torque_base_files", ], - copts = select({ + copts = ["-Wno-implicit-fallthrough"] + select({ "@v8//bazel/config:is_posix": ["-fexceptions"], "//conditions:default": [], }), @@ -3597,21 +3698,27 @@ v8_library( srcs = [ ":v8_base_without_compiler_files", ":v8_common_libshared_files", - ], + ] + select({ + ":is_v8_enable_turbofan": [ + ":v8_compiler_files", + ], + "//conditions:default": [], + }), + copts = ["-Wno-implicit-fallthrough"], icu_deps = [ - ":icu/generated_torque_headers", + ":icu/generated_torque_definitions_headers", "//external:icu", ], icu_srcs = [ ":generated_regexp_special_case", - ":icu/generated_torque_files", + ":icu/generated_torque_definitions", ":icu/v8_base_without_compiler_files", ], noicu_deps = [ - ":noicu/generated_torque_headers", + ":noicu/generated_torque_definitions_headers", ], noicu_srcs = [ - ":noicu/generated_torque_files", + ":noicu/generated_torque_definitions", ], deps = [ ":v8_libbase", @@ -3621,8 +3728,17 @@ v8_library( v8_library( name = "v8", - srcs = [":v8_inspector_files"], + srcs = [ + ":v8_inspector_files", + ] + select({ + ":is_not_v8_enable_turbofan": [ + # With Turbofan disabled, we only include the stubbed-out API. + "src/compiler/turbofan-disabled.cc", + ], + "//conditions:default": [], + }), hdrs = [":public_header_files"], + copts = ["-Wno-implicit-fallthrough"], icu_deps = [":icu/v8_libshared"], icu_srcs = [":icu/snapshot_files"], noicu_deps = [":noicu/v8_libshared"], @@ -3635,6 +3751,7 @@ v8_library( name = "wee8", srcs = [":wee8_files"], hdrs = [":public_wasm_c_api_header_files"], + copts = ["-Wno-implicit-fallthrough"], strip_include_prefix = "third_party", visibility = ["//visibility:public"], deps = [":noicu/v8"], @@ -3664,6 +3781,7 @@ v8_binary( "src/interpreter/bytecodes.cc", "src/interpreter/bytecodes.h", ], + copts = ["-Wno-implicit-fallthrough"], deps = ["v8_libbase"], ) @@ -3675,6 +3793,7 @@ v8_binary( ":v8_libbase_files", ":v8_shared_internal_headers", ], + copts = ["-Wno-implicit-fallthrough"], defines = [ "V8_INTL_SUPPORT", "ICU_UTIL_DATA_IMPL=ICU_UTIL_DATA_STATIC", @@ -3693,7 +3812,7 @@ v8_binary( "src/torque/torque.cc", ":torque_base_files", ], - copts = select({ + copts = ["-Wno-implicit-fallthrough"] + select({ "@v8//bazel/config:is_posix": ["-fexceptions"], "//conditions:default": [], }), @@ -3707,18 +3826,36 @@ v8_binary( v8_binary( name = "mksnapshot", - srcs = [":mksnapshot_files"], + srcs = [ + ":mksnapshot_files", + ] + select({ + ":is_not_v8_enable_turbofan": [ + # Turbofan is needed to generate builtins. + ":v8_compiler_files", + ], + "//conditions:default": [], + }), + copts = ["-Wno-implicit-fallthrough"], icu_deps = [":icu/v8_libshared"], linkopts = select({ "@v8//bazel/config:is_android": ["-llog"], "//conditions:default": [], }), + icu_srcs = [ + ":icu/generated_torque_initializers", + ":icu/v8_initializers_files", + ], noicu_deps = [":v8_libshared_noicu"], + noicu_srcs = [ + ":noicu/generated_torque_initializers", + ":noicu/v8_initializers_files", + ], ) v8_binary( name = "d8", srcs = [":d8_files"], + copts = ["-Wno-implicit-fallthrough"], icu_deps = [":icu/v8"], noicu_deps = [":noicu/v8"], ) diff --git a/deps/v8/BUILD.gn b/deps/v8/BUILD.gn index 78fd8cd2d38790..277f47717da3dd 100644 --- a/deps/v8/BUILD.gn +++ b/deps/v8/BUILD.gn @@ -10,10 +10,6 @@ import("//build/config/mips.gni") import("//build/config/sanitizers/sanitizers.gni") import("//build_overrides/build.gni") -if (is_android) { - import("//build/config/android/rules.gni") -} - import("gni/snapshot_toolchain.gni") import("gni/v8.gni") @@ -120,6 +116,9 @@ declare_args() { # as per the --native-code-counters flag. v8_enable_snapshot_native_code_counters = "" + # Use pre-generated static root pointer values from static-roots.h. + v8_enable_static_roots = "" + # Enable code-generation-time checking of types in the CodeStubAssembler. v8_enable_verify_csa = false @@ -204,10 +203,6 @@ declare_args() { # Sets -dV8_EXTERNAL_CODE_SPACE v8_enable_external_code_space = "" - # Enable the Maglev compiler. - # Sets -dV8_ENABLE_MAGLEV - v8_enable_maglev = "" - # With post mortem support enabled, metadata is embedded into libv8 that # describes various parameters of the VM for use by debuggers. See # tools/gen-postmortem-metadata.py for details. @@ -310,9 +305,6 @@ declare_args() { # Sets -DV8_ENABLE_SANDBOX. v8_enable_sandbox = "" - # Enable all available sandbox features. Implies v8_enable_sandbox. - v8_enable_sandbox_future = false - # Expose the memory corruption API to JavaScript. Useful for testing the sandbox. # WARNING This will expose builtins that (by design) cause memory corruption. # Sets -DV8_EXPOSE_MEMORY_CORRUPTION_API @@ -376,6 +368,9 @@ declare_args() { # Compile V8 using zlib as dependency. # Sets -DV8_USE_ZLIB v8_use_zlib = true + + # Make ValueDeserializer crash if the data to deserialize is invalid. + v8_value_deserializer_hard_fail = false } # Derived defaults. @@ -459,17 +454,35 @@ if (v8_enable_external_code_space == "") { (target_os != "fuchsia" && v8_current_cpu == "arm64")) } if (v8_enable_maglev == "") { - v8_enable_maglev = v8_current_cpu == "x64" && v8_enable_pointer_compression + v8_enable_maglev = v8_enable_turbofan && + (v8_current_cpu == "x64" || v8_current_cpu == "arm64") && + v8_enable_pointer_compression } +assert(v8_enable_turbofan || !v8_enable_maglev, + "Maglev is not available when Turbofan is disabled.") + if (v8_builtins_profiling_log_file == "default") { v8_builtins_profiling_log_file = "" - if (is_debug == false) { - if (v8_current_cpu == "x64") { + + # Don't use existing profile when + # * generating a new one (i.e. v8_enable_builtins_profiling), + # * is_debug or dcheck_always_on because they add more checks to the + # builtins control flow which we don't want to generate, + # * v8_enable_webassembly because it changes the set of opcodes which affects + # graphs hashes, + # * !is_clang because it might affect argument evaluation order, which + # makes node IDs not predictable for subgraphs like Op1(Op2(), Op3()) and + # as a result different graph hash. + if (!v8_enable_builtins_profiling && is_clang && !is_debug && + !dcheck_always_on && v8_enable_webassembly) { + if ((v8_current_cpu == "x64" || v8_current_cpu == "arm64") && + v8_enable_pointer_compression && v8_enable_external_code_space) { + # Note, currently x64 profile can be applied to arm64 but not the other + # way round. v8_builtins_profiling_log_file = "tools/builtins-pgo/x64.profile" - } else if (v8_current_cpu == "arm64") { - v8_builtins_profiling_log_file = "tools/builtins-pgo/arm64.profile" - } else if (v8_current_cpu == "arm") { - v8_builtins_profiling_log_file = "tools/builtins-pgo/arm.profile" + } else if (v8_current_cpu == "x86" || v8_current_cpu == "arm") { + # Note, x86 profile can be applied to arm but not the other way round. + v8_builtins_profiling_log_file = "tools/builtins-pgo/x86.profile" } } } @@ -500,6 +513,10 @@ assert(!v8_enable_trace_ignition || v8_enable_trace_unoptimized, "Ignition tracing requires unoptimized tracing to be enabled.") assert(!v8_enable_trace_baseline_exec || v8_enable_trace_unoptimized, "Baseline tracing requires unoptimized tracing to be enabled.") +assert( + v8_enable_debugging_features == true || dcheck_always_on || + !v8_enable_slow_dchecks, + "v8_enable_slow_dchecks requires v8_enable_debugging_features or dcheck_always_on.") if (v8_enable_short_builtin_calls && (!v8_enable_pointer_compression && v8_current_cpu != "x64")) { @@ -522,9 +539,30 @@ if (v8_enable_sandbox == "") { v8_enable_external_code_space && target_os != "fuchsia" } -# Enable all available sandbox features if sandbox future is enabled. -if (v8_enable_sandbox_future) { - v8_enable_sandbox = true +if (v8_enable_static_roots == "") { + # Static roots are only valid for builds with pointer compression and a + # shared read-only heap. + # TODO(olivf, v8:13466) Some configurations could be supported if we + # introduce different static root files for different build configurations: + # Non-wasm and non-i18n builds have fewer read only roots. Configurations + # without external code space allocate read only roots at a further + # location relative to the cage base. + v8_enable_static_roots = + v8_enable_pointer_compression && v8_enable_shared_ro_heap && + v8_enable_pointer_compression_shared_cage && + v8_enable_external_code_space && v8_enable_webassembly && + v8_enable_i18n_support +} + +assert(!v8_enable_static_roots || + (v8_enable_pointer_compression && v8_enable_shared_ro_heap && + v8_enable_pointer_compression_shared_cage && + v8_enable_external_code_space && v8_enable_webassembly && + v8_enable_i18n_support), + "Trying to enable static roots in a configuration that is not supported") + +if (v8_enable_webassembly && !target_is_simulator && v8_current_cpu == "x64") { + v8_enable_wasm_simd256_revec = true } assert(!v8_disable_write_barriers || v8_enable_single_generation, @@ -567,8 +605,9 @@ assert( assert( !v8_enable_pointer_compression_shared_cage || v8_current_cpu == "x64" || - v8_current_cpu == "arm64" || v8_current_cpu == "riscv64", - "Sharing a pointer compression cage is only supported on x64,arm64 and riscv64") + v8_current_cpu == "arm64" || v8_current_cpu == "riscv64" || + v8_current_cpu == "ppc64", + "Sharing a pointer compression cage is only supported on x64,arm64, ppc64 and riscv64") assert(!v8_enable_unconditional_write_barriers || !v8_disable_write_barriers, "Write barriers can't be both enabled and disabled") @@ -741,6 +780,7 @@ external_v8_defines = [ "V8_USE_PERFETTO", "V8_MAP_PACKING", "V8_IS_TSAN", + "V8_ENABLE_CONSERVATIVE_STACK_SCANNING", ] enabled_external_v8_defines = [] @@ -780,6 +820,9 @@ if (v8_enable_map_packing) { if (is_tsan) { enabled_external_v8_defines += [ "V8_IS_TSAN" ] } +if (v8_enable_conservative_stack_scanning) { + enabled_external_v8_defines += [ "V8_ENABLE_CONSERVATIVE_STACK_SCANNING" ] +} disabled_external_v8_defines = external_v8_defines - enabled_external_v8_defines @@ -800,6 +843,7 @@ config("v8_header_features") { external_cppgc_defines = [ "CPPGC_SUPPORTS_OBJECT_NAMES", "CPPGC_CAGED_HEAP", + "CPPGC_SLIM_WRITE_BARRIER", "CPPGC_YOUNG_GENERATION", "CPPGC_POINTER_COMPRESSION", ] @@ -829,6 +873,9 @@ if (cppgc_enable_pointer_compression) { if (cppgc_enable_2gb_cage) { enabled_external_cppgc_defines += [ "CPPGC_2GB_CAGE" ] } +if (cppgc_enable_slim_write_barrier) { + enabled_external_cppgc_defines += [ "CPPGC_SLIM_WRITE_BARRIER" ] +} disabled_external_cppgc_defines = external_cppgc_defines - enabled_external_cppgc_defines @@ -944,9 +991,6 @@ config("features") { if (v8_enable_single_generation) { defines += [ "V8_ENABLE_SINGLE_GENERATION" ] } - if (v8_enable_conservative_stack_scanning) { - defines += [ "V8_ENABLE_CONSERVATIVE_STACK_SCANNING" ] - } if (v8_enable_inner_pointer_resolution_osb) { defines += [ "V8_ENABLE_INNER_POINTER_RESOLUTION_OSB" ] } @@ -1010,6 +1054,9 @@ config("features") { if (v8_enable_maglev) { defines += [ "V8_ENABLE_MAGLEV" ] } + if (v8_enable_turbofan) { + defines += [ "V8_ENABLE_TURBOFAN" ] + } if (v8_enable_swiss_name_dictionary) { defines += [ "V8_ENABLE_SWISS_NAME_DICTIONARY" ] } @@ -1052,9 +1099,21 @@ config("features") { if (v8_enable_pointer_compression_8gb) { defines += [ "V8_COMPRESS_POINTERS_8GB" ] } + if (v8_enable_static_roots) { + defines += [ "V8_STATIC_ROOTS" ] + } if (v8_use_zlib) { defines += [ "V8_USE_ZLIB" ] } + if (v8_use_libm_trig_functions) { + defines += [ "V8_USE_LIBM_TRIG_FUNCTIONS" ] + } + if (v8_value_deserializer_hard_fail) { + defines += [ "V8_VALUE_DESERIALIZER_HARD_FAIL" ] + } + if (v8_enable_wasm_simd256_revec) { + defines += [ "V8_ENABLE_WASM_SIMD256_REVEC" ] + } } config("toolchain") { @@ -1242,6 +1301,9 @@ config("toolchain") { } else if (target_os == "win") { defines += [ "V8_HAVE_TARGET_OS" ] defines += [ "V8_TARGET_OS_WIN" ] + } else if (target_os == "chromeos") { + defines += [ "V8_HAVE_TARGET_OS" ] + defines += [ "V8_TARGET_OS_CHROMEOS" ] } # TODO(infra): Support v8_enable_prof on Windows. @@ -1251,13 +1313,12 @@ config("toolchain") { if ((is_linux || is_chromeos) && v8_enable_backtrace) { ldflags += [ "-rdynamic" ] } - + } + if (v8_enable_debugging_features || dcheck_always_on) { defines += [ "DEBUG" ] if (v8_enable_slow_dchecks) { defines += [ "ENABLE_SLOW_DCHECKS" ] } - } else if (dcheck_always_on) { - defines += [ "DEBUG" ] } if (v8_enable_verify_csa) { @@ -1556,108 +1617,95 @@ template("asm_to_inline_asm") { } } -if (is_android && enable_java_templates) { - android_assets("v8_external_startup_data_assets") { - if (v8_use_external_startup_data) { - deps = [ "//v8" ] - renaming_sources = [ "$root_out_dir/snapshot_blob.bin" ] - if (current_cpu == "arm" || current_cpu == "x86") { - renaming_destinations = [ "snapshot_blob_32.bin" ] - } else { - renaming_destinations = [ "snapshot_blob_64.bin" ] - } - disable_compression = true - } - } -} - -action("postmortem-metadata") { - # Only targets in this file and the top-level visibility target can - # depend on this. - visibility = [ - ":*", - "//:gn_visibility", - ] - - script = "tools/gen-postmortem-metadata.py" - - # NOSORT - sources = [ - "$target_gen_dir/torque-generated/instance-types.h", - "src/objects/allocation-site.h", - "src/objects/allocation-site-inl.h", - "src/objects/cell.h", - "src/objects/cell-inl.h", - "src/objects/code.h", - "src/objects/code-inl.h", - "src/objects/data-handler.h", - "src/objects/data-handler-inl.h", - "src/objects/descriptor-array.h", - "src/objects/descriptor-array-inl.h", - "src/objects/feedback-cell.h", - "src/objects/feedback-cell-inl.h", - "src/objects/fixed-array.h", - "src/objects/fixed-array-inl.h", - "src/objects/heap-number.h", - "src/objects/heap-number-inl.h", - "src/objects/heap-object.h", - "src/objects/heap-object-inl.h", - "src/objects/instance-type.h", - "src/objects/js-array-buffer.h", - "src/objects/js-array-buffer-inl.h", - "src/objects/js-array.h", - "src/objects/js-array-inl.h", - "src/objects/js-function-inl.h", - "src/objects/js-function.cc", - "src/objects/js-function.h", - "src/objects/js-objects.cc", - "src/objects/js-objects.h", - "src/objects/js-objects-inl.h", - "src/objects/js-promise.h", - "src/objects/js-promise-inl.h", - "src/objects/js-raw-json.cc", - "src/objects/js-raw-json.h", - "src/objects/js-raw-json-inl.h", - "src/objects/js-regexp.cc", - "src/objects/js-regexp.h", - "src/objects/js-regexp-inl.h", - "src/objects/js-regexp-string-iterator.h", - "src/objects/js-regexp-string-iterator-inl.h", - "src/objects/map.cc", - "src/objects/map.h", - "src/objects/map-inl.h", - "src/objects/megadom-handler.h", - "src/objects/megadom-handler-inl.h", - "src/objects/name.h", - "src/objects/name-inl.h", - "src/objects/objects.h", - "src/objects/objects-inl.h", - "src/objects/oddball.h", - "src/objects/oddball-inl.h", - "src/objects/primitive-heap-object.h", - "src/objects/primitive-heap-object-inl.h", - "src/objects/scope-info.h", - "src/objects/scope-info-inl.h", - "src/objects/script.h", - "src/objects/script-inl.h", - "src/objects/shared-function-info.cc", - "src/objects/shared-function-info.h", - "src/objects/shared-function-info-inl.h", - "src/objects/string.cc", - "src/objects/string-comparator.cc", - "src/objects/string-comparator.h", - "src/objects/string.h", - "src/objects/string-inl.h", - "src/objects/struct.h", - "src/objects/struct-inl.h", - ] - - outputs = [ "$target_gen_dir/debug-support.cc" ] +if (v8_postmortem_support) { + action("postmortem-metadata") { + # Only targets in this file and the top-level visibility target can + # depend on this. + visibility = [ + ":*", + "//:gn_visibility", + ] - args = rebase_path(outputs, root_build_dir) + - rebase_path(sources, root_build_dir) + script = "tools/gen-postmortem-metadata.py" - deps = [ ":run_torque" ] + # NOSORT + sources = [ + "$target_gen_dir/torque-generated/instance-types.h", + "src/objects/allocation-site.h", + "src/objects/allocation-site-inl.h", + "src/objects/cell.h", + "src/objects/cell-inl.h", + "src/objects/code.h", + "src/objects/code-inl.h", + "src/objects/data-handler.h", + "src/objects/data-handler-inl.h", + "src/objects/descriptor-array.h", + "src/objects/descriptor-array-inl.h", + "src/objects/feedback-cell.h", + "src/objects/feedback-cell-inl.h", + "src/objects/fixed-array.h", + "src/objects/fixed-array-inl.h", + "src/objects/heap-number.h", + "src/objects/heap-number-inl.h", + "src/objects/heap-object.h", + "src/objects/heap-object-inl.h", + "src/objects/instance-type.h", + "src/objects/js-array-buffer.h", + "src/objects/js-array-buffer-inl.h", + "src/objects/js-array.h", + "src/objects/js-array-inl.h", + "src/objects/js-function-inl.h", + "src/objects/js-function.cc", + "src/objects/js-function.h", + "src/objects/js-objects.cc", + "src/objects/js-objects.h", + "src/objects/js-objects-inl.h", + "src/objects/js-promise.h", + "src/objects/js-promise-inl.h", + "src/objects/js-raw-json.cc", + "src/objects/js-raw-json.h", + "src/objects/js-raw-json-inl.h", + "src/objects/js-regexp.cc", + "src/objects/js-regexp.h", + "src/objects/js-regexp-inl.h", + "src/objects/js-regexp-string-iterator.h", + "src/objects/js-regexp-string-iterator-inl.h", + "src/objects/map.cc", + "src/objects/map.h", + "src/objects/map-inl.h", + "src/objects/megadom-handler.h", + "src/objects/megadom-handler-inl.h", + "src/objects/name.h", + "src/objects/name-inl.h", + "src/objects/objects.h", + "src/objects/objects-inl.h", + "src/objects/oddball.h", + "src/objects/oddball-inl.h", + "src/objects/primitive-heap-object.h", + "src/objects/primitive-heap-object-inl.h", + "src/objects/scope-info.h", + "src/objects/scope-info-inl.h", + "src/objects/script.h", + "src/objects/script-inl.h", + "src/objects/shared-function-info.cc", + "src/objects/shared-function-info.h", + "src/objects/shared-function-info-inl.h", + "src/objects/string.cc", + "src/objects/string-comparator.cc", + "src/objects/string-comparator.h", + "src/objects/string.h", + "src/objects/string-inl.h", + "src/objects/struct.h", + "src/objects/struct-inl.h", + ] + + outputs = [ "$target_gen_dir/debug-support.cc" ] + + args = rebase_path(outputs, root_build_dir) + + rebase_path(sources, root_build_dir) + + deps = [ ":run_torque" ] + } } torque_files = [ @@ -1713,6 +1761,7 @@ torque_files = [ "src/builtins/internal-coverage.tq", "src/builtins/internal.tq", "src/builtins/iterator.tq", + "src/builtins/iterator-helpers.tq", "src/builtins/math.tq", "src/builtins/number.tq", "src/builtins/object-fromentries.tq", @@ -1756,6 +1805,7 @@ torque_files = [ "src/builtins/string-html.tq", "src/builtins/string-includes.tq", "src/builtins/string-indexof.tq", + "src/builtins/string-iswellformed.tq", "src/builtins/string-iterator.tq", "src/builtins/string-match-search.tq", "src/builtins/string-pad.tq", @@ -1765,6 +1815,7 @@ torque_files = [ "src/builtins/string-startswith.tq", "src/builtins/string-substr.tq", "src/builtins/string-substring.tq", + "src/builtins/string-towellformed.tq", "src/builtins/string-trim.tq", "src/builtins/symbol.tq", "src/builtins/torque-internal.tq", @@ -1821,6 +1872,7 @@ torque_files = [ "src/objects/js-collection.tq", "src/objects/js-function.tq", "src/objects/js-generator.tq", + "src/objects/js-iterator-helpers.tq", "src/objects/js-objects.tq", "src/objects/js-promise.tq", "src/objects/js-proxy.tq", @@ -1860,6 +1912,7 @@ torque_files = [ "src/objects/templates.tq", "src/objects/torque-defined-classes.tq", "src/objects/turbofan-types.tq", + "src/objects/turboshaft-types.tq", "test/torque/test-torque.tq", "third_party/v8/builtins/array-sort.tq", ] @@ -2114,12 +2167,6 @@ template("run_mksnapshot") { suffix = "_$name" } action("run_mksnapshot_" + name) { - # Only targets in this file and running mkgrokdump can depend on this. - visibility = [ - ":*", - "tools/debug_helper:run_mkgrokdump", - ] - deps = [ ":mksnapshot($v8_snapshot_toolchain)" ] script = "tools/run.py" @@ -2159,6 +2206,12 @@ template("run_mksnapshot") { "--turbo-profiling-input", rebase_path(v8_builtins_profiling_log_file, root_build_dir), ] + + # Replace this with --warn-about-builtin-profile-data to see the full + # list of builtins with incompatible profiles. + # TODO(crbug.com/v8/13647): Do not fail for invalid profiles + # args += [ "--abort-on-bad-builtin-profile-data" ] + args += [ "--warn-about-builtin-profile-data" ] } # This is needed to distinguish between generating code for the simulator @@ -2257,6 +2310,7 @@ action("v8_dump_build_config") { script = "tools/testrunner/utils/dump_build_config.py" outputs = [ "$root_out_dir/v8_build_config.json" ] is_gcov_coverage = v8_code_coverage && !is_clang + is_DEBUG_defined = v8_enable_debugging_features || dcheck_always_on is_full_debug = v8_enable_debugging_features && !v8_optimized_debug args = [ rebase_path("$root_out_dir/v8_build_config.json", root_build_dir), @@ -2268,35 +2322,45 @@ action("v8_dump_build_config") { "is_clang=$is_clang", "is_component_build=$is_component_build", "is_debug=$v8_enable_debugging_features", + "is_DEBUG_defined=$is_DEBUG_defined", "is_full_debug=$is_full_debug", "is_gcov_coverage=$is_gcov_coverage", "is_msan=$is_msan", "is_tsan=$is_tsan", "is_ubsan_vptr=$is_ubsan_vptr", "target_cpu=\"$target_cpu\"", + "v8_code_comments=$v8_code_comments", + "v8_control_flow_integrity=$v8_control_flow_integrity", "v8_current_cpu=\"$v8_current_cpu\"", + "v8_dict_property_const_tracking=$v8_dict_property_const_tracking", + "v8_disable_write_barriers=$v8_disable_write_barriers", "v8_enable_atomic_object_field_writes=" + "$v8_enable_atomic_object_field_writes", + "v8_enable_cet_shadow_stack=$v8_enable_cet_shadow_stack", + "v8_enable_concurrent_marking=$v8_enable_concurrent_marking", "v8_enable_conservative_stack_scanning=" + "$v8_enable_conservative_stack_scanning", - "v8_enable_concurrent_marking=$v8_enable_concurrent_marking", - "v8_enable_single_generation=$v8_enable_single_generation", + "v8_enable_debug_code=$v8_enable_debug_code", + "v8_enable_disassembler=$v8_enable_disassembler", + "v8_enable_gdbjit=$v8_enable_gdbjit", "v8_enable_i18n_support=$v8_enable_i18n_support", - "v8_enable_verify_predictable=$v8_enable_verify_predictable", - "v8_enable_verify_csa=$v8_enable_verify_csa", "v8_enable_lite_mode=$v8_enable_lite_mode", - "v8_enable_runtime_call_stats=$v8_enable_runtime_call_stats", + "v8_enable_maglev=$v8_enable_maglev", "v8_enable_pointer_compression=$v8_enable_pointer_compression", "v8_enable_pointer_compression_shared_cage=" + "$v8_enable_pointer_compression_shared_cage", + "v8_enable_runtime_call_stats=$v8_enable_runtime_call_stats", "v8_enable_sandbox=$v8_enable_sandbox", "v8_enable_shared_ro_heap=$v8_enable_shared_ro_heap", + "v8_enable_single_generation=$v8_enable_single_generation", + "v8_enable_slow_dchecks=$v8_enable_slow_dchecks", "v8_enable_third_party_heap=$v8_enable_third_party_heap", + "v8_enable_turbofan=$v8_enable_turbofan", + "v8_enable_verify_csa=$v8_enable_verify_csa", + "v8_enable_verify_heap=$v8_enable_verify_heap", + "v8_enable_verify_predictable=$v8_enable_verify_predictable", "v8_enable_webassembly=$v8_enable_webassembly", - "v8_dict_property_const_tracking=$v8_dict_property_const_tracking", - "v8_control_flow_integrity=$v8_control_flow_integrity", "v8_target_cpu=\"$v8_target_cpu\"", - "v8_enable_cet_shadow_stack=$v8_enable_cet_shadow_stack", ] if (v8_current_cpu == "mips64" || v8_current_cpu == "mips64el") { @@ -2317,6 +2381,7 @@ v8_source_set("v8_snapshot") { deps = [ ":v8_internal_headers", ":v8_libbase", + ":v8_tracing", ] public_deps = [ # This should be public so downstream targets can declare the snapshot @@ -2404,6 +2469,7 @@ v8_source_set("v8_initializers") { "src/builtins/builtins-microtask-queue-gen.cc", "src/builtins/builtins-number-gen.cc", "src/builtins/builtins-object-gen.cc", + "src/builtins/builtins-object-gen.h", "src/builtins/builtins-promise-gen.cc", "src/builtins/builtins-promise-gen.h", "src/builtins/builtins-proxy-gen.cc", @@ -2454,57 +2520,57 @@ v8_source_set("v8_initializers") { if (v8_current_cpu == "x86") { sources += [ - ### gcmole(arch:ia32) ### + ### gcmole(ia32) ### "src/builtins/ia32/builtins-ia32.cc", ] } else if (v8_current_cpu == "x64") { sources += [ - ### gcmole(arch:x64) ### + ### gcmole(x64) ### "src/builtins/x64/builtins-x64.cc", ] } else if (v8_current_cpu == "arm") { sources += [ - ### gcmole(arch:arm) ### + ### gcmole(arm) ### "src/builtins/arm/builtins-arm.cc", ] } else if (v8_current_cpu == "arm64") { sources += [ - ### gcmole(arch:arm64) ### + ### gcmole(arm64) ### "src/builtins/arm64/builtins-arm64.cc", ] } else if (v8_current_cpu == "mips64" || v8_current_cpu == "mips64el") { sources += [ - ### gcmole(arch:mips64el) ### + ### gcmole(mips64el) ### "src/builtins/mips64/builtins-mips64.cc", ] } else if (v8_current_cpu == "loong64") { sources += [ - ### gcmole(arch:loong64) ### + ### gcmole(loong64) ### "src/builtins/loong64/builtins-loong64.cc", ] } else if (v8_current_cpu == "ppc") { sources += [ - ### gcmole(arch:ppc) ### + ### gcmole(ppc) ### "src/builtins/ppc/builtins-ppc.cc", ] } else if (v8_current_cpu == "ppc64") { sources += [ - ### gcmole(arch:ppc64) ### + ### gcmole(ppc64) ### "src/builtins/ppc/builtins-ppc.cc", ] } else if (v8_current_cpu == "s390" || v8_current_cpu == "s390x") { sources += [ - ### gcmole(arch:s390) ### + ### gcmole(s390) ### "src/builtins/s390/builtins-s390.cc", ] } else if (v8_current_cpu == "riscv64") { sources += [ - ### gcmole(arch:riscv64) ### + ### gcmole(riscv64) ### "src/builtins/riscv/builtins-riscv.cc", ] } else if (v8_current_cpu == "riscv32") { sources += [ - ### gcmole(arch:riscv32) ### + ### gcmole(riscv32) ### "src/builtins/riscv/builtins-riscv.cc", ] } @@ -2775,6 +2841,7 @@ v8_header_set("v8_internal_headers") { "src/codegen/interface-descriptors.h", "src/codegen/label.h", "src/codegen/machine-type.h", + "src/codegen/macro-assembler-base.h", "src/codegen/macro-assembler-inl.h", "src/codegen/macro-assembler.h", "src/codegen/maglev-safepoint-table.h", @@ -2795,7 +2862,6 @@ v8_header_set("v8_internal_headers") { "src/codegen/source-position.h", "src/codegen/tick-counter.h", "src/codegen/tnode.h", - "src/codegen/turbo-assembler.h", "src/codegen/unoptimized-compilation-info.h", "src/common/assert-scope.h", "src/common/checks.h", @@ -2928,25 +2994,46 @@ v8_header_set("v8_internal_headers") { "src/compiler/simplified-operator.h", "src/compiler/state-values-utils.h", "src/compiler/store-store-elimination.h", + "src/compiler/turbofan.h", "src/compiler/turboshaft/assembler.h", + "src/compiler/turboshaft/assert-types-reducer.h", + "src/compiler/turboshaft/branch-elimination-reducer.h", + "src/compiler/turboshaft/dead-code-elimination-reducer.h", "src/compiler/turboshaft/decompression-optimization.h", + "src/compiler/turboshaft/define-assembler-macros.inc", "src/compiler/turboshaft/deopt-data.h", "src/compiler/turboshaft/fast-hash.h", "src/compiler/turboshaft/graph-builder.h", "src/compiler/turboshaft/graph-visualizer.h", "src/compiler/turboshaft/graph.h", + "src/compiler/turboshaft/index.h", + "src/compiler/turboshaft/late-escape-analysis-reducer.h", + "src/compiler/turboshaft/layered-hash-map.h", + "src/compiler/turboshaft/machine-lowering-reducer.h", "src/compiler/turboshaft/machine-optimization-reducer.h", + "src/compiler/turboshaft/memory-optimization.h", "src/compiler/turboshaft/operation-matching.h", "src/compiler/turboshaft/operations.h", "src/compiler/turboshaft/optimization-phase.h", "src/compiler/turboshaft/recreate-schedule.h", + "src/compiler/turboshaft/reducer-traits.h", "src/compiler/turboshaft/representations.h", "src/compiler/turboshaft/select-lowering-reducer.h", "src/compiler/turboshaft/sidetable.h", "src/compiler/turboshaft/simplify-tf-loops.h", "src/compiler/turboshaft/snapshot-table.h", + "src/compiler/turboshaft/tag-untag-lowering-reducer.h", + "src/compiler/turboshaft/type-inference-analysis.h", + "src/compiler/turboshaft/type-inference-reducer.h", + "src/compiler/turboshaft/type-parser.h", + "src/compiler/turboshaft/typed-optimizations-reducer.h", + "src/compiler/turboshaft/typer.h", + "src/compiler/turboshaft/types.h", + "src/compiler/turboshaft/undef-assembler.macros.inc", + "src/compiler/turboshaft/uniform-reducer-adapater.h", "src/compiler/turboshaft/utils.h", "src/compiler/turboshaft/value-numbering-reducer.h", + "src/compiler/turboshaft/variable-reducer.h", "src/compiler/type-cache.h", "src/compiler/type-narrowing-reducer.h", "src/compiler/typed-optimization.h", @@ -3057,12 +3144,13 @@ v8_header_set("v8_internal_headers") { "src/heap/cppgc-js/cpp-marking-state-inl.h", "src/heap/cppgc-js/cpp-marking-state.h", "src/heap/cppgc-js/cpp-snapshot.h", + "src/heap/cppgc-js/cross-heap-remembered-set.h", "src/heap/cppgc-js/unified-heap-marking-state-inl.h", "src/heap/cppgc-js/unified-heap-marking-state.h", "src/heap/cppgc-js/unified-heap-marking-verifier.h", "src/heap/cppgc-js/unified-heap-marking-visitor.h", - "src/heap/embedder-tracing-inl.h", - "src/heap/embedder-tracing.h", + "src/heap/cppgc-js/wrappable-info-inl.h", + "src/heap/cppgc-js/wrappable-info.h", "src/heap/evacuation-allocator-inl.h", "src/heap/evacuation-allocator.h", "src/heap/evacuation-verifier-inl.h", @@ -3078,7 +3166,6 @@ v8_header_set("v8_internal_headers") { "src/heap/gc-idle-time-handler.h", "src/heap/gc-tracer-inl.h", "src/heap/gc-tracer.h", - "src/heap/global-handle-marking-visitor.h", "src/heap/heap-allocator-inl.h", "src/heap/heap-allocator.h", "src/heap/heap-controller.h", @@ -3145,6 +3232,7 @@ v8_header_set("v8_internal_headers") { "src/heap/stress-marking-observer.h", "src/heap/stress-scavenge-observer.h", "src/heap/sweeper.h", + "src/heap/traced-handles-marking-visitor.h", "src/heap/weak-object-worklists.h", "src/ic/call-optimization.h", "src/ic/handler-configuration-inl.h", @@ -3281,6 +3369,8 @@ v8_header_set("v8_internal_headers") { "src/objects/js-function.h", "src/objects/js-generator-inl.h", "src/objects/js-generator.h", + "src/objects/js-iterator-helpers-inl.h", + "src/objects/js-iterator-helpers.h", "src/objects/js-objects-inl.h", "src/objects/js-objects.h", "src/objects/js-promise-inl.h", @@ -3406,6 +3496,8 @@ v8_header_set("v8_internal_headers") { "src/objects/transitions.h", "src/objects/turbofan-types-inl.h", "src/objects/turbofan-types.h", + "src/objects/turboshaft-types-inl.h", + "src/objects/turboshaft-types.h", "src/objects/type-hints.h", "src/objects/value-serializer.h", "src/objects/visitors-inl.h", @@ -3473,6 +3565,7 @@ v8_header_set("v8_internal_headers") { "src/regexp/special-case.h", "src/roots/roots-inl.h", "src/roots/roots.h", + "src/roots/static-roots.h", "src/runtime/runtime-utils.h", "src/runtime/runtime.h", "src/sandbox/bounded-size-inl.h", @@ -3592,12 +3685,17 @@ v8_header_set("v8_internal_headers") { "src/maglev/maglev-interpreter-frame-state.h", "src/maglev/maglev-ir-inl.h", "src/maglev/maglev-ir.h", + "src/maglev/maglev-phi-representation-selector.h", "src/maglev/maglev-regalloc-data.h", "src/maglev/maglev-regalloc.h", "src/maglev/maglev-register-frame-array.h", - "src/maglev/maglev-vreg-allocator.h", "src/maglev/maglev.h", ] + if (v8_current_cpu == "arm64") { + sources += [ "src/maglev/arm64/maglev-assembler-arm64-inl.h" ] + } else if (v8_current_cpu == "x64") { + sources += [ "src/maglev/x64/maglev-assembler-x64-inl.h" ] + } } if (v8_enable_webassembly) { @@ -3608,6 +3706,7 @@ v8_header_set("v8_internal_headers") { "src/asmjs/asm-scanner.h", "src/asmjs/asm-types.h", "src/compiler/int64-lowering.h", + "src/compiler/wasm-call-descriptors.h", "src/compiler/wasm-compiler-definitions.h", "src/compiler/wasm-compiler.h", "src/compiler/wasm-escape-analysis.h", @@ -3615,6 +3714,7 @@ v8_header_set("v8_internal_headers") { "src/compiler/wasm-gc-operator-reducer.h", "src/compiler/wasm-graph-assembler.h", "src/compiler/wasm-inlining.h", + "src/compiler/wasm-load-elimination.h", "src/compiler/wasm-loop-peeling.h", "src/compiler/wasm-typer.h", "src/debug/debug-wasm-objects-inl.h", @@ -3684,7 +3784,10 @@ v8_header_set("v8_internal_headers") { } if (v8_enable_wasm_simd256_revec) { - sources += [ "src/compiler/linear-scheduler.h" ] + sources += [ + "src/compiler/linear-scheduler.h", + "src/compiler/revectorizer.h", + ] } if (!v8_enable_third_party_heap) { @@ -3758,7 +3861,8 @@ v8_header_set("v8_internal_headers") { } if (v8_current_cpu == "x86") { - sources += [ ### gcmole(arch:ia32) ### + sources += [ + ### gcmole(ia32) ### "src/baseline/ia32/baseline-assembler-ia32-inl.h", "src/baseline/ia32/baseline-compiler-ia32-inl.h", "src/codegen/ia32/assembler-ia32-inl.h", @@ -3776,7 +3880,8 @@ v8_header_set("v8_internal_headers") { "src/wasm/baseline/ia32/liftoff-assembler-ia32.h", ] } else if (v8_current_cpu == "x64") { - sources += [ ### gcmole(arch:x64) ### + sources += [ + ### gcmole(x64) ### "src/baseline/x64/baseline-assembler-x64-inl.h", "src/baseline/x64/baseline-compiler-x64-inl.h", "src/codegen/shared-ia32-x64/macro-assembler-shared-ia32-x64.h", @@ -3812,7 +3917,8 @@ v8_header_set("v8_internal_headers") { } } } else if (v8_current_cpu == "arm") { - sources += [ ### gcmole(arch:arm) ### + sources += [ + ### gcmole(arm) ### "src/baseline/arm/baseline-assembler-arm-inl.h", "src/baseline/arm/baseline-compiler-arm-inl.h", "src/codegen/arm/assembler-arm-inl.h", @@ -3830,7 +3936,8 @@ v8_header_set("v8_internal_headers") { "src/wasm/baseline/arm/liftoff-assembler-arm.h", ] } else if (v8_current_cpu == "arm64") { - sources += [ ### gcmole(arch:arm64) ### + sources += [ + ### gcmole(arm64) ### "src/baseline/arm64/baseline-assembler-arm64-inl.h", "src/baseline/arm64/baseline-compiler-arm64-inl.h", "src/codegen/arm64/assembler-arm64-inl.h", @@ -3859,7 +3966,7 @@ v8_header_set("v8_internal_headers") { if (v8_enable_webassembly) { # Trap handling is enabled on arm64 Mac and in simulators on x64 on Linux # and Mac. - if ((current_cpu == "arm64" && is_mac) || + if ((current_cpu == "arm64" && (is_mac || is_ios)) || (current_cpu == "x64" && (is_linux || is_chromeos || is_mac))) { sources += [ "src/trap-handler/handler-inside-posix.h" ] } @@ -3872,7 +3979,8 @@ v8_header_set("v8_internal_headers") { sources += [ "src/diagnostics/unwinding-info-win64.h" ] } } else if (v8_current_cpu == "mips64" || v8_current_cpu == "mips64el") { - sources += [ ### gcmole(arch:mips64el) ### + sources += [ + ### gcmole(mips64el) ### "src/baseline/mips64/baseline-assembler-mips64-inl.h", "src/baseline/mips64/baseline-compiler-mips64-inl.h", "src/codegen/mips64/assembler-mips64-inl.h", @@ -3888,7 +3996,8 @@ v8_header_set("v8_internal_headers") { "src/wasm/baseline/mips64/liftoff-assembler-mips64.h", ] } else if (v8_current_cpu == "loong64") { - sources += [ ### gcmole(arch:loong64) ### + sources += [ + ### gcmole(loong64) ### "src/baseline/loong64/baseline-assembler-loong64-inl.h", "src/baseline/loong64/baseline-compiler-loong64-inl.h", "src/codegen/loong64/assembler-loong64-inl.h", @@ -3904,7 +4013,8 @@ v8_header_set("v8_internal_headers") { "src/wasm/baseline/loong64/liftoff-assembler-loong64.h", ] } else if (v8_current_cpu == "ppc") { - sources += [ ### gcmole(arch:ppc) ### + sources += [ + ### gcmole(ppc) ### "src/codegen/ppc/assembler-ppc-inl.h", "src/codegen/ppc/assembler-ppc.h", "src/codegen/ppc/constants-ppc.h", @@ -3920,7 +4030,8 @@ v8_header_set("v8_internal_headers") { "src/wasm/baseline/ppc/liftoff-assembler-ppc.h", ] } else if (v8_current_cpu == "ppc64") { - sources += [ ### gcmole(arch:ppc64) ### + sources += [ + ### gcmole(ppc64) ### "src/baseline/ppc/baseline-assembler-ppc-inl.h", "src/baseline/ppc/baseline-compiler-ppc-inl.h", "src/codegen/ppc/assembler-ppc-inl.h", @@ -3938,7 +4049,8 @@ v8_header_set("v8_internal_headers") { "src/wasm/baseline/ppc/liftoff-assembler-ppc.h", ] } else if (v8_current_cpu == "s390" || v8_current_cpu == "s390x") { - sources += [ ### gcmole(arch:s390) ### + sources += [ + ### gcmole(s390) ### "src/baseline/s390/baseline-assembler-s390-inl.h", "src/baseline/s390/baseline-compiler-s390-inl.h", "src/codegen/s390/assembler-s390-inl.h", @@ -3956,7 +4068,8 @@ v8_header_set("v8_internal_headers") { "src/wasm/baseline/s390/liftoff-assembler-s390.h", ] } else if (v8_current_cpu == "riscv64") { - sources += [ ### gcmole(arch:riscv64) ### + sources += [ + ### gcmole(riscv64) ### "src/baseline/riscv/baseline-assembler-riscv-inl.h", "src/baseline/riscv/baseline-compiler-riscv-inl.h", "src/codegen/riscv/assembler-riscv-inl.h", @@ -3995,7 +4108,8 @@ v8_header_set("v8_internal_headers") { "src/wasm/baseline/riscv64/liftoff-assembler-riscv64.h", ] } else if (v8_current_cpu == "riscv32") { - sources += [ ### gcmole(arch:riscv32) ### + sources += [ + ### gcmole(riscv32) ### "src/baseline/riscv/baseline-assembler-riscv-inl.h", "src/baseline/riscv/baseline-compiler-riscv-inl.h", "src/codegen/riscv/assembler-riscv.h", @@ -4157,6 +4271,7 @@ v8_compiler_sources = [ "src/compiler/simplified-operator.cc", "src/compiler/state-values-utils.cc", "src/compiler/store-store-elimination.cc", + "src/compiler/turbofan-enabled.cc", "src/compiler/type-cache.cc", "src/compiler/type-narrowing-reducer.cc", "src/compiler/typed-optimization.cc", @@ -4165,30 +4280,122 @@ v8_compiler_sources = [ "src/compiler/value-numbering-reducer.cc", "src/compiler/verifier.cc", "src/compiler/zone-stats.cc", - "src/utils/hex-format.cc", - "src/utils/sha-256.cc", ] +if (v8_current_cpu == "x86") { + v8_compiler_sources += [ + ### gcmole(ia32) ### + "src/compiler/backend/ia32/code-generator-ia32.cc", + "src/compiler/backend/ia32/instruction-scheduler-ia32.cc", + "src/compiler/backend/ia32/instruction-selector-ia32.cc", + ] +} else if (v8_current_cpu == "x64") { + v8_compiler_sources += [ + ### gcmole(x64) ### + "src/compiler/backend/x64/code-generator-x64.cc", + "src/compiler/backend/x64/instruction-scheduler-x64.cc", + "src/compiler/backend/x64/instruction-selector-x64.cc", + "src/compiler/backend/x64/unwinding-info-writer-x64.cc", + ] +} else if (v8_current_cpu == "arm") { + v8_compiler_sources += [ + ### gcmole(arm) ### + "src/compiler/backend/arm/code-generator-arm.cc", + "src/compiler/backend/arm/instruction-scheduler-arm.cc", + "src/compiler/backend/arm/instruction-selector-arm.cc", + "src/compiler/backend/arm/unwinding-info-writer-arm.cc", + ] +} else if (v8_current_cpu == "arm64") { + v8_compiler_sources += [ + ### gcmole(arm64) ### + "src/compiler/backend/arm64/code-generator-arm64.cc", + "src/compiler/backend/arm64/instruction-scheduler-arm64.cc", + "src/compiler/backend/arm64/instruction-selector-arm64.cc", + "src/compiler/backend/arm64/unwinding-info-writer-arm64.cc", + ] +} else if (v8_current_cpu == "mips64" || v8_current_cpu == "mips64el") { + v8_compiler_sources += [ + ### gcmole(mips64el) ### + "src/compiler/backend/mips64/code-generator-mips64.cc", + "src/compiler/backend/mips64/instruction-scheduler-mips64.cc", + "src/compiler/backend/mips64/instruction-selector-mips64.cc", + ] +} else if (v8_current_cpu == "loong64") { + v8_compiler_sources += [ + ### gcmole(loong64) ### + "src/compiler/backend/loong64/code-generator-loong64.cc", + "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) ### + "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 == "s390" || v8_current_cpu == "s390x") { + v8_compiler_sources += [ + ### gcmole(s390) ### + "src/compiler/backend/s390/code-generator-s390.cc", + "src/compiler/backend/s390/instruction-scheduler-s390.cc", + "src/compiler/backend/s390/instruction-selector-s390.cc", + "src/compiler/backend/s390/unwinding-info-writer-s390.cc", + ] +} else if (v8_current_cpu == "riscv64") { + v8_compiler_sources += [ + ### gcmole(riscv64) ### + "src/compiler/backend/riscv/code-generator-riscv.cc", + "src/compiler/backend/riscv/instruction-scheduler-riscv.cc", + "src/compiler/backend/riscv/instruction-selector-riscv64.cc", + ] +} else if (v8_current_cpu == "riscv32") { + v8_compiler_sources += [ + ### gcmole(riscv32) ### + "src/compiler/backend/riscv/code-generator-riscv.cc", + "src/compiler/backend/riscv/instruction-scheduler-riscv.cc", + "src/compiler/backend/riscv/instruction-selector-riscv32.cc", + ] +} + if (v8_enable_webassembly) { v8_compiler_sources += [ "src/compiler/int64-lowering.cc", + "src/compiler/wasm-call-descriptors.cc", "src/compiler/wasm-compiler.cc", "src/compiler/wasm-escape-analysis.cc", "src/compiler/wasm-gc-lowering.cc", "src/compiler/wasm-gc-operator-reducer.cc", "src/compiler/wasm-graph-assembler.cc", "src/compiler/wasm-inlining.cc", + "src/compiler/wasm-load-elimination.cc", "src/compiler/wasm-loop-peeling.cc", "src/compiler/wasm-typer.cc", ] } if (v8_enable_wasm_simd256_revec) { - v8_compiler_sources += [ "src/compiler/linear-scheduler.cc" ] + v8_compiler_sources += [ + "src/compiler/linear-scheduler.cc", + "src/compiler/revectorizer.cc", + ] } -# The src/compiler files with optimizations. -v8_source_set("v8_compiler_opt") { +# The src/compiler files for use in mksnapshot. +# - These might be built with additional optimizations if +# v8_enable_fast_mksnapshot is set. +# - We always include Turbofan even if v8_enable_turbofan is unset s.t. +# builtins can be generated by mksnapshot. +v8_source_set("v8_compiler_for_mksnapshot_source_set") { visibility = [ ":*" ] # Only targets in this file can depend on this. sources = v8_compiler_sources @@ -4219,11 +4426,16 @@ v8_source_set("v8_compiler_opt") { } } -# The src/compiler files with default optimization behavior. +# The src/compiler files with default behavior. v8_source_set("v8_compiler") { visibility = [ ":*" ] # Only targets in this file can depend on this. - sources = v8_compiler_sources + if (v8_enable_turbofan) { + sources = v8_compiler_sources + } else { + # With Turbofan disabled, we only include the stubbed-out API. + sources = [ "src/compiler/turbofan-disabled.cc" ] + } public_deps = [ ":generate_bytecode_builtins_list", @@ -4247,15 +4459,21 @@ v8_source_set("v8_turboshaft") { visibility = [ ":*" ] # Only targets in this file can depend on this. sources = [ + "src/compiler/turboshaft/assembler.cc", "src/compiler/turboshaft/decompression-optimization.cc", "src/compiler/turboshaft/graph-builder.cc", "src/compiler/turboshaft/graph-visualizer.cc", "src/compiler/turboshaft/graph.cc", + "src/compiler/turboshaft/late-escape-analysis-reducer.cc", + "src/compiler/turboshaft/memory-optimization.cc", "src/compiler/turboshaft/operations.cc", "src/compiler/turboshaft/optimization-phase.cc", "src/compiler/turboshaft/recreate-schedule.cc", "src/compiler/turboshaft/representations.cc", "src/compiler/turboshaft/simplify-tf-loops.cc", + "src/compiler/turboshaft/type-parser.cc", + "src/compiler/turboshaft/typer.cc", + "src/compiler/turboshaft/types.cc", "src/compiler/turboshaft/utils.cc", ] @@ -4277,8 +4495,14 @@ v8_source_set("v8_turboshaft") { } group("v8_compiler_for_mksnapshot") { - if (is_debug && !v8_optimized_debug && v8_enable_fast_mksnapshot) { - deps = [ ":v8_compiler_opt" ] + if ((is_debug && !v8_optimized_debug && v8_enable_fast_mksnapshot) || + !v8_enable_turbofan) { + # mksnapshot needs its own version of the compiler, either because + # a) we're optimizing for mksnapshot execution speed and the compiler + # should be optimized even if the rest of V8 is not; or + # b) Turbofan is disabled and thus not compiled into the rest of V8, yet + # mksnapshot still needs TF to generate builtins. + deps = [ ":v8_compiler_for_mksnapshot_source_set" ] } else { deps = [ ":v8_compiler" ] } @@ -4297,7 +4521,11 @@ group("v8_tracing") { } v8_source_set("v8_base_without_compiler") { - visibility = [ ":*" ] # Only targets in this file can depend on this. + # Only targets in this file and gcmole can depend on this. + visibility = [ + ":*", + "tools/gcmole/:*", + ] # Split static libraries on windows into two. split_count = 2 @@ -4351,7 +4579,6 @@ v8_source_set("v8_base_without_compiler") { "src/builtins/builtins-trace.cc", "src/builtins/builtins-typed-array.cc", "src/builtins/builtins-weak-refs.cc", - "src/builtins/builtins-web-snapshots.cc", "src/builtins/builtins.cc", "src/builtins/constants-table-builder.cc", "src/codegen/aligned-slot-allocator.cc", @@ -4371,6 +4598,7 @@ v8_source_set("v8_base_without_compiler") { "src/codegen/handler-table.cc", "src/codegen/interface-descriptors.cc", "src/codegen/machine-type.cc", + "src/codegen/macro-assembler-base.cc", "src/codegen/maglev-safepoint-table.cc", "src/codegen/optimized-compilation-info.cc", "src/codegen/pending-optimization-table.cc", @@ -4381,10 +4609,10 @@ v8_source_set("v8_base_without_compiler") { "src/codegen/source-position.cc", "src/codegen/tick-counter.cc", "src/codegen/tnode.cc", - "src/codegen/turbo-assembler.cc", "src/codegen/unoptimized-compilation-info.cc", "src/common/assert-scope.cc", "src/common/code-memory-access.cc", + "src/common/ptr-compr.cc", "src/compiler-dispatcher/lazy-compile-dispatcher.cc", "src/compiler-dispatcher/optimizing-compile-dispatcher.cc", "src/date/date.cc", @@ -4460,10 +4688,10 @@ v8_source_set("v8_base_without_compiler") { "src/heap/concurrent-marking.cc", "src/heap/cppgc-js/cpp-heap.cc", "src/heap/cppgc-js/cpp-snapshot.cc", + "src/heap/cppgc-js/cross-heap-remembered-set.cc", "src/heap/cppgc-js/unified-heap-marking-state.cc", "src/heap/cppgc-js/unified-heap-marking-verifier.cc", "src/heap/cppgc-js/unified-heap-marking-visitor.cc", - "src/heap/embedder-tracing.cc", "src/heap/evacuation-verifier.cc", "src/heap/factory-base.cc", "src/heap/factory.cc", @@ -4471,7 +4699,6 @@ v8_source_set("v8_base_without_compiler") { "src/heap/free-list.cc", "src/heap/gc-idle-time-handler.cc", "src/heap/gc-tracer.cc", - "src/heap/global-handle-marking-visitor.cc", "src/heap/heap-allocator.cc", "src/heap/heap-controller.cc", "src/heap/heap-layout-tracer.cc", @@ -4509,6 +4736,7 @@ v8_source_set("v8_base_without_compiler") { "src/heap/stress-marking-observer.cc", "src/heap/stress-scavenge-observer.cc", "src/heap/sweeper.cc", + "src/heap/traced-handles-marking-visitor.cc", "src/heap/weak-object-worklists.cc", "src/ic/call-optimization.cc", "src/ic/handler-configuration.cc", @@ -4584,6 +4812,7 @@ v8_source_set("v8_base_without_compiler") { "src/objects/js-segment-iterator.cc", "src/objects/js-segmenter.cc", "src/objects/js-segments.cc", + "src/objects/js-struct.cc", "src/objects/js-temporal-objects.cc", "src/objects/keys.cc", "src/objects/literal-objects.cc", @@ -4736,13 +4965,13 @@ v8_source_set("v8_base_without_compiler") { "src/utils/allocation.cc", "src/utils/bit-vector.cc", "src/utils/detachable-vector.cc", + "src/utils/hex-format.cc", "src/utils/identity-map.cc", "src/utils/memcopy.cc", "src/utils/ostreams.cc", + "src/utils/sha-256.cc", "src/utils/utils.cc", "src/utils/version.cc", - "src/web-snapshot/web-snapshot.cc", - "src/web-snapshot/web-snapshot.h", "src/zone/accounting-allocator.cc", "src/zone/type-stats.cc", "src/zone/zone-segment.cc", @@ -4765,13 +4994,26 @@ v8_source_set("v8_base_without_compiler") { "src/maglev/maglev-graph-printer.cc", "src/maglev/maglev-interpreter-frame-state.cc", "src/maglev/maglev-ir.cc", + "src/maglev/maglev-phi-representation-selector.cc", "src/maglev/maglev-regalloc.cc", "src/maglev/maglev.cc", ] + if (v8_current_cpu == "arm64") { + sources += [ + "src/maglev/arm64/maglev-assembler-arm64.cc", + "src/maglev/arm64/maglev-ir-arm64.cc", + ] + } else if (v8_current_cpu == "x64") { + sources += [ + "src/maglev/x64/maglev-assembler-x64.cc", + "src/maglev/x64/maglev-ir-x64.cc", + ] + } } if (v8_enable_webassembly) { - sources += [ ### gcmole(all) ### + sources += [ + ### gcmole(all) ### "src/asmjs/asm-js.cc", "src/asmjs/asm-parser.cc", "src/asmjs/asm-scanner.cc", @@ -4853,14 +5095,12 @@ v8_source_set("v8_base_without_compiler") { } if (v8_current_cpu == "x86") { - sources += [ ### gcmole(arch:ia32) ### + sources += [ + ### gcmole(ia32) ### "src/codegen/ia32/assembler-ia32.cc", "src/codegen/ia32/cpu-ia32.cc", "src/codegen/ia32/macro-assembler-ia32.cc", "src/codegen/shared-ia32-x64/macro-assembler-shared-ia32-x64.cc", - "src/compiler/backend/ia32/code-generator-ia32.cc", - "src/compiler/backend/ia32/instruction-scheduler-ia32.cc", - "src/compiler/backend/ia32/instruction-selector-ia32.cc", "src/deoptimizer/ia32/deoptimizer-ia32.cc", "src/diagnostics/ia32/disasm-ia32.cc", "src/diagnostics/ia32/unwinder-ia32.cc", @@ -4868,15 +5108,12 @@ v8_source_set("v8_base_without_compiler") { "src/regexp/ia32/regexp-macro-assembler-ia32.cc", ] } else if (v8_current_cpu == "x64") { - sources += [ ### gcmole(arch:x64) ### + sources += [ + ### gcmole(x64) ### "src/codegen/shared-ia32-x64/macro-assembler-shared-ia32-x64.cc", "src/codegen/x64/assembler-x64.cc", "src/codegen/x64/cpu-x64.cc", "src/codegen/x64/macro-assembler-x64.cc", - "src/compiler/backend/x64/code-generator-x64.cc", - "src/compiler/backend/x64/instruction-scheduler-x64.cc", - "src/compiler/backend/x64/instruction-selector-x64.cc", - "src/compiler/backend/x64/unwinding-info-writer-x64.cc", "src/deoptimizer/x64/deoptimizer-x64.cc", "src/diagnostics/x64/disasm-x64.cc", "src/diagnostics/x64/eh-frame-x64.cc", @@ -4906,15 +5143,12 @@ v8_source_set("v8_base_without_compiler") { } } } else if (v8_current_cpu == "arm") { - sources += [ ### gcmole(arch:arm) ### + sources += [ + ### gcmole(arm) ### "src/codegen/arm/assembler-arm.cc", "src/codegen/arm/constants-arm.cc", "src/codegen/arm/cpu-arm.cc", "src/codegen/arm/macro-assembler-arm.cc", - "src/compiler/backend/arm/code-generator-arm.cc", - "src/compiler/backend/arm/instruction-scheduler-arm.cc", - "src/compiler/backend/arm/instruction-selector-arm.cc", - "src/compiler/backend/arm/unwinding-info-writer-arm.cc", "src/deoptimizer/arm/deoptimizer-arm.cc", "src/diagnostics/arm/disasm-arm.cc", "src/diagnostics/arm/eh-frame-arm.cc", @@ -4924,7 +5158,8 @@ v8_source_set("v8_base_without_compiler") { "src/regexp/arm/regexp-macro-assembler-arm.cc", ] } else if (v8_current_cpu == "arm64") { - sources += [ ### gcmole(arch:arm64) ### + sources += [ + ### gcmole(arm64) ### "src/codegen/arm64/assembler-arm64.cc", "src/codegen/arm64/cpu-arm64.cc", "src/codegen/arm64/decoder-arm64.cc", @@ -4933,10 +5168,6 @@ v8_source_set("v8_base_without_compiler") { "src/codegen/arm64/macro-assembler-arm64.cc", "src/codegen/arm64/register-arm64.cc", "src/codegen/arm64/utils-arm64.cc", - "src/compiler/backend/arm64/code-generator-arm64.cc", - "src/compiler/backend/arm64/instruction-scheduler-arm64.cc", - "src/compiler/backend/arm64/instruction-selector-arm64.cc", - "src/compiler/backend/arm64/unwinding-info-writer-arm64.cc", "src/deoptimizer/arm64/deoptimizer-arm64.cc", "src/diagnostics/arm64/disasm-arm64.cc", "src/diagnostics/arm64/eh-frame-arm64.cc", @@ -4950,7 +5181,7 @@ v8_source_set("v8_base_without_compiler") { if (v8_enable_webassembly) { # Trap handling is enabled on arm64 Mac and in simulators on x64 on Linux, # Mac, and Windows. - if ((current_cpu == "arm64" && is_mac) || + if ((current_cpu == "arm64" && is_apple) || (current_cpu == "x64" && (is_linux || is_chromeos || is_mac))) { sources += [ "src/trap-handler/handler-inside-posix.cc", @@ -4971,15 +5202,13 @@ v8_source_set("v8_base_without_compiler") { sources += [ "src/diagnostics/unwinding-info-win64.cc" ] } } else if (v8_current_cpu == "mips64" || v8_current_cpu == "mips64el") { - sources += [ ### gcmole(arch:mips64el) ### + sources += [ + ### gcmole(mips64el) ### "src/codegen/mips64/assembler-mips64.cc", "src/codegen/mips64/constants-mips64.cc", "src/codegen/mips64/cpu-mips64.cc", "src/codegen/mips64/interface-descriptors-mips64-inl.h", "src/codegen/mips64/macro-assembler-mips64.cc", - "src/compiler/backend/mips64/code-generator-mips64.cc", - "src/compiler/backend/mips64/instruction-scheduler-mips64.cc", - "src/compiler/backend/mips64/instruction-selector-mips64.cc", "src/deoptimizer/mips64/deoptimizer-mips64.cc", "src/diagnostics/mips64/disasm-mips64.cc", "src/diagnostics/mips64/unwinder-mips64.cc", @@ -4988,15 +5217,13 @@ v8_source_set("v8_base_without_compiler") { "src/regexp/mips64/regexp-macro-assembler-mips64.cc", ] } else if (v8_current_cpu == "loong64") { - sources += [ ### gcmole(arch:loong64) ### + sources += [ + ### gcmole(loong64) ### "src/codegen/loong64/assembler-loong64.cc", "src/codegen/loong64/constants-loong64.cc", "src/codegen/loong64/cpu-loong64.cc", "src/codegen/loong64/interface-descriptors-loong64-inl.h", "src/codegen/loong64/macro-assembler-loong64.cc", - "src/compiler/backend/loong64/code-generator-loong64.cc", - "src/compiler/backend/loong64/instruction-scheduler-loong64.cc", - "src/compiler/backend/loong64/instruction-selector-loong64.cc", "src/deoptimizer/loong64/deoptimizer-loong64.cc", "src/diagnostics/loong64/disasm-loong64.cc", "src/diagnostics/loong64/unwinder-loong64.cc", @@ -5005,15 +5232,12 @@ v8_source_set("v8_base_without_compiler") { "src/regexp/loong64/regexp-macro-assembler-loong64.cc", ] } else if (v8_current_cpu == "ppc") { - sources += [ ### gcmole(arch: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/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", "src/deoptimizer/ppc/deoptimizer-ppc.cc", "src/diagnostics/ppc/disasm-ppc.cc", "src/diagnostics/ppc/eh-frame-ppc.cc", @@ -5023,15 +5247,12 @@ v8_source_set("v8_base_without_compiler") { "src/regexp/ppc/regexp-macro-assembler-ppc.cc", ] } else if (v8_current_cpu == "ppc64") { - sources += [ ### gcmole(arch:ppc64) ### + sources += [ + ### gcmole(ppc64) ### "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/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", "src/deoptimizer/ppc/deoptimizer-ppc.cc", "src/diagnostics/ppc/disasm-ppc.cc", "src/diagnostics/ppc/eh-frame-ppc.cc", @@ -5041,15 +5262,12 @@ v8_source_set("v8_base_without_compiler") { "src/regexp/ppc/regexp-macro-assembler-ppc.cc", ] } else if (v8_current_cpu == "s390" || v8_current_cpu == "s390x") { - sources += [ ### gcmole(arch:s390) ### + sources += [ + ### gcmole(s390) ### "src/codegen/s390/assembler-s390.cc", "src/codegen/s390/constants-s390.cc", "src/codegen/s390/cpu-s390.cc", "src/codegen/s390/macro-assembler-s390.cc", - "src/compiler/backend/s390/code-generator-s390.cc", - "src/compiler/backend/s390/instruction-scheduler-s390.cc", - "src/compiler/backend/s390/instruction-selector-s390.cc", - "src/compiler/backend/s390/unwinding-info-writer-s390.cc", "src/deoptimizer/s390/deoptimizer-s390.cc", "src/diagnostics/s390/disasm-s390.cc", "src/diagnostics/s390/eh-frame-s390.cc", @@ -5059,7 +5277,8 @@ v8_source_set("v8_base_without_compiler") { "src/regexp/s390/regexp-macro-assembler-s390.cc", ] } else if (v8_current_cpu == "riscv64") { - sources += [ ### gcmole(arch:riscv64) ### + sources += [ + ### gcmole(riscv64) ### "src/codegen/riscv/assembler-riscv.cc", "src/codegen/riscv/base-assembler-riscv.cc", "src/codegen/riscv/base-constants-riscv.cc", @@ -5074,9 +5293,6 @@ v8_source_set("v8_base_without_compiler") { "src/codegen/riscv/extension-riscv-zicsr.cc", "src/codegen/riscv/extension-riscv-zifencei.cc", "src/codegen/riscv/macro-assembler-riscv.cc", - "src/compiler/backend/riscv/code-generator-riscv.cc", - "src/compiler/backend/riscv/instruction-scheduler-riscv.cc", - "src/compiler/backend/riscv/instruction-selector-riscv64.cc", "src/deoptimizer/riscv/deoptimizer-riscv.cc", "src/diagnostics/riscv/disasm-riscv.cc", "src/diagnostics/riscv/unwinder-riscv.cc", @@ -5085,7 +5301,8 @@ v8_source_set("v8_base_without_compiler") { "src/regexp/riscv/regexp-macro-assembler-riscv.cc", ] } else if (v8_current_cpu == "riscv32") { - sources += [ ### gcmole(arch:riscv32) ### + sources += [ + ### gcmole(riscv32) ### "src/codegen/riscv/assembler-riscv.cc", "src/codegen/riscv/base-assembler-riscv.cc", "src/codegen/riscv/base-constants-riscv.cc", @@ -5100,9 +5317,6 @@ v8_source_set("v8_base_without_compiler") { "src/codegen/riscv/extension-riscv-zicsr.cc", "src/codegen/riscv/extension-riscv-zifencei.cc", "src/codegen/riscv/macro-assembler-riscv.cc", - "src/compiler/backend/riscv/code-generator-riscv.cc", - "src/compiler/backend/riscv/instruction-scheduler-riscv.cc", - "src/compiler/backend/riscv/instruction-selector-riscv32.cc", "src/deoptimizer/riscv/deoptimizer-riscv.cc", "src/diagnostics/riscv/disasm-riscv.cc", "src/diagnostics/riscv/unwinder-riscv.cc", @@ -5223,8 +5437,11 @@ group("v8_base") { public_deps = [ ":v8_base_without_compiler", ":v8_compiler", - ":v8_turboshaft", ] + + if (v8_enable_turbofan) { + public_deps += [ ":v8_turboshaft" ] + } } v8_source_set("torque_base") { @@ -5528,7 +5745,6 @@ v8_component("v8_libbase") { sources += [ "src/base/debug/stack_trace_posix.cc", "src/base/platform/platform-darwin.cc", - "src/base/platform/platform-macos.cc", ] } else { sources += [ @@ -5556,7 +5772,6 @@ v8_component("v8_libbase") { sources += [ "src/base/debug/stack_trace_posix.cc", "src/base/platform/platform-darwin.cc", - "src/base/platform/platform-macos.cc", ] } else if (is_ios) { sources += [ @@ -5612,9 +5827,35 @@ v8_component("v8_libbase") { [ "//build/config/clang:llvm-symbolizer_data($host_toolchain)" ] } + if (v8_use_libm_trig_functions) { + deps += [ ":libm" ] + } + # TODO(infra): Add support for qnx, freebsd, openbsd, netbsd, and solaris. } +if (v8_use_libm_trig_functions) { + source_set("libm") { + sources = [ + "third_party/glibc/src/sysdeps/ieee754/dbl-64/branred.c", + "third_party/glibc/src/sysdeps/ieee754/dbl-64/branred.h", + "third_party/glibc/src/sysdeps/ieee754/dbl-64/dla.h", + "third_party/glibc/src/sysdeps/ieee754/dbl-64/endian.h", + "third_party/glibc/src/sysdeps/ieee754/dbl-64/mydefs.h", + "third_party/glibc/src/sysdeps/ieee754/dbl-64/s_sin.c", + "third_party/glibc/src/sysdeps/ieee754/dbl-64/sincostab.c", + "third_party/glibc/src/sysdeps/ieee754/dbl-64/trig.h", + "third_party/glibc/src/sysdeps/ieee754/dbl-64/usncs.h", + ] + configs += [ "//build/config/compiler:no_chromium_code" ] + configs -= [ "//build/config/compiler:chromium_code" ] + if (!is_debug) { + # Build code using -O3, see: crbug.com/1084371. + configs += [ "//build/config/compiler:optimize_speed" ] + } + } +} + v8_component("v8_libplatform") { sources = [ "//base/trace_event/common/trace_event_common.h", @@ -5764,31 +6005,31 @@ v8_source_set("v8_heap_base") { if (is_clang || !is_win) { if (current_cpu == "x64") { - sources += [ "src/heap/base/asm/x64/save_registers_asm.cc" ] + sources += [ "src/heap/base/asm/x64/push_registers_asm.cc" ] } else if (current_cpu == "x86") { - sources += [ "src/heap/base/asm/ia32/save_registers_asm.cc" ] + sources += [ "src/heap/base/asm/ia32/push_registers_asm.cc" ] } else if (current_cpu == "arm") { - sources += [ "src/heap/base/asm/arm/save_registers_asm.cc" ] + sources += [ "src/heap/base/asm/arm/push_registers_asm.cc" ] } else if (current_cpu == "arm64") { - sources += [ "src/heap/base/asm/arm64/save_registers_asm.cc" ] + sources += [ "src/heap/base/asm/arm64/push_registers_asm.cc" ] } else if (current_cpu == "ppc64") { - sources += [ "src/heap/base/asm/ppc/save_registers_asm.cc" ] + sources += [ "src/heap/base/asm/ppc/push_registers_asm.cc" ] } else if (current_cpu == "s390x") { - sources += [ "src/heap/base/asm/s390/save_registers_asm.cc" ] + sources += [ "src/heap/base/asm/s390/push_registers_asm.cc" ] } else if (current_cpu == "mips64el") { - sources += [ "src/heap/base/asm/mips64/save_registers_asm.cc" ] + sources += [ "src/heap/base/asm/mips64/push_registers_asm.cc" ] } else if (current_cpu == "loong64") { - sources += [ "src/heap/base/asm/loong64/save_registers_asm.cc" ] + sources += [ "src/heap/base/asm/loong64/push_registers_asm.cc" ] } else if (current_cpu == "riscv64" || current_cpu == "riscv32") { - sources += [ "src/heap/base/asm/riscv/save_registers_asm.cc" ] + sources += [ "src/heap/base/asm/riscv/push_registers_asm.cc" ] } } else if (is_win) { if (current_cpu == "x64") { - sources += [ "src/heap/base/asm/x64/save_registers_masm.asm" ] + sources += [ "src/heap/base/asm/x64/push_registers_masm.asm" ] } else if (current_cpu == "x86") { - sources += [ "src/heap/base/asm/ia32/save_registers_masm.asm" ] + sources += [ "src/heap/base/asm/ia32/push_registers_masm.asm" ] } else if (current_cpu == "arm64") { - sources += [ "src/heap/base/asm/arm64/save_registers_masm.S" ] + sources += [ "src/heap/base/asm/arm64/push_registers_masm.S" ] } } @@ -6124,6 +6365,8 @@ if (current_toolchain == v8_snapshot_toolchain) { "src/snapshot/embedded/platform-embedded-file-writer-win.h", "src/snapshot/mksnapshot.cc", "src/snapshot/snapshot-empty.cc", + "src/snapshot/static-roots-gen.cc", + "src/snapshot/static-roots-gen.h", ] if (v8_control_flow_integrity) { @@ -6402,10 +6645,14 @@ if (is_component_build) { ":torque_ls_base", ":v8_base", ":v8_headers", - ":v8_initializers", ":v8_snapshot", ] + if (v8_enable_turbofan) { + # For cctest/test-serialize. + public_deps += [ ":v8_initializers" ] + } + configs = [ ":internal_config" ] public_configs = [ ":external_config" ] @@ -6458,10 +6705,14 @@ if (is_component_build) { ":torque_base", ":torque_ls_base", ":v8_base", - ":v8_initializers", ":v8_snapshot", ] + if (v8_enable_turbofan) { + # For cctest/test-serialize. + public_deps += [ ":v8_initializers" ] + } + public_configs = [ ":external_config" ] } diff --git a/deps/v8/DEPS b/deps/v8/DEPS index ab0a9bf5431112..d40052528da793 100644 --- a/deps/v8/DEPS +++ b/deps/v8/DEPS @@ -30,8 +30,18 @@ vars = { 'checkout_instrumented_libraries': False, 'checkout_ittapi': False, + + # Fetch the prebuilt binaries for llvm-cov and llvm-profdata. Needed to + # process the raw profiles produced by instrumented targets (built with + # the gn arg 'use_clang_coverage'). + 'checkout_clang_coverage_tools': False, + # Fetch clang-tidy into the same bin/ directory as our clang binary. 'checkout_clang_tidy': False, + + # Fetch and build V8 builtins with PGO profiles + 'checkout_v8_builtins_pgo_profiles': False, + 'chromium_url': 'https://chromium.googlesource.com', 'android_url': 'https://android.googlesource.com', 'download_gcmole': False, @@ -43,22 +53,22 @@ vars = { 'fuchsia_sdk_cipd_prefix': 'fuchsia/sdk/gn/', # reclient CIPD package version - 'reclient_version': 're_client_version:0.83.0.da55f4f-gomaip', + 'reclient_version': 're_client_version:0.96.2.d36a87c-gomaip', # GN CIPD package version. - 'gn_version': 'git_revision:a4d67be044b42963de801001e7146f9657c7fad4', + 'gn_version': 'git_revision:b25a2f8c2d33f02082f0f258350f5e22c0973108', # ninja CIPD package version # https://chrome-infra-packages.appspot.com/p/infra/3pp/tools/ninja - 'ninja_version': 'version:2@1.8.2.chromium.3', + 'ninja_version': 'version:2@1.11.1.chromium.6', # luci-go CIPD package version. - 'luci_go': 'git_revision:f8f64a8c560d2bf68a3ad1137979d17cffb36d30', + 'luci_go': 'git_revision:8a8b4f2ea65c7ff5fde8a0c522008aed78d42d9d', # 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:10.20221109.1.1', + 'fuchsia_version': 'version:11.20230222.0.1', # Three lines of non-changing comments so that # the commit queue can handle CLs rolling android_sdk_build-tools_version @@ -91,18 +101,18 @@ 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': 'IPzAG-uU5zVMxohpg9-7-N0tQC1TCSW1VbrBFw7Ld04C', + 'android_sdk_cmdline-tools_version': '3Yn5Sn7BMObm8gsoZCF0loJMKg9_PpgU07G9DObCLdQC', } deps = { 'base/trace_event/common': - Var('chromium_url') + '/chromium/src/base/trace_event/common.git' + '@' + '521ac34ebd795939c7e16b37d9d3ddb40e8ed556', + Var('chromium_url') + '/chromium/src/base/trace_event/common.git' + '@' + '147f65333c38ddd1ebf554e89965c243c8ce50b3', 'build': - Var('chromium_url') + '/chromium/src/build.git' + '@' + '875cb19167f2e0d7b1eca89a4d5b5693421424c6', + Var('chromium_url') + '/chromium/src/build.git' + '@' + '4d96c496d92cb76c10b201cf9affb2d2027e3a86', 'buildtools': - Var('chromium_url') + '/chromium/src/buildtools.git' + '@' + '49ac7cf34ab2e59a10629a7a722cfb94348c4996', + Var('chromium_url') + '/chromium/src/buildtools.git' + '@' + 'd110f6238fee0e4c82ab64606e5e967a3c809c55', 'buildtools/clang_format/script': - Var('chromium_url') + '/external/github.com/llvm/llvm-project/clang/tools/clang-format.git' + '@' + '8b525d2747f2584fc35d8c7e612e66f377858df7', + Var('chromium_url') + '/external/github.com/llvm/llvm-project/clang/tools/clang-format.git' + '@' + 'f97059df7f8b205064625cdb5f97b56668a125ef', 'buildtools/linux64': { 'packages': [ { @@ -124,11 +134,11 @@ deps = { 'condition': 'host_os == "mac"', }, 'buildtools/third_party/libc++/trunk': - Var('chromium_url') + '/external/github.com/llvm/llvm-project/libcxx.git' + '@' + '4218f3525ad438b22b0e173d963515a09d143398', + Var('chromium_url') + '/external/github.com/llvm/llvm-project/libcxx.git' + '@' + 'abad4bb576d98d81c2d5861c3862cc87145f7dad', 'buildtools/third_party/libc++abi/trunk': - Var('chromium_url') + '/external/github.com/llvm/llvm-project/libcxxabi.git' + '@' + '1a32724f721e1c3b6c590a07fe4a954344f15e48', + Var('chromium_url') + '/external/github.com/llvm/llvm-project/libcxxabi.git' + '@' + '5559ffe8ca32471e894f4cb04b7d18d28862677f', 'buildtools/third_party/libunwind/trunk': - Var('chromium_url') + '/external/github.com/llvm/llvm-project/libunwind.git' + '@' + 'a318d6a4c283a9d342d2a1e20292c1496fe12997', + Var('chromium_url') + '/external/github.com/llvm/llvm-project/libunwind.git' + '@' + 'aecf8d01b908e9dbfe6741da2fe7425879df3537', 'buildtools/win': { 'packages': [ { @@ -147,14 +157,14 @@ deps = { } ], 'dep_type': 'cipd', - 'condition': '(host_os == "linux" or host_os == "mac" or host_os == "win") and host_cpu != "s390" and host_cpu != "ppc"', + 'condition': '(host_os == "linux" or host_os == "mac" or host_os == "win") and host_cpu != "s390" and host_cpu != "ppc" and host_cpu != "arm64"', }, 'test/benchmarks/data': Var('chromium_url') + '/v8/deps/third_party/benchmarks.git' + '@' + '05d7188267b4560491ff9155c5ee13e207ecd65f', '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' + '@' + 'ade328d530525333751e8a3b58f02e18624da085', + Var('chromium_url') + '/external/github.com/tc39/test262.git' + '@' + 'e7364ea7dc36a466edb2db5ef0a8e66da8dabb7d', 'third_party/android_ndk': { 'url': Var('chromium_url') + '/android_ndk.git' + '@' + '8388a2be5421311dc75c5f937aae13d821a27f3d', 'condition': 'checkout_android', @@ -202,7 +212,7 @@ deps = { 'dep_type': 'cipd', }, 'third_party/catapult': { - 'url': Var('chromium_url') + '/catapult.git' + '@' + 'f0b11967c94cba8f7cca91d2da20c98d4420fc25', + 'url': Var('chromium_url') + '/catapult.git' + '@' + 'c6149c709aabcbdaa61b9348b467a221bcf21f99', 'condition': 'checkout_android', }, 'third_party/colorama/src': { @@ -210,7 +220,7 @@ deps = { 'condition': 'checkout_android', }, 'third_party/depot_tools': - Var('chromium_url') + '/chromium/tools/depot_tools.git' + '@' + 'ae1a70891738fb14f64fbb884e00b87ac663aa15', + Var('chromium_url') + '/chromium/tools/depot_tools.git' + '@' + '4756d7c420fa4b6ecd8f9776638de7c7301f021b', 'third_party/fuchsia-sdk/sdk': { 'packages': [ { @@ -227,9 +237,9 @@ deps = { 'third_party/googletest/src': Var('chromium_url') + '/external/github.com/google/googletest.git' + '@' + 'af29db7ec28d6df1c7f0f745186884091e602e07', 'third_party/icu': - Var('chromium_url') + '/chromium/deps/icu.git' + '@' + 'da07448619763d1cde255b361324242646f5b268', + Var('chromium_url') + '/chromium/deps/icu.git' + '@' + 'c6b68522318204f795a8f04caebf6c0beb679cc4', 'third_party/instrumented_libraries': - Var('chromium_url') + '/chromium/src/third_party/instrumented_libraries.git' + '@' + '7bb87a375ffc3effd17a50f690099dcfb9ee280b', + Var('chromium_url') + '/chromium/src/third_party/instrumented_libraries.git' + '@' + '0f536d22dbed454b1254c7e6d7130eab28fba1fa', 'third_party/ittapi': { # Force checkout ittapi libraries to pass v8 header includes check on # bots that has check_v8_header_includes enabled. @@ -237,7 +247,7 @@ deps = { 'condition': "checkout_ittapi or check_v8_header_includes", }, 'third_party/jinja2': - Var('chromium_url') + '/chromium/src/third_party/jinja2.git' + '@' + '4633bf431193690c3491244f5a0acbe9ac776233', + Var('chromium_url') + '/chromium/src/third_party/jinja2.git' + '@' + '264c07d7e64f2874434a3b8039e101ddf1b01e7e', 'third_party/jsoncpp/source': Var('chromium_url') + '/external/github.com/open-source-parsers/jsoncpp.git'+ '@' + '42e892d96e47b1f6e29844cc705e148ec4856448', 'third_party/logdog/logdog': @@ -255,7 +265,7 @@ deps = { 'condition': 'host_cpu != "s390" and host_cpu != "ppc"' }, 'third_party/perfetto': - Var('android_url') + '/platform/external/perfetto.git' + '@' + '0eba417b2c72264fa825dc21067b9adc9b8adf70', + Var('android_url') + '/platform/external/perfetto.git' + '@' + '7708bc5ae4f77926cf017d7832d784bfc4685418', 'third_party/protobuf': Var('chromium_url') + '/external/github.com/google/protobuf'+ '@' + '6a59a2ad1f61d9696092f79b6d74368b4d7970a3', 'third_party/requests': { @@ -263,9 +273,9 @@ deps = { 'condition': 'checkout_android', }, 'third_party/zlib': - Var('chromium_url') + '/chromium/src/third_party/zlib.git'+ '@' + '8bbd6c3129b5146489f2321f054e855c347857f4', + Var('chromium_url') + '/chromium/src/third_party/zlib.git'+ '@' + 'ab0d470309eab637f990878965d0f10ca34f60fc', 'tools/clang': - Var('chromium_url') + '/chromium/src/tools/clang.git' + '@' + 'd3df9cc5362e0af4cda798b0612dde39783b3dc0', + Var('chromium_url') + '/chromium/src/tools/clang.git' + '@' + '59d4a6deb0f4f0ec8a7d134f94a2b2fef14d444f', 'tools/luci-go': { 'packages': [ { @@ -499,7 +509,7 @@ hooks = [ '--arch=x64'], }, { - 'name': 'msan_chained_origins', + 'name': 'msan_chained_origins_focal', 'pattern': '.', 'condition': 'checkout_instrumented_libraries', 'action': [ 'python3', @@ -507,11 +517,11 @@ hooks = [ '--no_resume', '--no_auth', '--bucket', 'chromium-instrumented-libraries', - '-s', 'third_party/instrumented_libraries/binaries/msan-chained-origins.tgz.sha1', + '-s', 'third_party/instrumented_libraries/binaries/msan-chained-origins-focal.tgz.sha1', ], }, { - 'name': 'msan_no_origins', + 'name': 'msan_no_origins_focal', 'pattern': '.', 'condition': 'checkout_instrumented_libraries', 'action': [ 'python3', @@ -519,7 +529,7 @@ hooks = [ '--no_resume', '--no_auth', '--bucket', 'chromium-instrumented-libraries', - '-s', 'third_party/instrumented_libraries/binaries/msan-no-origins.tgz.sha1', + '-s', 'third_party/instrumented_libraries/binaries/msan-no-origins-focal.tgz.sha1', ], }, { @@ -557,6 +567,14 @@ hooks = [ 'condition': 'host_os != "aix"', 'action': ['python3', 'tools/clang/scripts/update.py'], }, + { + # This is supposed to support the same set of platforms as 'clang' above. + 'name': 'clang_coverage', + 'pattern': '.', + 'condition': 'checkout_clang_coverage_tools', + 'action': ['python3', 'tools/clang/scripts/update.py', + '--package=coverage_tools'], + }, { 'name': 'clang_tidy', 'pattern': '.', @@ -606,6 +624,16 @@ hooks = [ 'tools/generate-header-include-checks.py', ], }, + { + 'name': 'checkout_v8_builtins_pgo_profiles', + 'pattern': '.', + 'condition': 'checkout_v8_builtins_pgo_profiles', + 'action': [ + 'python3', + 'tools/builtins-pgo/download_profiles.py', + 'download', + ], + }, { # Clean up build dirs for crbug.com/1337238. # After a libc++ roll and revert, .ninja_deps would get into a state diff --git a/deps/v8/PPC_OWNERS b/deps/v8/PPC_OWNERS index 02c2cd757c9cb7..6edd45a6ef2e04 100644 --- a/deps/v8/PPC_OWNERS +++ b/deps/v8/PPC_OWNERS @@ -2,4 +2,3 @@ junyan@redhat.com joransiu@ca.ibm.com midawson@redhat.com mfarazma@redhat.com -vasili.skurydzin@ibm.com diff --git a/deps/v8/PRESUBMIT.py b/deps/v8/PRESUBMIT.py index 03db4c126f346d..5c31d4dfabd776 100644 --- a/deps/v8/PRESUBMIT.py +++ b/deps/v8/PRESUBMIT.py @@ -85,6 +85,7 @@ def _V8PresubmitChecks(input_api, output_api): sys.path.append(input_api.os_path.join( input_api.PresubmitLocalPath(), 'tools')) from v8_presubmit import CppLintProcessor + from v8_presubmit import GCMoleProcessor from v8_presubmit import JSLintProcessor from v8_presubmit import TorqueLintProcessor from v8_presubmit import SourceProcessor @@ -126,6 +127,9 @@ def FilterJSFile(affected_file): if not StatusFilesProcessor().RunOnFiles( input_api.AffectedFiles(include_deletes=True)): results.append(output_api.PresubmitError("Status file check failed")) + if not GCMoleProcessor().RunOnFiles( + input_api.AffectedFiles(include_deletes=False)): + results.append(output_api.PresubmitError("GCMole pattern check failed")) results.extend(input_api.canned_checks.CheckAuthorizedAuthor( input_api, output_api, bot_allowlist=[ 'v8-ci-autoroll-builder@chops-service-accounts.iam.gserviceaccount.com' @@ -257,8 +261,9 @@ def FilterFile(affected_file): files_to_check=(file_inclusion_pattern, ), files_to_skip=files_to_skip) - leading_src_pattern = input_api.re.compile(r'^src/') - dash_dot_slash_pattern = input_api.re.compile(r'[-./]') + leading_src_pattern = input_api.re.compile(r'^src[\\\/]') + dash_dot_slash_pattern = input_api.re.compile(r'[-.\\\/]') + def PathToGuardMacro(path): """Guards should be of the form V8_PATH_TO_FILE_WITHOUT_SRC_H_.""" x = input_api.re.sub(leading_src_pattern, 'v8_', path) diff --git a/deps/v8/S390_OWNERS b/deps/v8/S390_OWNERS index 02c2cd757c9cb7..6edd45a6ef2e04 100644 --- a/deps/v8/S390_OWNERS +++ b/deps/v8/S390_OWNERS @@ -2,4 +2,3 @@ junyan@redhat.com joransiu@ca.ibm.com midawson@redhat.com mfarazma@redhat.com -vasili.skurydzin@ibm.com diff --git a/deps/v8/WATCHLISTS b/deps/v8/WATCHLISTS index a078c5568e4707..d853a0de2a2e36 100644 --- a/deps/v8/WATCHLISTS +++ b/deps/v8/WATCHLISTS @@ -101,11 +101,16 @@ '|test/unittests/heap/cppgc/' \ '|test/unittests/heap/cppgc-js/', }, + 'trap-handler': { + 'filepath': 'src/trap-handler/', + }, + 'tests': { + 'filepath': 'test/', + }, }, 'WATCHLISTS': { 'maglev': [ - 'jgruber+watch@chromium.org', 'leszeks+watch@chromium.org', 'verwaest+watch@chromium.org', 'victorgomes+watch@chromium.org', @@ -122,6 +127,7 @@ ], 'feature_shipping_status': [ 'hablich@chromium.org', + 'saelo+watch@chromium.org', ], 'heap_changes': [ 'hpayer@chromium.org', @@ -168,5 +174,14 @@ 'cppgc': [ 'oilpan-reviews+v8@chromium.org', ], + 'trap-handler': [ + 'ahaas@chromium.org', + 'clemensb@chromium.org', + 'mark@chromium.org', + 'mseaborn@chromium.org', + ], + 'tests': [ + 'almuthanna+watch@chromium.org', + ], }, } diff --git a/deps/v8/base/trace_event/common/trace_event_common.h b/deps/v8/base/trace_event/common/trace_event_common.h index f07f19b3095f57..f2ee4d36b317db 100644 --- a/deps/v8/base/trace_event/common/trace_event_common.h +++ b/deps/v8/base/trace_event/common/trace_event_common.h @@ -208,9 +208,6 @@ #include "base/time/time.h" #include "build/build_config.h" -// Export Perfetto symbols in the same way as //base symbols. -#define PERFETTO_COMPONENT_EXPORT BASE_EXPORT - // Enable legacy trace event macros (e.g., TRACE_EVENT{0,1,2}). #define PERFETTO_ENABLE_LEGACY_TRACE_EVENTS 1 @@ -224,11 +221,6 @@ // variable a unique name based on the line number to prevent name collisions. #define INTERNAL_TRACE_EVENT_UID(name_prefix) PERFETTO_UID(name_prefix) -// Special trace event macro to trace log messages. -// TODO(skyostil): Convert this into a regular typed trace event. -#define TRACE_LOG_MESSAGE(file, message, line) \ - INTERNAL_TRACE_LOG_MESSAGE(file, message, line) - // Declare debug annotation converters for base time types, so they can be // passed as trace event arguments. // TODO(skyostil): Serialize timestamps using perfetto::TracedValue instead. @@ -250,7 +242,8 @@ WriteDebugAnnotation(protos::pbzero::DebugAnnotation* annotation, ::base::Time); } // namespace perfetto // Pull in the tracing macro definitions from Perfetto. -#include "third_party/perfetto/include/perfetto/tracing.h" +#include "third_party/perfetto/include/perfetto/tracing/track_event.h" +#include "third_party/perfetto/include/perfetto/tracing/track_event_legacy.h" namespace perfetto { namespace legacy { @@ -983,10 +976,6 @@ struct BASE_EXPORT TraceTimestampTraits<::base::TimeTicks> { category_group, name, id, \ TRACE_EVENT_FLAG_COPY, arg1_name, arg1_val) -// Special trace event macro to trace log messages. -#define TRACE_LOG_MESSAGE(file, message, line) \ - INTERNAL_TRACE_LOG_MESSAGE(file, message, line) - // TRACE_EVENT_METADATA* events are information related to other // injected events, not events in their own right. #define TRACE_EVENT_METADATA1(category_group, name, arg1_name, arg1_val) \ diff --git a/deps/v8/bazel/config/BUILD.bazel b/deps/v8/bazel/config/BUILD.bazel index 448260de88465d..7af7ccb6067883 100644 --- a/deps/v8/bazel/config/BUILD.bazel +++ b/deps/v8/bazel/config/BUILD.bazel @@ -22,6 +22,13 @@ config_setting( }, ) +config_setting( + name = "is_opt", + values = { + "compilation_mode": "opt", + }, +) + config_setting( name = "is_debug", values = { diff --git a/deps/v8/bazel/defs.bzl b/deps/v8/bazel/defs.bzl index 77e86ef6f2e646..a23646ea377f5e 100644 --- a/deps/v8/bazel/defs.bzl +++ b/deps/v8/bazel/defs.bzl @@ -152,6 +152,14 @@ def _default_args(): ], "//conditions:default": [], }), + cxxopts = select({ + "//third_party/v8/HEAD/google3/config:is_opt": [ + "-fvisibility=hidden", + "-fvisibility-inlines-hidden", + ], + "//conditions:default": [ + ], + }), includes = ["include"], linkopts = select({ "@v8//bazel/config:is_windows": [ @@ -197,7 +205,7 @@ def v8_binary( name = "noicu/" + name, srcs = srcs + noicu_srcs, deps = deps + noicu_deps + default.deps, - includes = includes + default.includes, + includes = includes + ["noicu/"] + default.includes, copts = copts + default.copts, linkopts = linkopts + default.linkopts, **kwargs @@ -206,7 +214,7 @@ def v8_binary( name = "icu/" + name, srcs = srcs + icu_srcs, deps = deps + icu_deps + default.deps, - includes = includes + default.includes, + includes = includes + ["icu/"] + default.includes, copts = copts + default.copts + ENABLE_I18N_SUPPORT_DEFINES, linkopts = linkopts + default.linkopts, **kwargs @@ -241,7 +249,7 @@ def v8_library( name = name + "_noicu", srcs = srcs + noicu_srcs, deps = deps + noicu_deps + default.deps, - includes = includes + default.includes, + includes = includes + ["noicu/"] + default.includes, copts = copts + default.copts, linkopts = linkopts + default.linkopts, alwayslink = 1, @@ -260,7 +268,7 @@ def v8_library( name = name + "_icu", srcs = srcs + icu_srcs, deps = deps + icu_deps + default.deps, - includes = includes + default.includes, + includes = includes + ["icu/"] + default.includes, copts = copts + default.copts + ENABLE_I18N_SUPPORT_DEFINES, linkopts = linkopts + default.linkopts, alwayslink = 1, @@ -288,7 +296,7 @@ def v8_library( **kwargs ) -def _torque_impl(ctx): +def _torque_initializers_impl(ctx): if ctx.workspace_name == "v8": v8root = "." else: @@ -309,7 +317,7 @@ def _torque_impl(ctx): # Generate/declare output files outs = [] for src in ctx.files.srcs: - root, period, ext = src.path.rpartition(".") + root, _period, _ext = src.path.rpartition(".") # Strip v8root if root[:len(v8root)] == v8root: @@ -317,6 +325,84 @@ def _torque_impl(ctx): file = ctx.attr.prefix + "/torque-generated/" + root outs.append(ctx.actions.declare_file(file + "-tq-csa.cc")) outs.append(ctx.actions.declare_file(file + "-tq-csa.h")) + outs += [ctx.actions.declare_file(ctx.attr.prefix + "/torque-generated/" + f) for f in ctx.attr.extras] + ctx.actions.run( + outputs = outs, + inputs = ctx.files.srcs, + arguments = args, + executable = ctx.executable.tool, + mnemonic = "GenTorqueInitializers", + progress_message = "Generating Torque initializers", + ) + return [DefaultInfo(files = depset(outs))] + +_v8_torque_initializers = rule( + implementation = _torque_initializers_impl, + # cfg = v8_target_cpu_transition, + attrs = { + "prefix": attr.string(mandatory = True), + "srcs": attr.label_list(allow_files = True, mandatory = True), + "extras": attr.string_list(), + "tool": attr.label( + allow_files = True, + executable = True, + cfg = "exec", + ), + "args": attr.string_list(), + }, +) + +def v8_torque_initializers(name, noicu_srcs, icu_srcs, args, extras): + _v8_torque_initializers( + name = "noicu/" + name, + prefix = "noicu", + srcs = noicu_srcs, + args = args, + extras = extras, + tool = select({ + "@v8//bazel/config:v8_target_is_32_bits": ":torque_non_pointer_compression", + "//conditions:default": ":torque", + }), + ) + _v8_torque_initializers( + name = "icu/" + name, + prefix = "icu", + srcs = icu_srcs, + args = args, + extras = extras, + tool = select({ + "@v8//bazel/config:v8_target_is_32_bits": ":torque_non_pointer_compression", + "//conditions:default": ":torque", + }), + ) + +def _torque_definitions_impl(ctx): + if ctx.workspace_name == "v8": + v8root = "." + else: + v8root = "external/v8" + + # Arguments + args = [] + args += ctx.attr.args + args.append("-o") + args.append(ctx.bin_dir.path + "/" + v8root + "/" + ctx.attr.prefix + "/torque-generated") + args.append("-strip-v8-root") + args.append("-v8-root") + args.append(v8root) + + # Sources + args += [f.path for f in ctx.files.srcs] + + # Generate/declare output files + outs = [] + for src in ctx.files.srcs: + root, _period, _ext = src.path.rpartition(".") + + # Strip v8root + if root[:len(v8root)] == v8root: + root = root[len(v8root):] + file = ctx.attr.prefix + "/torque-generated/" + root outs.append(ctx.actions.declare_file(file + "-tq-inl.inc")) outs.append(ctx.actions.declare_file(file + "-tq.inc")) outs.append(ctx.actions.declare_file(file + "-tq.cc")) @@ -326,13 +412,13 @@ def _torque_impl(ctx): inputs = ctx.files.srcs, arguments = args, executable = ctx.executable.tool, - mnemonic = "GenTorque", - progress_message = "Generating Torque files", + mnemonic = "GenTorqueDefinitions", + progress_message = "Generating Torque definitions", ) return [DefaultInfo(files = depset(outs))] -_v8_torque = rule( - implementation = _torque_impl, +_v8_torque_definitions = rule( + implementation = _torque_definitions_impl, # cfg = v8_target_cpu_transition, attrs = { "prefix": attr.string(mandatory = True), @@ -347,8 +433,8 @@ _v8_torque = rule( }, ) -def v8_torque(name, noicu_srcs, icu_srcs, args, extras): - _v8_torque( +def v8_torque_definitions(name, noicu_srcs, icu_srcs, args, extras): + _v8_torque_definitions( name = "noicu/" + name, prefix = "noicu", srcs = noicu_srcs, @@ -359,7 +445,7 @@ def v8_torque(name, noicu_srcs, icu_srcs, args, extras): "//conditions:default": ":torque", }), ) - _v8_torque( + _v8_torque_definitions( name = "icu/" + name, prefix = "icu", srcs = icu_srcs, @@ -525,7 +611,17 @@ def build_config_content(cpu, icu): ("v8_enable_single_generation", "false"), ("v8_enable_sandbox", "false"), ("v8_enable_shared_ro_heap", "false"), + ("v8_disable_write_barriers", "false"), ("v8_target_cpu", cpu), + ("v8_code_comments", "false"), + ("v8_enable_debug_code", "false"), + ("v8_enable_verify_heap", "false"), + ("v8_enable_slow_dchecks", "false"), + ("v8_enable_maglev", "false"), + ("v8_enable_turbofan", "true"), + ("v8_enable_disassembler", "false"), + ("is_DEBUG_defined", "false"), + ("v8_enable_gdbjit", "false"), ]) # TODO(victorgomes): Create a rule (instead of a macro), that can diff --git a/deps/v8/gni/snapshot_toolchain.gni b/deps/v8/gni/snapshot_toolchain.gni index 99de816372bf9c..c7faa8ca5897a6 100644 --- a/deps/v8/gni/snapshot_toolchain.gni +++ b/deps/v8/gni/snapshot_toolchain.gni @@ -104,6 +104,10 @@ if (v8_snapshot_toolchain == "") { # cross compile Windows arm64 with host toolchain. v8_snapshot_toolchain = host_toolchain } + } else if (host_cpu == "arm64" && current_cpu == "arm64" && + host_os == "mac") { + # cross compile iOS arm64 with host_toolchain + v8_snapshot_toolchain = host_toolchain } } diff --git a/deps/v8/gni/v8.gni b/deps/v8/gni/v8.gni index 3f093597faccdc..e6ef2249d3573c 100644 --- a/deps/v8/gni/v8.gni +++ b/deps/v8/gni/v8.gni @@ -63,10 +63,19 @@ declare_args() { # Sets -DV8_LITE_MODE. v8_enable_lite_mode = false + # Enable the Turbofan compiler. + # Sets -dV8_ENABLE_TURBOFAN. + v8_enable_turbofan = "" + + # Enable the Maglev compiler. + # Sets -dV8_ENABLE_MAGLEV + v8_enable_maglev = "" + # Include support for WebAssembly. If disabled, the 'WebAssembly' global # will not be available, and embedder APIs to generate WebAssembly modules # will fail. Also, asm.js will not be translated to WebAssembly and will be # executed as standard JavaScript instead. + # Sets -dV8_ENABLE_WEBASSEMBLY. v8_enable_webassembly = "" # Enable 256-bit long vector re-vectorization pass in WASM compilation pipeline. @@ -97,6 +106,12 @@ declare_args() { # Enable young generation in cppgc. cppgc_enable_young_generation = false + # Enables a slim write barrier that only performs a single check in the fast + # path and delegates all further checks to a slow path call. This is fast + # in a setting with few slow-path checks, i.e., with disabled young generation + # GC. + cppgc_enable_slim_write_barrier = true + # Enable pointer compression in cppgc. cppgc_enable_pointer_compression = false @@ -107,6 +122,9 @@ declare_args() { # Enable advanced BigInt algorithms, costing about 10-30 KB binary size # depending on platform. Disabled on Android to save binary size. v8_advanced_bigint_algorithms = !is_android + + # TODO: macros for determining endian type are clang specific. + v8_use_libm_trig_functions = is_clang } if (v8_use_external_startup_data == "") { @@ -132,6 +150,13 @@ if (v8_enable_webassembly == "") { assert(!(v8_enable_webassembly && v8_enable_lite_mode), "Webassembly is not available in lite mode.") +# Turbofan is enabled by default, except in lite mode. +if (v8_enable_turbofan == "") { + v8_enable_turbofan = !v8_enable_lite_mode +} +assert(v8_enable_turbofan || !v8_enable_webassembly, + "Webassembly is not available when Turbofan is disabled.") + # 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 # subdirectories. @@ -277,6 +302,7 @@ template("v8_executable") { template("v8_component") { component(target_name) { + output_name = target_name forward_variables_from(invoker, "*", [ diff --git a/deps/v8/include/cppgc/cross-thread-persistent.h b/deps/v8/include/cppgc/cross-thread-persistent.h index 1fa28afa136eb4..a5f8bac0b1013e 100644 --- a/deps/v8/include/cppgc/cross-thread-persistent.h +++ b/deps/v8/include/cppgc/cross-thread-persistent.h @@ -148,10 +148,11 @@ class BasicCrossThreadPersistent final : public CrossThreadPersistentBase, template ::value>> BasicCrossThreadPersistent( internal::BasicMember + MemberCheckingPolicy, MemberStorageType> member, const SourceLocation& loc = SourceLocation::Current()) : BasicCrossThreadPersistent(member.Get(), loc) {} @@ -230,10 +231,11 @@ class BasicCrossThreadPersistent final : public CrossThreadPersistentBase, // Assignment from member. template ::value>> BasicCrossThreadPersistent& operator=( internal::BasicMember + MemberCheckingPolicy, MemberStorageType> member) { return operator=(member.Get()); } diff --git a/deps/v8/include/cppgc/heap-consistency.h b/deps/v8/include/cppgc/heap-consistency.h index 35c59ed1ad417f..eb7fdaee8c3c02 100644 --- a/deps/v8/include/cppgc/heap-consistency.h +++ b/deps/v8/include/cppgc/heap-consistency.h @@ -62,10 +62,10 @@ class HeapConsistency final { * \returns whether a write barrier is needed and which barrier to invoke. */ template + typename CheckingPolicy, typename StorageType> static V8_INLINE WriteBarrierType GetWriteBarrierType( const internal::BasicMember& value, + CheckingPolicy, StorageType>& value, WriteBarrierParams& params) { return internal::WriteBarrier::GetWriteBarrierType( value.GetRawSlot(), value.GetRawStorage(), params); diff --git a/deps/v8/include/cppgc/internal/api-constants.h b/deps/v8/include/cppgc/internal/api-constants.h index 023426e94b04c9..a27cea6c928098 100644 --- a/deps/v8/include/cppgc/internal/api-constants.h +++ b/deps/v8/include/cppgc/internal/api-constants.h @@ -32,7 +32,7 @@ static constexpr uint16_t kFullyConstructedBitMask = uint16_t{1}; static constexpr size_t kPageSize = size_t{1} << 17; -#if defined(V8_TARGET_ARCH_ARM64) && defined(V8_OS_MACOS) +#if defined(V8_TARGET_ARCH_ARM64) && defined(V8_OS_DARWIN) constexpr size_t kGuardPageSize = 0; #else constexpr size_t kGuardPageSize = 4096; diff --git a/deps/v8/include/cppgc/internal/gc-info.h b/deps/v8/include/cppgc/internal/gc-info.h index e8f90fed57109f..08ffd411a8efab 100644 --- a/deps/v8/include/cppgc/internal/gc-info.h +++ b/deps/v8/include/cppgc/internal/gc-info.h @@ -10,6 +10,7 @@ #include #include "cppgc/internal/finalizer-trait.h" +#include "cppgc/internal/logging.h" #include "cppgc/internal/name-trait.h" #include "cppgc/trace-trait.h" #include "v8config.h" // NOLINT(build/include_directory) @@ -20,12 +21,12 @@ namespace internal { using GCInfoIndex = uint16_t; struct V8_EXPORT EnsureGCInfoIndexTrait final { - // Acquires a new GC info object and returns the index. In addition, also - // updates `registered_index` atomically. + // Acquires a new GC info object and updates `registered_index` with the index + // that identifies that new info accordingly. template - V8_INLINE static GCInfoIndex EnsureIndex( + V8_INLINE static void EnsureIndex( std::atomic& registered_index) { - return EnsureGCInfoIndexTraitDispatch{}(registered_index); + EnsureGCInfoIndexTraitDispatch{}(registered_index); } private: @@ -34,38 +35,32 @@ struct V8_EXPORT EnsureGCInfoIndexTrait final { bool = NameTrait::HasNonHiddenName()> struct EnsureGCInfoIndexTraitDispatch; - static GCInfoIndex EnsureGCInfoIndexPolymorphic(std::atomic&, - TraceCallback, - FinalizationCallback, - NameCallback); - static GCInfoIndex EnsureGCInfoIndexPolymorphic(std::atomic&, - TraceCallback, - FinalizationCallback); - static GCInfoIndex EnsureGCInfoIndexPolymorphic(std::atomic&, - TraceCallback, NameCallback); - static GCInfoIndex EnsureGCInfoIndexPolymorphic(std::atomic&, - TraceCallback); - static GCInfoIndex EnsureGCInfoIndexNonPolymorphic(std::atomic&, - TraceCallback, - FinalizationCallback, - NameCallback); - static GCInfoIndex EnsureGCInfoIndexNonPolymorphic(std::atomic&, - TraceCallback, - FinalizationCallback); - static GCInfoIndex EnsureGCInfoIndexNonPolymorphic(std::atomic&, - TraceCallback, - NameCallback); - static GCInfoIndex EnsureGCInfoIndexNonPolymorphic(std::atomic&, - TraceCallback); + static void V8_PRESERVE_MOST + EnsureGCInfoIndexPolymorphic(std::atomic&, TraceCallback, + FinalizationCallback, NameCallback); + static void V8_PRESERVE_MOST EnsureGCInfoIndexPolymorphic( + std::atomic&, TraceCallback, FinalizationCallback); + static void V8_PRESERVE_MOST EnsureGCInfoIndexPolymorphic( + std::atomic&, TraceCallback, NameCallback); + static void V8_PRESERVE_MOST + EnsureGCInfoIndexPolymorphic(std::atomic&, TraceCallback); + static void V8_PRESERVE_MOST + EnsureGCInfoIndexNonPolymorphic(std::atomic&, TraceCallback, + FinalizationCallback, NameCallback); + static void V8_PRESERVE_MOST EnsureGCInfoIndexNonPolymorphic( + std::atomic&, TraceCallback, FinalizationCallback); + static void V8_PRESERVE_MOST EnsureGCInfoIndexNonPolymorphic( + std::atomic&, TraceCallback, NameCallback); + static void V8_PRESERVE_MOST + EnsureGCInfoIndexNonPolymorphic(std::atomic&, TraceCallback); }; #define DISPATCH(is_polymorphic, has_finalizer, has_non_hidden_name, function) \ template \ struct EnsureGCInfoIndexTrait::EnsureGCInfoIndexTraitDispatch< \ T, is_polymorphic, has_finalizer, has_non_hidden_name> { \ - V8_INLINE GCInfoIndex \ - operator()(std::atomic& registered_index) { \ - return function; \ + V8_INLINE void operator()(std::atomic& registered_index) { \ + function; \ } \ }; @@ -143,9 +138,16 @@ struct GCInfoTrait final { static_assert(sizeof(T), "T must be fully defined"); static std::atomic registered_index; // Uses zero initialization. - const GCInfoIndex index = registered_index.load(std::memory_order_acquire); - return index ? index - : EnsureGCInfoIndexTrait::EnsureIndex(registered_index); + GCInfoIndex index = registered_index.load(std::memory_order_acquire); + if (V8_UNLIKELY(!index)) { + EnsureGCInfoIndexTrait::EnsureIndex(registered_index); + // Slow path call uses V8_PRESERVE_MOST which does not support return + // values (also preserves RAX). Avoid out parameter by just reloading the + // value here which at this point is guaranteed to be set. + index = registered_index.load(std::memory_order_acquire); + CPPGC_DCHECK(index != 0); + } + return index; } }; diff --git a/deps/v8/include/cppgc/internal/member-storage.h b/deps/v8/include/cppgc/internal/member-storage.h index 0eb6382070c4da..5c78e80f9bd87f 100644 --- a/deps/v8/include/cppgc/internal/member-storage.h +++ b/deps/v8/include/cppgc/internal/member-storage.h @@ -17,6 +17,11 @@ namespace cppgc { namespace internal { +enum class WriteBarrierSlotType { + kCompressed, + kUncompressed, +}; + #if defined(CPPGC_POINTER_COMPRESSION) #if defined(__clang__) @@ -64,6 +69,8 @@ class CageBaseGlobal final { class V8_TRIVIAL_ABI CompressedPointer final { public: using IntegralType = uint32_t; + static constexpr auto kWriteBarrierSlotType = + WriteBarrierSlotType::kCompressed; V8_INLINE CompressedPointer() : value_(0u) {} V8_INLINE explicit CompressedPointer(const void* ptr) @@ -173,6 +180,8 @@ class V8_TRIVIAL_ABI CompressedPointer final { class V8_TRIVIAL_ABI RawPointer final { public: using IntegralType = uintptr_t; + static constexpr auto kWriteBarrierSlotType = + WriteBarrierSlotType::kUncompressed; V8_INLINE RawPointer() : ptr_(nullptr) {} V8_INLINE explicit RawPointer(const void* ptr) : ptr_(ptr) {} @@ -225,9 +234,9 @@ class V8_TRIVIAL_ABI RawPointer final { }; #if defined(CPPGC_POINTER_COMPRESSION) -using MemberStorage = CompressedPointer; +using DefaultMemberStorage = CompressedPointer; #else // !defined(CPPGC_POINTER_COMPRESSION) -using MemberStorage = RawPointer; +using DefaultMemberStorage = RawPointer; #endif // !defined(CPPGC_POINTER_COMPRESSION) } // namespace internal diff --git a/deps/v8/include/cppgc/internal/pointer-policies.h b/deps/v8/include/cppgc/internal/pointer-policies.h index 8455b3df8196b4..06fa884f49f34b 100644 --- a/deps/v8/include/cppgc/internal/pointer-policies.h +++ b/deps/v8/include/cppgc/internal/pointer-policies.h @@ -33,20 +33,53 @@ struct DijkstraWriteBarrierPolicy { // barrier doesn't break the tri-color invariant. } + template V8_INLINE static void AssigningBarrier(const void* slot, const void* value) { +#ifdef CPPGC_SLIM_WRITE_BARRIER + if (V8_UNLIKELY(WriteBarrier::IsEnabled())) + WriteBarrier::CombinedWriteBarrierSlow(slot); +#else // !CPPGC_SLIM_WRITE_BARRIER WriteBarrier::Params params; const WriteBarrier::Type type = WriteBarrier::GetWriteBarrierType(slot, value, params); WriteBarrier(type, params, slot, value); +#endif // !CPPGC_SLIM_WRITE_BARRIER } + template + V8_INLINE static void AssigningBarrier(const void* slot, RawPointer storage) { + static_assert( + SlotType == WriteBarrierSlotType::kUncompressed, + "Assigning storages of Member and UncompressedMember is not supported"); +#ifdef CPPGC_SLIM_WRITE_BARRIER + if (V8_UNLIKELY(WriteBarrier::IsEnabled())) + WriteBarrier::CombinedWriteBarrierSlow(slot); +#else // !CPPGC_SLIM_WRITE_BARRIER + WriteBarrier::Params params; + const WriteBarrier::Type type = + WriteBarrier::GetWriteBarrierType(slot, storage, params); + WriteBarrier(type, params, slot, storage.Load()); +#endif // !CPPGC_SLIM_WRITE_BARRIER + } + +#if defined(CPPGC_POINTER_COMPRESSION) + template V8_INLINE static void AssigningBarrier(const void* slot, - MemberStorage storage) { + CompressedPointer storage) { + static_assert( + SlotType == WriteBarrierSlotType::kCompressed, + "Assigning storages of Member and UncompressedMember is not supported"); +#ifdef CPPGC_SLIM_WRITE_BARRIER + if (V8_UNLIKELY(WriteBarrier::IsEnabled())) + WriteBarrier::CombinedWriteBarrierSlow(slot); +#else // !CPPGC_SLIM_WRITE_BARRIER WriteBarrier::Params params; const WriteBarrier::Type type = WriteBarrier::GetWriteBarrierType(slot, storage, params); WriteBarrier(type, params, slot, storage.Load()); +#endif // !CPPGC_SLIM_WRITE_BARRIER } +#endif // defined(CPPGC_POINTER_COMPRESSION) private: V8_INLINE static void WriteBarrier(WriteBarrier::Type type, @@ -68,7 +101,9 @@ struct DijkstraWriteBarrierPolicy { struct NoWriteBarrierPolicy { V8_INLINE static void InitializingBarrier(const void*, const void*) {} + template V8_INLINE static void AssigningBarrier(const void*, const void*) {} + template V8_INLINE static void AssigningBarrier(const void*, MemberStorage) {} }; @@ -197,7 +232,8 @@ template class BasicPersistent; template + typename CheckingPolicy = DefaultMemberCheckingPolicy, + typename StorageType = DefaultMemberStorage> class BasicMember; } // namespace internal diff --git a/deps/v8/include/cppgc/internal/write-barrier.h b/deps/v8/include/cppgc/internal/write-barrier.h index 37bc5c973ef995..566724d30a0901 100644 --- a/deps/v8/include/cppgc/internal/write-barrier.h +++ b/deps/v8/include/cppgc/internal/write-barrier.h @@ -70,6 +70,7 @@ class V8_EXPORT WriteBarrier final { static V8_INLINE Type GetWriteBarrierType(const void* slot, const void* value, Params& params); // Returns the required write barrier for a given `slot` and `value`. + template static V8_INLINE Type GetWriteBarrierType(const void* slot, MemberStorage, Params& params); // Returns the required write barrier for a given `slot`. @@ -79,6 +80,15 @@ class V8_EXPORT WriteBarrier final { // Returns the required write barrier for a given `value`. static V8_INLINE Type GetWriteBarrierType(const void* value, Params& params); +#ifdef CPPGC_SLIM_WRITE_BARRIER + // A write barrier that combines `GenerationalBarrier()` and + // `DijkstraMarkingBarrier()`. We only pass a single parameter here to clobber + // as few registers as possible. + template + static V8_NOINLINE void V8_PRESERVE_MOST + CombinedWriteBarrierSlow(const void* slot); +#endif // CPPGC_SLIM_WRITE_BARRIER + static V8_INLINE void DijkstraMarkingBarrier(const Params& params, const void* object); static V8_INLINE void DijkstraMarkingBarrierRange( @@ -163,7 +173,8 @@ class V8_EXPORT WriteBarrierTypeForCagedHeapPolicy final { return ValueModeDispatch::Get(slot, value, params, callback); } - template + template static V8_INLINE WriteBarrier::Type Get(const void* slot, MemberStorage value, WriteBarrier::Params& params, HeapHandleCallback callback) { @@ -207,7 +218,7 @@ class V8_EXPORT WriteBarrierTypeForCagedHeapPolicy final { template <> struct WriteBarrierTypeForCagedHeapPolicy::ValueModeDispatch< WriteBarrier::ValueMode::kValuePresent> { - template + template static V8_INLINE WriteBarrier::Type Get(const void* slot, MemberStorage storage, WriteBarrier::Params& params, @@ -305,11 +316,9 @@ class V8_EXPORT WriteBarrierTypeForNonCagedHeapPolicy final { } template - static V8_INLINE WriteBarrier::Type Get(const void* slot, MemberStorage value, + static V8_INLINE WriteBarrier::Type Get(const void* slot, RawPointer value, WriteBarrier::Params& params, HeapHandleCallback callback) { - // `MemberStorage` will always be `RawPointer` for non-caged heap builds. - // Just convert to `void*` in this case. return ValueModeDispatch::Get(slot, value.Load(), params, callback); } @@ -383,6 +392,7 @@ WriteBarrier::Type WriteBarrier::GetWriteBarrierType( } // static +template WriteBarrier::Type WriteBarrier::GetWriteBarrierType( const void* slot, MemberStorage value, WriteBarrier::Params& params) { return WriteBarrierTypePolicy::Get(slot, value, diff --git a/deps/v8/include/cppgc/member.h b/deps/v8/include/cppgc/member.h index 9bc383634f18ea..b6382a02358744 100644 --- a/deps/v8/include/cppgc/member.h +++ b/deps/v8/include/cppgc/member.h @@ -28,13 +28,11 @@ namespace internal { // MemberBase always refers to the object as const object and defers to // BasicMember on casting to the right type as needed. +template class V8_TRIVIAL_ABI MemberBase { public: -#if defined(CPPGC_POINTER_COMPRESSION) - using RawStorage = CompressedPointer; -#else // !defined(CPPGC_POINTER_COMPRESSION) - using RawStorage = RawPointer; -#endif // !defined(CPPGC_POINTER_COMPRESSION) + using RawStorage = StorageType; + protected: struct AtomicInitializerTag {}; @@ -75,16 +73,19 @@ class V8_TRIVIAL_ABI MemberBase { // The basic class from which all Member classes are 'generated'. template -class V8_TRIVIAL_ABI BasicMember final : private MemberBase, + typename CheckingPolicy, typename StorageType> +class V8_TRIVIAL_ABI BasicMember final : private MemberBase, private CheckingPolicy { + using Base = MemberBase; + public: using PointeeType = T; + using RawStorage = typename Base::RawStorage; V8_INLINE constexpr BasicMember() = default; - V8_INLINE constexpr BasicMember(std::nullptr_t) {} // NOLINT - V8_INLINE BasicMember(SentinelPointer s) : MemberBase(s) {} // NOLINT - V8_INLINE BasicMember(T* raw) : MemberBase(raw) { // NOLINT + V8_INLINE constexpr BasicMember(std::nullptr_t) {} // NOLINT + V8_INLINE BasicMember(SentinelPointer s) : Base(s) {} // NOLINT + V8_INLINE BasicMember(T* raw) : Base(raw) { // NOLINT InitializingWriteBarrier(raw); this->CheckPointer(Get()); } @@ -94,13 +95,13 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase, // Atomic ctor. Using the AtomicInitializerTag forces BasicMember to // initialize using atomic assignments. This is required for preventing // data races with concurrent marking. - using AtomicInitializerTag = MemberBase::AtomicInitializerTag; + using AtomicInitializerTag = typename Base::AtomicInitializerTag; V8_INLINE BasicMember(std::nullptr_t, AtomicInitializerTag atomic) - : MemberBase(nullptr, atomic) {} + : Base(nullptr, atomic) {} V8_INLINE BasicMember(SentinelPointer s, AtomicInitializerTag atomic) - : MemberBase(s, atomic) {} + : Base(s, atomic) {} V8_INLINE BasicMember(T* raw, AtomicInitializerTag atomic) - : MemberBase(raw, atomic) { + : Base(raw, atomic) { InitializingWriteBarrier(raw); this->CheckPointer(Get()); } @@ -119,7 +120,7 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase, std::enable_if_t>* = nullptr> V8_INLINE BasicMember( // NOLINT const BasicMember& other) + OtherCheckingPolicy, StorageType>& other) : BasicMember(other.GetRawStorage()) {} template >* = nullptr> V8_INLINE BasicMember( // NOLINT const BasicMember& other) + OtherCheckingPolicy, StorageType>& other) : BasicMember(other.Get()) {} // Move ctor. @@ -142,8 +143,9 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase, template >* = nullptr> - V8_INLINE BasicMember(BasicMember&& other) noexcept + V8_INLINE BasicMember( + BasicMember&& other) noexcept : BasicMember(other.GetRawStorage()) { other.Clear(); } @@ -151,8 +153,9 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase, template >* = nullptr> - V8_INLINE BasicMember(BasicMember&& other) noexcept + V8_INLINE BasicMember( + BasicMember&& other) noexcept : BasicMember(other.Get()) { other.Clear(); } @@ -179,7 +182,7 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase, typename OtherCheckingPolicy> V8_INLINE BasicMember& operator=( const BasicMember& other) { + OtherCheckingPolicy, StorageType>& other) { if constexpr (internal::IsDecayedSameV) { return operator=(other.GetRawStorage()); } else { @@ -201,8 +204,8 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase, template V8_INLINE BasicMember& operator=( - BasicMember&& other) noexcept { + BasicMember&& other) noexcept { if constexpr (internal::IsDecayedSameV) { operator=(other.GetRawStorage()); } else { @@ -226,7 +229,7 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase, } V8_INLINE BasicMember& operator=(T* other) { - SetRawAtomic(other); + Base::SetRawAtomic(other); AssigningWriteBarrier(other); this->CheckPointer(Get()); return *this; @@ -237,20 +240,20 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase, return *this; } V8_INLINE BasicMember& operator=(SentinelPointer s) { - SetRawAtomic(s); + Base::SetRawAtomic(s); return *this; } template V8_INLINE void Swap(BasicMember& other) { + OtherCheckingPolicy, StorageType>& other) { auto tmp = GetRawStorage(); *this = other; other = tmp; } - V8_INLINE explicit operator bool() const { return !IsCleared(); } + V8_INLINE explicit operator bool() const { return !Base::IsCleared(); } V8_INLINE operator T*() const { return Get(); } V8_INLINE T* operator->() const { return Get(); } V8_INLINE T& operator*() const { return *Get(); } @@ -264,10 +267,12 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase, // The const_cast below removes the constness from MemberBase storage. The // following static_cast re-adds any constness if specified through the // user-visible template parameter T. - return static_cast(const_cast(MemberBase::GetRaw())); + return static_cast(const_cast(Base::GetRaw())); } - V8_INLINE void Clear() { SetRawStorageAtomic(RawStorage{}); } + V8_INLINE void Clear() { + Base::SetRawStorageAtomic(RawStorage{}); + } V8_INLINE T* Release() { T* result = Get(); @@ -276,41 +281,44 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase, } V8_INLINE const T** GetSlotForTesting() const { - return reinterpret_cast(GetRawSlot()); + return reinterpret_cast(Base::GetRawSlot()); } V8_INLINE RawStorage GetRawStorage() const { - return MemberBase::GetRawStorage(); + return Base::GetRawStorage(); } private: - V8_INLINE explicit BasicMember(RawStorage raw) : MemberBase(raw) { + V8_INLINE explicit BasicMember(RawStorage raw) : Base(raw) { InitializingWriteBarrier(Get()); this->CheckPointer(Get()); } V8_INLINE BasicMember& operator=(RawStorage other) { - SetRawStorageAtomic(other); + Base::SetRawStorageAtomic(other); AssigningWriteBarrier(); this->CheckPointer(Get()); return *this; } V8_INLINE const T* GetRawAtomic() const { - return static_cast(MemberBase::GetRawAtomic()); + return static_cast(Base::GetRawAtomic()); } V8_INLINE void InitializingWriteBarrier(T* value) const { - WriteBarrierPolicy::InitializingBarrier(GetRawSlot(), value); + WriteBarrierPolicy::InitializingBarrier(Base::GetRawSlot(), value); } V8_INLINE void AssigningWriteBarrier(T* value) const { - WriteBarrierPolicy::AssigningBarrier(GetRawSlot(), value); + WriteBarrierPolicy::template AssigningBarrier< + StorageType::kWriteBarrierSlotType>(Base::GetRawSlot(), value); } V8_INLINE void AssigningWriteBarrier() const { - WriteBarrierPolicy::AssigningBarrier(GetRawSlot(), GetRawStorage()); + WriteBarrierPolicy::template AssigningBarrier< + StorageType::kWriteBarrierSlotType>(Base::GetRawSlot(), + Base::GetRawStorage()); } - V8_INLINE void ClearFromGC() const { MemberBase::ClearFromGC(); } + V8_INLINE void ClearFromGC() const { Base::ClearFromGC(); } V8_INLINE T* GetFromGC() const { return Get(); } @@ -319,19 +327,20 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase, template friend struct cppgc::TraceTrait; template + typename CheckingPolicy1, typename StorageType1> friend class BasicMember; }; // Member equality operators. template + typename WriteBarrierPolicy2, typename CheckingPolicy2, + typename StorageType> V8_INLINE bool operator==( - const BasicMember& - member1, - const BasicMember& - member2) { + const BasicMember& member1, + const BasicMember& member2) { if constexpr (internal::IsDecayedSameV) { // Check compressed pointers if types are the same. return member1.GetRawStorage() == member2.GetRawStorage(); @@ -345,31 +354,32 @@ V8_INLINE bool operator==( template + typename WriteBarrierPolicy2, typename CheckingPolicy2, + typename StorageType> V8_INLINE bool operator!=( - const BasicMember& - member1, - const BasicMember& - member2) { + const BasicMember& member1, + const BasicMember& member2) { return !(member1 == member2); } // Equality with raw pointers. template -V8_INLINE bool operator==(const BasicMember& member, - U* raw) { + typename CheckingPolicy, typename StorageType, typename U> +V8_INLINE bool operator==( + const BasicMember& member, + U* raw) { // Never allow comparison with erased pointers. static_assert(!internal::IsDecayedSameV); if constexpr (internal::IsDecayedSameV) { // Check compressed pointers if types are the same. - return member.GetRawStorage() == MemberBase::RawStorage(raw); + return member.GetRawStorage() == StorageType(raw); } else if constexpr (internal::IsStrictlyBaseOfV) { // Cast the raw pointer to T, which may adjust the pointer. - return member.GetRawStorage() == - MemberBase::RawStorage(static_cast(raw)); + return member.GetRawStorage() == StorageType(static_cast(raw)); } else { // Otherwise, decompressed the member. return member.Get() == raw; @@ -377,104 +387,112 @@ V8_INLINE bool operator==(const BasicMember -V8_INLINE bool operator!=(const BasicMember& member, - U* raw) { + typename CheckingPolicy, typename StorageType, typename U> +V8_INLINE bool operator!=( + const BasicMember& member, + U* raw) { return !(member == raw); } template -V8_INLINE bool operator==(T* raw, - const BasicMember& member) { + typename WriteBarrierPolicy, typename CheckingPolicy, + typename StorageType> +V8_INLINE bool operator==( + T* raw, const BasicMember& member) { return member == raw; } template -V8_INLINE bool operator!=(T* raw, - const BasicMember& member) { + typename WriteBarrierPolicy, typename CheckingPolicy, + typename StorageType> +V8_INLINE bool operator!=( + T* raw, const BasicMember& member) { return !(raw == member); } // Equality with sentinel. template -V8_INLINE bool operator==(const BasicMember& member, - SentinelPointer) { + typename CheckingPolicy, typename StorageType> +V8_INLINE bool operator==( + const BasicMember& member, + SentinelPointer) { return member.GetRawStorage().IsSentinel(); } template -V8_INLINE bool operator!=(const BasicMember& member, - SentinelPointer s) { + typename CheckingPolicy, typename StorageType> +V8_INLINE bool operator!=( + const BasicMember& member, + SentinelPointer s) { return !(member == s); } template -V8_INLINE bool operator==(SentinelPointer s, - const BasicMember& member) { + typename CheckingPolicy, typename StorageType> +V8_INLINE bool operator==( + SentinelPointer s, const BasicMember& member) { return member == s; } template -V8_INLINE bool operator!=(SentinelPointer s, - const BasicMember& member) { + typename CheckingPolicy, typename StorageType> +V8_INLINE bool operator!=( + SentinelPointer s, const BasicMember& member) { return !(s == member); } // Equality with nullptr. template -V8_INLINE bool operator==(const BasicMember& member, - std::nullptr_t) { + typename CheckingPolicy, typename StorageType> +V8_INLINE bool operator==( + const BasicMember& member, + std::nullptr_t) { return !static_cast(member); } template -V8_INLINE bool operator!=(const BasicMember& member, - std::nullptr_t n) { + typename CheckingPolicy, typename StorageType> +V8_INLINE bool operator!=( + const BasicMember& member, + std::nullptr_t n) { return !(member == n); } template -V8_INLINE bool operator==(std::nullptr_t n, - const BasicMember& member) { + typename CheckingPolicy, typename StorageType> +V8_INLINE bool operator==( + std::nullptr_t n, const BasicMember& member) { return member == n; } template -V8_INLINE bool operator!=(std::nullptr_t n, - const BasicMember& member) { + typename CheckingPolicy, typename StorageType> +V8_INLINE bool operator!=( + std::nullptr_t n, const BasicMember& member) { return !(n == member); } // Relational operators. template + typename WriteBarrierPolicy2, typename CheckingPolicy2, + typename StorageType> V8_INLINE bool operator<( - const BasicMember& - member1, - const BasicMember& - member2) { + const BasicMember& member1, + const BasicMember& member2) { static_assert( internal::IsDecayedSameV, "Comparison works only for same pointer type modulo cv-qualifiers"); @@ -483,12 +501,13 @@ V8_INLINE bool operator<( template + typename WriteBarrierPolicy2, typename CheckingPolicy2, + typename StorageType> V8_INLINE bool operator<=( - const BasicMember& - member1, - const BasicMember& - member2) { + const BasicMember& member1, + const BasicMember& member2) { static_assert( internal::IsDecayedSameV, "Comparison works only for same pointer type modulo cv-qualifiers"); @@ -497,12 +516,13 @@ V8_INLINE bool operator<=( template + typename WriteBarrierPolicy2, typename CheckingPolicy2, + typename StorageType> V8_INLINE bool operator>( - const BasicMember& - member1, - const BasicMember& - member2) { + const BasicMember& member1, + const BasicMember& member2) { static_assert( internal::IsDecayedSameV, "Comparison works only for same pointer type modulo cv-qualifiers"); @@ -511,21 +531,23 @@ V8_INLINE bool operator>( template + typename WriteBarrierPolicy2, typename CheckingPolicy2, + typename StorageType> V8_INLINE bool operator>=( - const BasicMember& - member1, - const BasicMember& - member2) { + const BasicMember& member1, + const BasicMember& member2) { static_assert( internal::IsDecayedSameV, "Comparison works only for same pointer type modulo cv-qualifiers"); return member1.GetRawStorage() >= member2.GetRawStorage(); } -template -struct IsWeak< - internal::BasicMember> +template +struct IsWeak> : std::true_type {}; } // namespace internal @@ -536,8 +558,9 @@ struct IsWeak< * trace method. */ template -using Member = internal::BasicMember; +using Member = internal::BasicMember< + T, internal::StrongMemberTag, internal::DijkstraWriteBarrierPolicy, + internal::DefaultMemberCheckingPolicy, internal::DefaultMemberStorage>; /** * WeakMember is similar to Member in that it is used to point to other garbage @@ -548,8 +571,9 @@ using Member = internal::BasicMember -using WeakMember = internal::BasicMember; +using WeakMember = internal::BasicMember< + T, internal::WeakMemberTag, internal::DijkstraWriteBarrierPolicy, + internal::DefaultMemberCheckingPolicy, internal::DefaultMemberStorage>; /** * UntracedMember is a pointer to an on-heap object that is not traced for some @@ -558,8 +582,22 @@ using WeakMember = internal::BasicMember -using UntracedMember = internal::BasicMember; +using UntracedMember = internal::BasicMember< + T, internal::UntracedMemberTag, internal::NoWriteBarrierPolicy, + internal::DefaultMemberCheckingPolicy, internal::DefaultMemberStorage>; + +namespace subtle { + +/** + * UncompressedMember. Use with care in hot paths that would otherwise cause + * many decompression cycles. + */ +template +using UncompressedMember = internal::BasicMember< + T, internal::StrongMemberTag, internal::DijkstraWriteBarrierPolicy, + internal::DefaultMemberCheckingPolicy, internal::RawPointer>; + +} // namespace subtle } // namespace cppgc diff --git a/deps/v8/include/cppgc/persistent.h b/deps/v8/include/cppgc/persistent.h index 3a66ccc0864328..709f3fd6ab0996 100644 --- a/deps/v8/include/cppgc/persistent.h +++ b/deps/v8/include/cppgc/persistent.h @@ -114,11 +114,12 @@ class BasicPersistent final : public PersistentBase, // Constructor from member. template ::value>> - BasicPersistent( - const internal::BasicMember& member, - const SourceLocation& loc = SourceLocation::Current()) + BasicPersistent(const internal::BasicMember< + U, MemberBarrierPolicy, MemberWeaknessTag, + MemberCheckingPolicy, MemberStorageType>& member, + const SourceLocation& loc = SourceLocation::Current()) : BasicPersistent(member.Get(), loc) {} ~BasicPersistent() { Clear(); } @@ -154,10 +155,12 @@ class BasicPersistent final : public PersistentBase, // Assignment from member. template ::value>> BasicPersistent& operator=( const internal::BasicMember& member) { + MemberCheckingPolicy, MemberStorageType>& + member) { return operator=(member.Get()); } @@ -286,36 +289,39 @@ bool operator!=(const BasicPersistent + typename MemberWeaknessTag, typename MemberCheckingPolicy, + typename MemberStorageType> bool operator==( const BasicPersistent& p, const BasicMember& m) { + MemberCheckingPolicy, MemberStorageType>& m) { return p.Get() == m.Get(); } template + typename MemberWeaknessTag, typename MemberCheckingPolicy, + typename MemberStorageType> bool operator!=( const BasicPersistent& p, const BasicMember& m) { + MemberCheckingPolicy, MemberStorageType>& m) { return !(p == m); } template + typename MemberStorageType, typename T2, + typename PersistentWeaknessPolicy, typename PersistentLocationPolicy, + typename PersistentCheckingPolicy> bool operator==( const BasicMember& m, + MemberCheckingPolicy, MemberStorageType>& m, const BasicPersistent& p) { @@ -324,11 +330,12 @@ bool operator==( template + typename MemberStorageType, typename T2, + typename PersistentWeaknessPolicy, typename PersistentLocationPolicy, + typename PersistentCheckingPolicy> bool operator!=( const BasicMember& m, + MemberCheckingPolicy, MemberStorageType>& m, const BasicPersistent& p) { diff --git a/deps/v8/include/cppgc/type-traits.h b/deps/v8/include/cppgc/type-traits.h index 2f499e6886b929..4651435390058f 100644 --- a/deps/v8/include/cppgc/type-traits.h +++ b/deps/v8/include/cppgc/type-traits.h @@ -16,7 +16,7 @@ class Visitor; namespace internal { template + typename CheckingPolicy, typename StorageType> class BasicMember; struct DijkstraWriteBarrierPolicy; struct NoWriteBarrierPolicy; @@ -126,9 +126,10 @@ template struct IsSubclassOfBasicMemberTemplate { private: - template + template static std::true_type SubclassCheck( - BasicMember*); + BasicMember*); static std::false_type SubclassCheck(...); public: diff --git a/deps/v8/include/cppgc/visitor.h b/deps/v8/include/cppgc/visitor.h index f7ebc1d01f566e..9b135e39a0be1c 100644 --- a/deps/v8/include/cppgc/visitor.h +++ b/deps/v8/include/cppgc/visitor.h @@ -99,6 +99,20 @@ class V8_EXPORT Visitor { &HandleWeak>, &weak_member); } +#if defined(CPPGC_POINTER_COMPRESSION) + /** + * Trace method for UncompressedMember. + * + * \param member UncompressedMember reference retaining an object. + */ + template + void Trace(const subtle::UncompressedMember& member) { + const T* value = member.GetRawAtomic(); + CPPGC_DCHECK(value != kSentinelPointer); + TraceImpl(value); + } +#endif // defined(CPPGC_POINTER_COMPRESSION) + /** * Trace method for inlined objects that are not allocated themselves but * otherwise follow managed heap layout and have a Trace() method. @@ -229,7 +243,8 @@ class V8_EXPORT Visitor { } /** - * Trace method for retaining containers weakly. + * Trace method for retaining containers weakly. Note that weak containers + * should emit write barriers. * * \param object reference to the container. * \param callback to be invoked. diff --git a/deps/v8/include/js_protocol.pdl b/deps/v8/include/js_protocol.pdl index 6efcf787854dac..6285d9b6f24f63 100644 --- a/deps/v8/include/js_protocol.pdl +++ b/deps/v8/include/js_protocol.pdl @@ -511,6 +511,7 @@ domain Debugger CompileError BlockedByActiveGenerator BlockedByActiveFunction + BlockedByTopLevelEsModuleChange # Exception details if any. Only present when `status` is `CompileError`. optional Runtime.ExceptionDetails exceptionDetails @@ -1402,6 +1403,13 @@ domain Runtime optional string objectGroup # Whether to throw an exception if side effect cannot be ruled out during evaluation. experimental optional boolean throwOnSideEffect + # An alternative way to specify the execution context to call function on. + # Compared to contextId that may be reused across processes, this is guaranteed to be + # system-unique, so it can be used to prevent accidental function call + # in context different than intended (e.g. as a result of navigation across process + # boundaries). + # This is mutually exclusive with `executionContextId`. + experimental optional string uniqueContextId # Whether the result should contain `webDriverValue`, serialized according to # https://w3c.github.io/webdriver-bidi. This is mutually exclusive with `returnByValue`, but # resulting `objectId` is still provided. @@ -1734,7 +1742,9 @@ domain Runtime event executionContextDestroyed parameters # Id of the destroyed context - ExecutionContextId executionContextId + deprecated ExecutionContextId executionContextId + # Unique Id of the destroyed context + experimental string executionContextUniqueId # Issued when all executionContexts were cleared in browser event executionContextsCleared diff --git a/deps/v8/include/libplatform/v8-tracing.h b/deps/v8/include/libplatform/v8-tracing.h index 12489327c54210..6039a9c520b6a3 100644 --- a/deps/v8/include/libplatform/v8-tracing.h +++ b/deps/v8/include/libplatform/v8-tracing.h @@ -282,12 +282,12 @@ class V8_PLATFORM_EXPORT TracingController const char* name, uint64_t handle) override; static const char* GetCategoryGroupName(const uint8_t* category_enabled_flag); -#endif // !defined(V8_USE_PERFETTO) void AddTraceStateObserver( v8::TracingController::TraceStateObserver* observer) override; void RemoveTraceStateObserver( v8::TracingController::TraceStateObserver* observer) override; +#endif // !defined(V8_USE_PERFETTO) void StartTracing(TraceConfig* trace_config); void StopTracing(); @@ -307,7 +307,6 @@ class V8_PLATFORM_EXPORT TracingController std::unique_ptr mutex_; std::unique_ptr trace_config_; std::atomic_bool recording_{false}; - std::unordered_set observers_; #if defined(V8_USE_PERFETTO) std::ostream* output_stream_ = nullptr; @@ -316,6 +315,7 @@ class V8_PLATFORM_EXPORT TracingController TraceEventListener* listener_for_testing_ = nullptr; std::unique_ptr tracing_session_; #else // !defined(V8_USE_PERFETTO) + std::unordered_set observers_; std::unique_ptr trace_buffer_; #endif // !defined(V8_USE_PERFETTO) diff --git a/deps/v8/include/v8-array-buffer.h b/deps/v8/include/v8-array-buffer.h index 841bd02a793333..804fc42c4b56dd 100644 --- a/deps/v8/include/v8-array-buffer.h +++ b/deps/v8/include/v8-array-buffer.h @@ -53,12 +53,28 @@ class V8_EXPORT BackingStore : public v8::internal::BackingStoreBase { */ size_t ByteLength() const; + /** + * The maximum length (in bytes) that this backing store may grow to. + * + * If this backing store was created for a resizable ArrayBuffer or a growable + * SharedArrayBuffer, it is >= ByteLength(). Otherwise it is == + * ByteLength(). + */ + size_t MaxByteLength() const; + /** * Indicates whether the backing store was created for an ArrayBuffer or * a SharedArrayBuffer. */ bool IsShared() const; + /** + * Indicates whether the backing store was created for a resizable ArrayBuffer + * or a growable SharedArrayBuffer, and thus may be resized by user JavaScript + * code. + */ + bool IsResizableByUserJavaScript() const; + /** * Prevent implicit instantiation of operator delete with size_t argument. * The size_t argument would be incorrect because ptr points to the @@ -189,6 +205,11 @@ class V8_EXPORT ArrayBuffer : public Object { */ size_t ByteLength() const; + /** + * Maximum length in bytes. + */ + size_t MaxByteLength() const; + /** * Create a new ArrayBuffer. Allocate |byte_length| bytes. * Allocated memory will be owned by a created ArrayBuffer and @@ -235,6 +256,21 @@ class V8_EXPORT ArrayBuffer : public Object { void* data, size_t byte_length, v8::BackingStore::DeleterCallback deleter, void* deleter_data); + /** + * Returns a new resizable standalone BackingStore that is allocated using the + * array buffer allocator of the isolate. The result can be later passed to + * ArrayBuffer::New. + * + * |byte_length| must be <= |max_byte_length|. + * + * This function is usable without an isolate. Unlike |NewBackingStore| calls + * with an isolate, GCs cannot be triggered, and there are no + * retries. Allocation failure will cause the function to crash with an + * out-of-memory error. + */ + static std::unique_ptr NewResizableBackingStore( + size_t byte_length, size_t max_byte_length); + /** * Returns true if this ArrayBuffer may be detached. */ @@ -392,6 +428,11 @@ class V8_EXPORT SharedArrayBuffer : public Object { */ size_t ByteLength() const; + /** + * Maximum length in bytes. + */ + size_t MaxByteLength() const; + /** * Create a new SharedArrayBuffer. Allocate |byte_length| bytes. * Allocated memory will be owned by a created SharedArrayBuffer and diff --git a/deps/v8/include/v8-callbacks.h b/deps/v8/include/v8-callbacks.h index 0ffdfb6656fc64..f3e96c37066e9f 100644 --- a/deps/v8/include/v8-callbacks.h +++ b/deps/v8/include/v8-callbacks.h @@ -328,6 +328,10 @@ using WasmSimdEnabledCallback = bool (*)(Local context); // --- Callback for checking if WebAssembly exceptions are enabled --- using WasmExceptionsEnabledCallback = bool (*)(Local context); +// --- Callback for checking if WebAssembly GC is enabled --- +// If the callback returns true, it will also enable Wasm stringrefs. +using WasmGCEnabledCallback = bool (*)(Local context); + // --- Callback for checking if the SharedArrayBuffer constructor is enabled --- using SharedArrayBufferConstructorEnabledCallback = bool (*)(Local context); diff --git a/deps/v8/include/v8-context.h b/deps/v8/include/v8-context.h index 3ce0eb0af38c67..d5df99a3506deb 100644 --- a/deps/v8/include/v8-context.h +++ b/deps/v8/include/v8-context.h @@ -9,6 +9,7 @@ #include "v8-data.h" // NOLINT(build/include_directory) #include "v8-local-handle.h" // NOLINT(build/include_directory) +#include "v8-maybe.h" // NOLINT(build/include_directory) #include "v8-snapshot.h" // NOLINT(build/include_directory) #include "v8config.h" // NOLINT(build/include_directory) @@ -163,6 +164,13 @@ class V8_EXPORT Context : public Data { */ void Exit(); + /** + * Attempts to recursively freeze all objects reachable from this context. + * Some objects (generators, iterators, non-const closures) can not be frozen + * and will cause this method to throw an error. + */ + Maybe DeepFreeze(); + /** Returns the isolate associated with a current context. */ Isolate* GetIsolate(); @@ -365,13 +373,18 @@ Local Context::GetEmbedderData(int index) { #ifdef V8_COMPRESS_POINTERS // We read the full pointer value and then decompress it in order to avoid // dealing with potential endiannes issues. - value = - I::DecompressTaggedAnyField(embedder_data, static_cast(value)); + value = I::DecompressTaggedField(embedder_data, static_cast(value)); #endif + +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + return Local(reinterpret_cast(value)); +#else internal::Isolate* isolate = internal::IsolateFromNeverReadOnlySpaceObject( *reinterpret_cast(this)); A* result = HandleScope::CreateHandle(isolate, value); return Local(reinterpret_cast(result)); +#endif + #else return SlowGetEmbedderData(index); #endif @@ -381,7 +394,7 @@ void* Context::GetAlignedPointerFromEmbedderData(int index) { #if !defined(V8_ENABLE_CHECKS) using A = internal::Address; using I = internal::Internals; - A ctx = *reinterpret_cast(this); + A ctx = internal::ValueHelper::ValueToAddress(this); A embedder_data = I::ReadTaggedPointerField(ctx, I::kNativeContextEmbedderDataOffset); int value_offset = I::kEmbedderDataArrayHeaderSize + diff --git a/deps/v8/include/v8-cppgc.h b/deps/v8/include/v8-cppgc.h index 3a6582cd258496..4a457027c9f76b 100644 --- a/deps/v8/include/v8-cppgc.h +++ b/deps/v8/include/v8-cppgc.h @@ -77,6 +77,12 @@ struct WrapperDescriptor final { }; struct V8_EXPORT CppHeapCreateParams { + CppHeapCreateParams( + std::vector> custom_spaces, + WrapperDescriptor wrapper_descriptor) + : custom_spaces(std::move(custom_spaces)), + wrapper_descriptor(wrapper_descriptor) {} + CppHeapCreateParams(const CppHeapCreateParams&) = delete; CppHeapCreateParams& operator=(const CppHeapCreateParams&) = delete; diff --git a/deps/v8/include/v8-embedder-heap.h b/deps/v8/include/v8-embedder-heap.h index f994cdfdf34376..9e2e3ef58c4341 100644 --- a/deps/v8/include/v8-embedder-heap.h +++ b/deps/v8/include/v8-embedder-heap.h @@ -5,27 +5,14 @@ #ifndef INCLUDE_V8_EMBEDDER_HEAP_H_ #define INCLUDE_V8_EMBEDDER_HEAP_H_ -#include -#include - -#include -#include - -#include "cppgc/common.h" -#include "v8-local-handle.h" // NOLINT(build/include_directory) #include "v8-traced-handle.h" // NOLINT(build/include_directory) #include "v8config.h" // NOLINT(build/include_directory) namespace v8 { -class Data; class Isolate; class Value; -namespace internal { -class LocalEmbedderHeapTracer; -} // namespace internal - /** * Handler for embedder roots on non-unified heap garbage collections. */ @@ -62,162 +49,6 @@ class V8_EXPORT EmbedderRootsHandler { virtual void ResetRoot(const v8::TracedReference& handle) = 0; }; -/** - * Interface for tracing through the embedder heap. During a V8 garbage - * collection, V8 collects hidden fields of all potential wrappers, and at the - * end of its marking phase iterates the collection and asks the embedder to - * trace through its heap and use reporter to report each JavaScript object - * reachable from any of the given wrappers. - */ -class V8_EXPORT -// GCC doesn't like combining __attribute__(()) with [[deprecated]]. -#ifdef __clang__ -V8_DEPRECATED("Use CppHeap when working with v8::TracedReference.") -#endif // __clang__ - EmbedderHeapTracer { - public: - using EmbedderStackState = cppgc::EmbedderStackState; - - enum TraceFlags : uint64_t { - kNoFlags = 0, - kReduceMemory = 1 << 0, - kForced = 1 << 2, - }; - - /** - * Interface for iterating through |TracedReference| handles. - */ - class V8_EXPORT TracedGlobalHandleVisitor { - public: - virtual ~TracedGlobalHandleVisitor() = default; - virtual void VisitTracedReference(const TracedReference& handle) {} - }; - - /** - * Summary of a garbage collection cycle. See |TraceEpilogue| on how the - * summary is reported. - */ - struct TraceSummary { - /** - * Time spent managing the retained memory in milliseconds. This can e.g. - * include the time tracing through objects in the embedder. - */ - double time = 0.0; - - /** - * Memory retained by the embedder through the |EmbedderHeapTracer| - * mechanism in bytes. - */ - size_t allocated_size = 0; - }; - - virtual ~EmbedderHeapTracer() = default; - - /** - * Iterates all |TracedReference| handles created for the |v8::Isolate| the - * tracer is attached to. - */ - void IterateTracedGlobalHandles(TracedGlobalHandleVisitor* visitor); - - /** - * Called by the embedder to set the start of the stack which is e.g. used by - * V8 to determine whether handles are used from stack or heap. - */ - void SetStackStart(void* stack_start); - - /** - * Called by v8 to register internal fields of found wrappers. - * - * The embedder is expected to store them somewhere and trace reachable - * wrappers from them when called through |AdvanceTracing|. - */ - virtual void RegisterV8References( - const std::vector>& embedder_fields) = 0; - - void RegisterEmbedderReference(const BasicTracedReference& ref); - - /** - * Called at the beginning of a GC cycle. - */ - virtual void TracePrologue(TraceFlags flags) {} - - /** - * Called to advance tracing in the embedder. - * - * The embedder is expected to trace its heap starting from wrappers reported - * by RegisterV8References method, and report back all reachable wrappers. - * Furthermore, the embedder is expected to stop tracing by the given - * deadline. A deadline of infinity means that tracing should be finished. - * - * Returns |true| if tracing is done, and false otherwise. - */ - virtual bool AdvanceTracing(double deadline_in_ms) = 0; - - /* - * Returns true if there no more tracing work to be done (see AdvanceTracing) - * and false otherwise. - */ - virtual bool IsTracingDone() = 0; - - /** - * Called at the end of a GC cycle. - * - * Note that allocation is *not* allowed within |TraceEpilogue|. Can be - * overriden to fill a |TraceSummary| that is used by V8 to schedule future - * garbage collections. - */ - virtual void TraceEpilogue(TraceSummary* trace_summary) {} - - /** - * Called upon entering the final marking pause. No more incremental marking - * steps will follow this call. - */ - virtual void EnterFinalPause(EmbedderStackState stack_state) = 0; - - /* - * Called by the embedder to request immediate finalization of the currently - * running tracing phase that has been started with TracePrologue and not - * yet finished with TraceEpilogue. - * - * Will be a noop when currently not in tracing. - * - * This is an experimental feature. - */ - void FinalizeTracing(); - - /** - * See documentation on EmbedderRootsHandler. - */ - virtual bool IsRootForNonTracingGC( - const v8::TracedReference& handle); - - /** - * See documentation on EmbedderRootsHandler. - */ - virtual void ResetHandleInNonTracingGC( - const v8::TracedReference& handle); - - /* - * Called by the embedder to signal newly allocated or freed memory. Not bound - * to tracing phases. Embedders should trade off when increments are reported - * as V8 may consult global heuristics on whether to trigger garbage - * collection on this change. - */ - void IncreaseAllocatedSize(size_t bytes); - void DecreaseAllocatedSize(size_t bytes); - - /* - * Returns the v8::Isolate this tracer is attached too and |nullptr| if it - * is not attached to any v8::Isolate. - */ - v8::Isolate* isolate() const { return v8_isolate_; } - - protected: - v8::Isolate* v8_isolate_ = nullptr; - - friend class internal::LocalEmbedderHeapTracer; -}; - } // namespace v8 #endif // INCLUDE_V8_EMBEDDER_HEAP_H_ diff --git a/deps/v8/include/v8-fast-api-calls.h b/deps/v8/include/v8-fast-api-calls.h index 9ea43fe2535397..0fe7cd2489b05e 100644 --- a/deps/v8/include/v8-fast-api-calls.h +++ b/deps/v8/include/v8-fast-api-calls.h @@ -247,6 +247,7 @@ class CTypeInfo { kUint64, kFloat32, kFloat64, + kPointer, kV8Value, kSeqOneByteString, kApiObject, // This will be deprecated once all users have @@ -435,6 +436,7 @@ struct AnyCType { uint64_t uint64_value; float float_value; double double_value; + void* pointer_value; Local object_value; Local sequence_value; const FastApiTypedArray* uint8_ta_value; @@ -620,6 +622,7 @@ class CFunctionInfoImpl : public CFunctionInfo { kReturnType == CTypeInfo::Type::kUint32 || kReturnType == CTypeInfo::Type::kFloat32 || kReturnType == CTypeInfo::Type::kFloat64 || + kReturnType == CTypeInfo::Type::kPointer || kReturnType == CTypeInfo::Type::kAny, "64-bit int, string and api object values are not currently " "supported return types."); @@ -658,13 +661,14 @@ struct CTypeInfoTraits {}; #define PRIMITIVE_C_TYPES(V) \ V(bool, kBool) \ + V(uint8_t, kUint8) \ V(int32_t, kInt32) \ V(uint32_t, kUint32) \ V(int64_t, kInt64) \ V(uint64_t, kUint64) \ V(float, kFloat32) \ V(double, kFloat64) \ - V(uint8_t, kUint8) + V(void*, kPointer) // Same as above, but includes deprecated types for compatibility. #define ALL_C_TYPES(V) \ @@ -698,13 +702,13 @@ PRIMITIVE_C_TYPES(DEFINE_TYPE_INFO_TRAITS) }; #define TYPED_ARRAY_C_TYPES(V) \ + V(uint8_t, kUint8) \ V(int32_t, kInt32) \ V(uint32_t, kUint32) \ V(int64_t, kInt64) \ V(uint64_t, kUint64) \ V(float, kFloat32) \ - V(double, kFloat64) \ - V(uint8_t, kUint8) + V(double, kFloat64) TYPED_ARRAY_C_TYPES(SPECIALIZE_GET_TYPE_INFO_HELPER_FOR_TA) diff --git a/deps/v8/include/v8-function-callback.h b/deps/v8/include/v8-function-callback.h index 2adff99b1cbb82..5db07c41f1795a 100644 --- a/deps/v8/include/v8-function-callback.h +++ b/deps/v8/include/v8-function-callback.h @@ -285,7 +285,7 @@ void ReturnValue::Set(const Local handle) { if (V8_UNLIKELY(handle.IsEmpty())) { *value_ = GetDefaultValue(); } else { - *value_ = *reinterpret_cast(*handle); + *value_ = handle.AddressFromSlot(); } } @@ -387,31 +387,32 @@ FunctionCallbackInfo::FunctionCallbackInfo(internal::Address* implicit_args, template Local FunctionCallbackInfo::operator[](int i) const { // values_ points to the first argument (not the receiver). - if (i < 0 || length_ <= i) return Local(*Undefined(GetIsolate())); - return Local(reinterpret_cast(values_ + i)); + if (i < 0 || length_ <= i) return Local::New(*Undefined(GetIsolate())); + return Local::New(reinterpret_cast(values_ + i)); } template Local FunctionCallbackInfo::This() const { // values_ points to the first argument (not the receiver). - return Local(reinterpret_cast(values_ - 1)); + return Local::New(reinterpret_cast(values_ - 1)); } template Local FunctionCallbackInfo::Holder() const { - return Local( + return Local::New( reinterpret_cast(&implicit_args_[kHolderIndex])); } template Local FunctionCallbackInfo::NewTarget() const { - return Local( + return Local::New( reinterpret_cast(&implicit_args_[kNewTargetIndex])); } template Local FunctionCallbackInfo::Data() const { - return Local(reinterpret_cast(&implicit_args_[kDataIndex])); + return Local::New( + reinterpret_cast(&implicit_args_[kDataIndex])); } template @@ -441,17 +442,17 @@ Isolate* PropertyCallbackInfo::GetIsolate() const { template Local PropertyCallbackInfo::Data() const { - return Local(reinterpret_cast(&args_[kDataIndex])); + return Local::New(reinterpret_cast(&args_[kDataIndex])); } template Local PropertyCallbackInfo::This() const { - return Local(reinterpret_cast(&args_[kThisIndex])); + return Local::New(reinterpret_cast(&args_[kThisIndex])); } template Local PropertyCallbackInfo::Holder() const { - return Local(reinterpret_cast(&args_[kHolderIndex])); + return Local::New(reinterpret_cast(&args_[kHolderIndex])); } template diff --git a/deps/v8/include/v8-inspector.h b/deps/v8/include/v8-inspector.h index aa5a044afb61c4..563ad196d6e607 100644 --- a/deps/v8/include/v8-inspector.h +++ b/deps/v8/include/v8-inspector.h @@ -32,19 +32,19 @@ namespace Debugger { namespace API { class SearchMatch; } -} +} // namespace Debugger namespace Runtime { namespace API { class RemoteObject; class StackTrace; class StackTraceId; -} -} +} // namespace API +} // namespace Runtime namespace Schema { namespace API { class Domain; } -} +} // namespace Schema } // namespace protocol class V8_EXPORT StringView { @@ -134,6 +134,13 @@ class V8_EXPORT V8DebuggerId { int64_t m_second = 0; }; +struct V8_EXPORT V8StackFrame { + StringView sourceURL; + StringView functionName; + int lineNumber; + int columnNumber; +}; + class V8_EXPORT V8StackTrace { public: virtual StringView firstNonEmptySourceURL() const = 0; @@ -151,6 +158,8 @@ class V8_EXPORT V8StackTrace { // Safe to pass between threads, drops async chain. virtual std::unique_ptr clone() = 0; + + virtual std::vector frames() const = 0; }; class V8_EXPORT V8InspectorSession { @@ -203,6 +212,9 @@ class V8_EXPORT V8InspectorSession { std::unique_ptr* objectGroup) = 0; virtual void releaseObjectGroup(StringView) = 0; virtual void triggerPreciseCoverageDeltaUpdate(StringView occasion) = 0; + + // Prepare for shutdown (disables debugger pausing, etc.). + virtual void stop() = 0; }; class V8_EXPORT WebDriverValue { @@ -365,9 +377,12 @@ class V8_EXPORT V8Inspector { virtual void flushProtocolNotifications() = 0; }; enum ClientTrustLevel { kUntrusted, kFullyTrusted }; + enum SessionPauseState { kWaitingForDebugger, kNotWaitingForDebugger }; + // TODO(chromium:1352175): remove default value once downstream change lands. virtual std::unique_ptr connect( int contextGroupId, Channel*, StringView state, - ClientTrustLevel client_trust_level) { + ClientTrustLevel client_trust_level, + SessionPauseState = kNotWaitingForDebugger) { return nullptr; } diff --git a/deps/v8/include/v8-internal.h b/deps/v8/include/v8-internal.h index a4b8ee0824d81d..3f34fd1c0d9959 100644 --- a/deps/v8/include/v8-internal.h +++ b/deps/v8/include/v8-internal.h @@ -30,6 +30,7 @@ class Isolate; typedef uintptr_t Address; static const Address kNullAddress = 0; +static const Address kLocalTaggedNullAddress = 1; constexpr int KB = 1024; constexpr int MB = KB * 1024; @@ -150,6 +151,7 @@ const int kSmiMinValue = static_cast(PlatformSmiTagging::kSmiMinValue); const int kSmiMaxValue = static_cast(PlatformSmiTagging::kSmiMaxValue); constexpr bool SmiValuesAre31Bits() { return kSmiValueSize == 31; } constexpr bool SmiValuesAre32Bits() { return kSmiValueSize == 32; } +constexpr bool Is64() { return kApiSystemPointerSize == sizeof(int64_t); } V8_INLINE static constexpr internal::Address IntToSmi(int value) { return (static_cast
(value) << (kSmiTagSize + kSmiShiftSize)) | @@ -242,6 +244,7 @@ static_assert(1ULL << (64 - kBoundedSizeShift) == #ifdef V8_COMPRESS_POINTERS +#ifdef V8_TARGET_OS_ANDROID // The size of the virtual memory reservation for an external pointer table. // This determines the maximum number of entries in a table. Using a maximum // size allows omitting bounds checks on table accesses if the indices are @@ -249,14 +252,18 @@ static_assert(1ULL << (64 - kBoundedSizeShift) == // value must be a power of two. static const size_t kExternalPointerTableReservationSize = 512 * MB; -// The maximum number of entries in an external pointer table. -static const size_t kMaxExternalPointers = - kExternalPointerTableReservationSize / kApiSystemPointerSize; - // 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. static const uint32_t kExternalPointerIndexShift = 6; +#else +static const size_t kExternalPointerTableReservationSize = 1024 * MB; +static const uint32_t kExternalPointerIndexShift = 5; +#endif // V8_TARGET_OS_ANDROID + +// The maximum number of entries in an external pointer table. +static const size_t kMaxExternalPointers = + kExternalPointerTableReservationSize / kApiSystemPointerSize; static_assert((1 << (32 - kExternalPointerIndexShift)) == kMaxExternalPointers, "kExternalPointerTableReservationSize and " "kExternalPointerIndexShift don't match"); @@ -345,6 +352,14 @@ using ExternalPointer_t = Address; // that the Embedder is not using this byte (really only this one bit) for any // other purpose. This bit also does not collide with the memory tagging // extension (MTE) which would use bits [56, 60). +// +// External pointer tables are also available even when the sandbox is off but +// pointer compression is on. In that case, the mechanism can be used to easy +// alignment requirements as it turns unaligned 64-bit raw pointers into +// aligned 32-bit indices. To "opt-in" to the external pointer table mechanism +// for this purpose, instead of using the ExternalPointer accessors one needs to +// use ExternalPointerHandles directly and use them to access the pointers in an +// ExternalPointerTable. constexpr uint64_t kExternalPointerMarkBit = 1ULL << 62; constexpr uint64_t kExternalPointerTagMask = 0x40ff000000000000; constexpr uint64_t kExternalPointerTagShift = 48; @@ -367,71 +382,58 @@ constexpr uint64_t kAllExternalPointerTypeTags[] = { 0b11001100, 0b11010001, 0b11010010, 0b11010100, 0b11011000, 0b11100001, 0b11100010, 0b11100100, 0b11101000, 0b11110000}; +#define TAG(i) \ + ((kAllExternalPointerTypeTags[i] << kExternalPointerTagShift) | \ + kExternalPointerMarkBit) + // clang-format off -// New entries should be added with state "sandboxed". + // When adding new tags, please ensure that the code using these tags is // "substitution-safe", i.e. still operate safely if external pointers of the // same type are swapped by an attacker. See comment above for more details. -#define TAG(i) (kAllExternalPointerTypeTags[i]) // Shared external pointers are owned by the shared Isolate and stored in the // shared external pointer table associated with that Isolate, where they can // be accessed from multiple threads at the same time. The objects referenced // in this way must therefore always be thread-safe. -#define SHARED_EXTERNAL_POINTER_TAGS(V) \ - V(kFirstSharedTag, sandboxed, TAG(0)) \ - V(kWaiterQueueNodeTag, sandboxed, TAG(0)) \ - V(kExternalStringResourceTag, sandboxed, TAG(1)) \ - V(kExternalStringResourceDataTag, sandboxed, TAG(2)) \ - V(kLastSharedTag, sandboxed, TAG(2)) +#define SHARED_EXTERNAL_POINTER_TAGS(V) \ + V(kFirstSharedTag, TAG(0)) \ + V(kWaiterQueueNodeTag, TAG(0)) \ + V(kExternalStringResourceTag, TAG(1)) \ + V(kExternalStringResourceDataTag, TAG(2)) \ + V(kLastSharedTag, TAG(2)) // External pointers using these tags are kept in a per-Isolate external // pointer table and can only be accessed when this Isolate is active. -#define PER_ISOLATE_EXTERNAL_POINTER_TAGS(V) \ - V(kForeignForeignAddressTag, sandboxed, TAG(10)) \ - V(kNativeContextMicrotaskQueueTag, sandboxed, TAG(11)) \ - V(kEmbedderDataSlotPayloadTag, sandboxed, TAG(12)) \ - V(kExternalObjectValueTag, sandboxed, TAG(13)) \ - V(kCallHandlerInfoCallbackTag, sandboxed, TAG(14)) \ - V(kAccessorInfoGetterTag, sandboxed, TAG(15)) \ - V(kAccessorInfoSetterTag, sandboxed, TAG(16)) \ - V(kWasmInternalFunctionCallTargetTag, sandboxed, TAG(17)) \ - V(kWasmTypeInfoNativeTypeTag, sandboxed, TAG(18)) \ - V(kWasmExportedFunctionDataSignatureTag, sandboxed, TAG(19)) \ - V(kWasmContinuationJmpbufTag, sandboxed, TAG(20)) \ - V(kArrayBufferExtensionTag, sandboxed, TAG(21)) +#define PER_ISOLATE_EXTERNAL_POINTER_TAGS(V) \ + V(kForeignForeignAddressTag, TAG(10)) \ + V(kNativeContextMicrotaskQueueTag, TAG(11)) \ + V(kEmbedderDataSlotPayloadTag, TAG(12)) \ +/* This tag essentially stands for a `void*` pointer in the V8 API, and */ \ +/* it is the Embedder's responsibility to ensure type safety (against */ \ +/* substitution) and lifetime validity of these objects. */ \ + V(kExternalObjectValueTag, TAG(13)) \ + V(kCallHandlerInfoCallbackTag, TAG(14)) \ + V(kAccessorInfoGetterTag, TAG(15)) \ + V(kAccessorInfoSetterTag, TAG(16)) \ + V(kWasmInternalFunctionCallTargetTag, TAG(17)) \ + V(kWasmTypeInfoNativeTypeTag, TAG(18)) \ + V(kWasmExportedFunctionDataSignatureTag, TAG(19)) \ + V(kWasmContinuationJmpbufTag, TAG(20)) \ + V(kArrayBufferExtensionTag, TAG(21)) // All external pointer tags. #define ALL_EXTERNAL_POINTER_TAGS(V) \ SHARED_EXTERNAL_POINTER_TAGS(V) \ PER_ISOLATE_EXTERNAL_POINTER_TAGS(V) -// When the sandbox is enabled, external pointers marked as "sandboxed" above -// use the external pointer table (i.e. are sandboxed). This allows a gradual -// rollout of external pointer sandboxing. If the sandbox is off, no external -// pointers are sandboxed. -// -// Sandboxed external pointer tags are available when compressing pointers even -// when the sandbox is off. Some tags (e.g. kWaiterQueueNodeTag) are used -// manually with the external pointer table even when the sandbox is off to ease -// alignment requirements. -#define sandboxed(X) (X << kExternalPointerTagShift) | kExternalPointerMarkBit -#define unsandboxed(X) kUnsandboxedExternalPointerTag -#if defined(V8_COMPRESS_POINTERS) -#define EXTERNAL_POINTER_TAG_ENUM(Name, State, Bits) Name = State(Bits), -#else -#define EXTERNAL_POINTER_TAG_ENUM(Name, State, Bits) Name = unsandboxed(Bits), -#endif - +#define EXTERNAL_POINTER_TAG_ENUM(Name, Tag) Name = Tag, #define MAKE_TAG(HasMarkBit, TypeTag) \ ((static_cast(TypeTag) << kExternalPointerTagShift) | \ (HasMarkBit ? kExternalPointerMarkBit : 0)) enum ExternalPointerTag : uint64_t { // Empty tag value. Mostly used as placeholder. kExternalPointerNullTag = MAKE_TAG(0, 0b00000000), - // Tag to use for unsandboxed external pointers, which are still stored as - // raw pointers on the heap. - kUnsandboxedExternalPointerTag = MAKE_TAG(0, 0b00000000), // External pointer tag that will match any external pointer. Use with care! kAnyExternalPointerTag = MAKE_TAG(1, 0b11111111), // The free entry tag has all type bits set so every type check with a @@ -445,20 +447,11 @@ enum ExternalPointerTag : uint64_t { }; #undef MAKE_TAG -#undef unsandboxed -#undef sandboxed #undef TAG #undef EXTERNAL_POINTER_TAG_ENUM // clang-format on -// True if the external pointer is sandboxed and so must be referenced through -// an external pointer table. -V8_INLINE static constexpr bool IsSandboxedExternalPointerType( - ExternalPointerTag tag) { - return tag != kUnsandboxedExternalPointerTag; -} - // True if the external pointer must be accessed from the shared isolate's // external pointer table. V8_INLINE static constexpr bool IsSharedExternalPointerType( @@ -467,12 +460,10 @@ V8_INLINE static constexpr bool IsSharedExternalPointerType( } // Sanity checks. -#define CHECK_SHARED_EXTERNAL_POINTER_TAGS(Tag, ...) \ - static_assert(!IsSandboxedExternalPointerType(Tag) || \ - IsSharedExternalPointerType(Tag)); +#define CHECK_SHARED_EXTERNAL_POINTER_TAGS(Tag, ...) \ + static_assert(IsSharedExternalPointerType(Tag)); #define CHECK_NON_SHARED_EXTERNAL_POINTER_TAGS(Tag, ...) \ - static_assert(!IsSandboxedExternalPointerType(Tag) || \ - !IsSharedExternalPointerType(Tag)); + static_assert(!IsSharedExternalPointerType(Tag)); SHARED_EXTERNAL_POINTER_TAGS(CHECK_SHARED_EXTERNAL_POINTER_TAGS) PER_ISOLATE_EXTERNAL_POINTER_TAGS(CHECK_NON_SHARED_EXTERNAL_POINTER_TAGS) @@ -545,7 +536,7 @@ class Internals { static const int kVariousBooleanFlagsOffset = kIsolateStackGuardOffset + kStackGuardSize; static const int kBuiltinTier0EntryTableOffset = - kVariousBooleanFlagsOffset + kApiSystemPointerSize; + kVariousBooleanFlagsOffset + 8; static const int kBuiltinTier0TableOffset = kBuiltinTier0EntryTableOffset + kBuiltinTier0EntryTableSize; static const int kIsolateEmbedderDataOffset = @@ -793,24 +784,23 @@ class Internals { V8_INLINE static internal::Address ReadExternalPointerField( v8::Isolate* isolate, internal::Address heap_object_ptr, int offset) { #ifdef V8_ENABLE_SANDBOX - if (IsSandboxedExternalPointerType(tag)) { - // See src/sandbox/external-pointer-table-inl.h. Logic duplicated here so - // it can be inlined and doesn't require an additional call. - internal::Address* table = - IsSharedExternalPointerType(tag) - ? GetSharedExternalPointerTableBase(isolate) - : GetExternalPointerTableBase(isolate); - internal::ExternalPointerHandle handle = - ReadRawField(heap_object_ptr, offset); - uint32_t index = handle >> kExternalPointerIndexShift; - std::atomic* ptr = - reinterpret_cast*>(&table[index]); - internal::Address entry = - std::atomic_load_explicit(ptr, std::memory_order_relaxed); - return entry & ~tag; - } -#endif + static_assert(tag != kExternalPointerNullTag); + // See src/sandbox/external-pointer-table-inl.h. Logic duplicated here so + // it can be inlined and doesn't require an additional call. + internal::Address* table = IsSharedExternalPointerType(tag) + ? GetSharedExternalPointerTableBase(isolate) + : GetExternalPointerTableBase(isolate); + internal::ExternalPointerHandle handle = + ReadRawField(heap_object_ptr, offset); + uint32_t index = handle >> kExternalPointerIndexShift; + std::atomic* ptr = + reinterpret_cast*>(&table[index]); + internal::Address entry = + std::atomic_load_explicit(ptr, std::memory_order_relaxed); + return entry & ~tag; +#else return ReadRawField
(heap_object_ptr, offset); +#endif // V8_ENABLE_SANDBOX } #ifdef V8_COMPRESS_POINTERS @@ -819,7 +809,7 @@ class Internals { return addr & -static_cast(kPtrComprCageBaseAlignment); } - V8_INLINE static internal::Address DecompressTaggedAnyField( + V8_INLINE static internal::Address DecompressTaggedField( internal::Address heap_object_ptr, uint32_t value) { internal::Address base = GetPtrComprCageBaseFromOnHeapAddress(heap_object_ptr); @@ -861,6 +851,19 @@ class BackingStoreBase {}; // This is needed for histograms sampling garbage collection reasons. constexpr int kGarbageCollectionReasonMaxValue = 27; +class ValueHelper final { + using A = internal::Address; + + public: + static A ValueToAddress(const Data* value) { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + return reinterpret_cast(value); +#else + return *reinterpret_cast(value); +#endif + } +}; + } // namespace internal } // namespace v8 diff --git a/deps/v8/include/v8-isolate.h b/deps/v8/include/v8-isolate.h index e9f531973b2eef..5bd829f752c1c7 100644 --- a/deps/v8/include/v8-isolate.h +++ b/deps/v8/include/v8-isolate.h @@ -233,7 +233,7 @@ class V8_EXPORT Isolate { * Explicitly specify a startup snapshot blob. The embedder owns the blob. * The embedder *must* ensure that the snapshot is from a trusted source. */ - StartupData* snapshot_blob = nullptr; + const StartupData* snapshot_blob = nullptr; /** * Enables the host application to provide a mechanism for recording @@ -537,6 +537,8 @@ class V8_EXPORT Isolate { kTurboFanOsrCompileStarted = 115, kAsyncStackTaggingCreateTaskCall = 116, kDurationFormat = 117, + kInvalidatedNumberStringPrototypeNoReplaceProtector = 118, + kRegExpUnicodeSetIncompatibilitiesWithUnicodeMode = 119, // 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 @@ -924,27 +926,10 @@ class V8_EXPORT Isolate { void RemoveGCPrologueCallback(GCCallbackWithData, void* data = nullptr); void RemoveGCPrologueCallback(GCCallback callback); - START_ALLOW_USE_DEPRECATED() - /** - * Sets the embedder heap tracer for the isolate. - * SetEmbedderHeapTracer cannot be used simultaneously with AttachCppHeap. - */ - void SetEmbedderHeapTracer(EmbedderHeapTracer* tracer); - - /* - * Gets the currently active heap tracer for the isolate that was set with - * SetEmbedderHeapTracer. - */ - EmbedderHeapTracer* GetEmbedderHeapTracer(); - END_ALLOW_USE_DEPRECATED() - /** * Sets an embedder roots handle that V8 should consider when performing - * non-unified heap garbage collections. - * - * Using only EmbedderHeapTracer automatically sets up a default handler. - * The intended use case is for setting a custom handler after invoking - * `AttachCppHeap()`. + * non-unified heap garbage collections. The intended use case is for setting + * a custom handler after invoking `AttachCppHeap()`. * * V8 does not take ownership of the handler. */ @@ -955,8 +940,6 @@ class V8_EXPORT Isolate { * embedder maintains ownership of the CppHeap. At most one C++ heap can be * attached to V8. * - * AttachCppHeap cannot be used simultaneously with SetEmbedderHeapTracer. - * * Multi-threaded use requires the use of v8::Locker/v8::Unlocker, see * CppHeap. */ @@ -1346,11 +1329,13 @@ class V8_EXPORT Isolate { * V8 uses this notification to guide heuristics which may result in a * smaller memory footprint at the cost of reduced runtime performance. */ + V8_DEPRECATED("Use IsolateInBackgroundNotification() instead") void EnableMemorySavingsMode(); /** * Optional notification which will disable the memory savings mode. */ + V8_DEPRECATED("Use IsolateInBackgroundNotification() instead") void DisableMemorySavingsMode(); /** @@ -1530,6 +1515,13 @@ class V8_EXPORT Isolate { V8_DEPRECATED("Wasm exceptions are always enabled") void SetWasmExceptionsEnabledCallback(WasmExceptionsEnabledCallback callback); + /** + * Register callback to control whehter Wasm GC is enabled. + * The callback overwrites the value of the flag. + * If the callback returns true, it will also enable Wasm stringrefs. + */ + void SetWasmGCEnabledCallback(WasmGCEnabledCallback callback); + void SetSharedArrayBufferConstructorEnabledCallback( SharedArrayBufferConstructorEnabledCallback callback); @@ -1684,7 +1676,11 @@ uint32_t Isolate::GetNumberOfDataSlots() { template MaybeLocal Isolate::GetDataFromSnapshotOnce(size_t index) { +#if V8_ENABLE_CONSERVATIVE_STACK_SCANNING + T* data = *reinterpret_cast(GetDataFromSnapshotOnce(index)); +#else T* data = reinterpret_cast(GetDataFromSnapshotOnce(index)); +#endif if (data) internal::PerformCastCheck(data); return Local(data); } diff --git a/deps/v8/include/v8-local-handle.h b/deps/v8/include/v8-local-handle.h index cbf87f949d09fa..4d88d2664e4ba9 100644 --- a/deps/v8/include/v8-local-handle.h +++ b/deps/v8/include/v8-local-handle.h @@ -53,6 +53,7 @@ class Utils; namespace internal { template class CustomArguments; +class SamplingHeapProfiler; } // namespace internal namespace api_internal { @@ -92,6 +93,9 @@ class V8_EXPORT V8_NODISCARD HandleScope { HandleScope(const HandleScope&) = delete; void operator=(const HandleScope&) = delete; + static internal::Address* CreateHandleForCurrentIsolate( + internal::Address value); + protected: V8_INLINE HandleScope() = default; @@ -154,7 +158,12 @@ class V8_EXPORT V8_NODISCARD HandleScope { template class Local { public: +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + V8_INLINE Local() + : val_(reinterpret_cast(internal::kLocalTaggedNullAddress)) {} +#else V8_INLINE Local() : val_(nullptr) {} +#endif template V8_INLINE Local(Local that) : val_(reinterpret_cast(*that)) { /** @@ -168,12 +177,24 @@ class Local { /** * Returns true if the handle is empty. */ - V8_INLINE bool IsEmpty() const { return val_ == nullptr; } + V8_INLINE bool IsEmpty() const { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + return (internal::Address)val_ == internal::kLocalTaggedNullAddress; +#else + return val_ == nullptr; +#endif + } /** * Sets the handle to be empty. IsEmpty() will then return true. */ - V8_INLINE void Clear() { val_ = nullptr; } + V8_INLINE void Clear() { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + val_ = reinterpret_cast(internal::kLocalTaggedNullAddress); +#else + val_ = nullptr; +#endif + } V8_INLINE T* operator->() const { return val_; } @@ -191,20 +212,37 @@ class Local { */ template V8_INLINE bool operator==(const Local& that) const { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + internal::Address a = reinterpret_cast(this->val_); + internal::Address b = reinterpret_cast(that.val_); + if (a == internal::kLocalTaggedNullAddress) + return b == internal::kLocalTaggedNullAddress; + if (b == internal::kLocalTaggedNullAddress) return false; + return a == b; +#else internal::Address* a = reinterpret_cast(this->val_); internal::Address* b = reinterpret_cast(that.val_); if (a == nullptr) return b == nullptr; if (b == nullptr) return false; return *a == *b; +#endif } template V8_INLINE bool operator==(const PersistentBase& that) const { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + internal::Address a = reinterpret_cast(this->val_); + internal::Address* b = reinterpret_cast(that.val_); + if (a == internal::kLocalTaggedNullAddress) return b == nullptr; + if (b == nullptr) return false; + return a == *b; +#else internal::Address* a = reinterpret_cast(this->val_); internal::Address* b = reinterpret_cast(that.val_); if (a == nullptr) return b == nullptr; if (b == nullptr) return false; return *a == *b; +#endif } /** @@ -252,6 +290,22 @@ class Local { return Local::Cast(*this); } + V8_INLINE T* ValueFromSlot() const { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + return val_; +#else + return *reinterpret_cast(val_); +#endif + } + + V8_INLINE internal::Address AddressFromSlot() const { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + return reinterpret_cast(val_); +#else + return *reinterpret_cast(val_); +#endif + } + /** * Create a local handle for the content of another handle. * The referee is kept alive by the local handle even when @@ -263,12 +317,34 @@ class Local { V8_INLINE static Local New(Isolate* isolate, const PersistentBase& that) { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + return New(isolate, *reinterpret_cast(that.val_)); +#else return New(isolate, that.val_); +#endif } V8_INLINE static Local New(Isolate* isolate, const BasicTracedReference& that) { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + return New(isolate, *reinterpret_cast(that.val_)); +#else return New(isolate, *that); +#endif + } + +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + V8_INLINE static Local New(Isolate* isolate, const Eternal& that) { + return New(isolate, *reinterpret_cast(that.val_)); + } +#endif + + V8_INLINE static Local New(T* value) { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + return Local(*reinterpret_cast(value)); +#else + return Local(value); +#endif } private: @@ -313,14 +389,22 @@ class Local { friend class BasicTracedReference; template friend class TracedReference; + friend class v8::internal::SamplingHeapProfiler; explicit V8_INLINE Local(T* that) : val_(that) {} V8_INLINE static Local New(Isolate* isolate, T* that) { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + if (reinterpret_cast(that) == + internal::kLocalTaggedNullAddress) + return Local(); + return Local(that); +#else if (that == nullptr) return Local(); T* that_ptr = that; internal::Address* p = reinterpret_cast(that_ptr); return Local(reinterpret_cast(HandleScope::CreateHandle( reinterpret_cast(isolate), *p))); +#endif } T* val_; }; @@ -344,13 +428,24 @@ using Handle = Local; template class MaybeLocal { public: +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + V8_INLINE MaybeLocal() + : val_(reinterpret_cast(internal::kLocalTaggedNullAddress)) {} +#else V8_INLINE MaybeLocal() : val_(nullptr) {} +#endif template V8_INLINE MaybeLocal(Local that) : val_(reinterpret_cast(*that)) { static_assert(std::is_base_of::value, "type check"); } - V8_INLINE bool IsEmpty() const { return val_ == nullptr; } + V8_INLINE bool IsEmpty() const { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + return (internal::Address)val_ == internal::kLocalTaggedNullAddress; +#else + return val_ == nullptr; +#endif + } /** * Converts this MaybeLocal<> to a Local<>. If this MaybeLocal<> is empty, @@ -358,7 +453,13 @@ class MaybeLocal { */ template V8_WARN_UNUSED_RESULT V8_INLINE bool ToLocal(Local* out) const { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + out->val_ = IsEmpty() + ? reinterpret_cast(internal::kLocalTaggedNullAddress) + : this->val_; +#else out->val_ = IsEmpty() ? nullptr : this->val_; +#endif return !IsEmpty(); } @@ -367,7 +468,13 @@ class MaybeLocal { * V8 will crash the process. */ V8_INLINE Local ToLocalChecked() { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + if (V8_UNLIKELY(reinterpret_cast(val_) == + internal::kLocalTaggedNullAddress)) + api_internal::ToLocalEmpty(); +#else if (V8_UNLIKELY(val_ == nullptr)) api_internal::ToLocalEmpty(); +#endif return Local(val_); } @@ -399,9 +506,13 @@ class V8_EXPORT V8_NODISCARD EscapableHandleScope : public HandleScope { */ template V8_INLINE Local Escape(Local value) { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + return value; +#else internal::Address* slot = Escape(reinterpret_cast(*value)); return Local(reinterpret_cast(slot)); +#endif } template diff --git a/deps/v8/include/v8-metrics.h b/deps/v8/include/v8-metrics.h index 887012ac8c3a0b..5c6c1c4705e38b 100644 --- a/deps/v8/include/v8-metrics.h +++ b/deps/v8/include/v8-metrics.h @@ -12,6 +12,7 @@ #include "v8-internal.h" // NOLINT(build/include_directory) #include "v8-local-handle.h" // NOLINT(build/include_directory) +#include "v8config.h" // NOLINT(build/include_directory) namespace v8 { @@ -96,16 +97,42 @@ struct GarbageCollectionYoungCycle { }; struct WasmModuleDecoded { + WasmModuleDecoded() = default; + WasmModuleDecoded(bool async, bool streamed, bool success, + size_t module_size_in_bytes, size_t function_count, + int64_t wall_clock_duration_in_us) + : async(async), + streamed(streamed), + success(success), + module_size_in_bytes(module_size_in_bytes), + function_count(function_count), + wall_clock_duration_in_us(wall_clock_duration_in_us) {} + bool async = false; bool streamed = false; bool success = false; size_t module_size_in_bytes = 0; size_t function_count = 0; int64_t wall_clock_duration_in_us = -1; - int64_t cpu_duration_in_us = -1; }; struct WasmModuleCompiled { + WasmModuleCompiled() = default; + + WasmModuleCompiled(bool async, bool streamed, bool cached, bool deserialized, + bool lazy, bool success, size_t code_size_in_bytes, + size_t liftoff_bailout_count, + int64_t wall_clock_duration_in_us) + : async(async), + streamed(streamed), + cached(cached), + deserialized(deserialized), + lazy(lazy), + success(success), + code_size_in_bytes(code_size_in_bytes), + liftoff_bailout_count(liftoff_bailout_count), + wall_clock_duration_in_us(wall_clock_duration_in_us) {} + bool async = false; bool streamed = false; bool cached = false; @@ -115,7 +142,6 @@ struct WasmModuleCompiled { size_t code_size_in_bytes = 0; size_t liftoff_bailout_count = 0; int64_t wall_clock_duration_in_us = -1; - int64_t cpu_duration_in_us = -1; }; struct WasmModuleInstantiated { diff --git a/deps/v8/include/v8-object.h b/deps/v8/include/v8-object.h index d7332ba0c88d12..6f3025e3adf229 100644 --- a/deps/v8/include/v8-object.h +++ b/deps/v8/include/v8-object.h @@ -707,7 +707,7 @@ Local Object::GetInternalField(int index) { #ifndef V8_ENABLE_CHECKS using A = internal::Address; using I = internal::Internals; - A obj = *reinterpret_cast(this); + A obj = internal::ValueHelper::ValueToAddress(this); // Fast path: If the object is a plain JSObject, which is the common case, we // know where to find the internal fields and can return the value directly. int instance_type = I::GetInstanceType(obj); @@ -717,12 +717,17 @@ Local Object::GetInternalField(int index) { #ifdef V8_COMPRESS_POINTERS // We read the full pointer value and then decompress it in order to avoid // dealing with potential endiannes issues. - value = I::DecompressTaggedAnyField(obj, static_cast(value)); + value = I::DecompressTaggedField(obj, static_cast(value)); #endif + +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + return Local(reinterpret_cast(value)); +#else internal::Isolate* isolate = internal::IsolateFromNeverReadOnlySpaceObject(obj); A* result = HandleScope::CreateHandle(isolate, value); return Local(reinterpret_cast(result)); +#endif } #endif return SlowGetInternalField(index); @@ -732,7 +737,7 @@ void* Object::GetAlignedPointerFromInternalField(int index) { #if !defined(V8_ENABLE_CHECKS) using A = internal::Address; using I = internal::Internals; - A obj = *reinterpret_cast(this); + A obj = internal::ValueHelper::ValueToAddress(this); // Fast path: If the object is a plain JSObject, which is the common case, we // know where to find the internal fields and can return the value directly. auto instance_type = I::GetInstanceType(obj); diff --git a/deps/v8/include/v8-persistent-handle.h b/deps/v8/include/v8-persistent-handle.h index dbda4edb9baf4e..39210f7a703e5d 100644 --- a/deps/v8/include/v8-persistent-handle.h +++ b/deps/v8/include/v8-persistent-handle.h @@ -45,6 +45,9 @@ V8_EXPORT void MoveGlobalReference(internal::Address** from, */ template class Eternal { + template + friend class Local; + public: V8_INLINE Eternal() : val_(nullptr) {} template @@ -55,7 +58,11 @@ class Eternal { V8_INLINE Local Get(Isolate* isolate) const { // The eternal handle will never go away, so as with the roots, we don't // even need to open a handle. +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + return Local::New(isolate, *this); +#else return Local(val_); +#endif } V8_INLINE bool IsEmpty() const { return val_ == nullptr; } @@ -132,10 +139,17 @@ class PersistentBase { template V8_INLINE bool operator==(const Local& that) const { internal::Address* a = reinterpret_cast(this->val_); +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + internal::Address b = reinterpret_cast(that.val_); + if (a == nullptr) return b == internal::kLocalTaggedNullAddress; + if (b == internal::kLocalTaggedNullAddress) return false; + return *a == b; +#else internal::Address* b = reinterpret_cast(that.val_); if (a == nullptr) return b == nullptr; if (b == nullptr) return false; return *a == *b; +#endif } template @@ -252,7 +266,7 @@ class NonCopyablePersistentTraits { * This will clone the contents of storage cell, but not any of the flags, etc. */ template -struct CopyablePersistentTraits { +struct V8_DEPRECATED("Use v8::Global instead") CopyablePersistentTraits { using CopyablePersistent = Persistent>; static const bool kResetInDestructor = true; template @@ -282,11 +296,22 @@ class Persistent : public PersistentBase { * When the Local is non-empty, a new storage cell is created * pointing to the same object, and no flags are set. */ + +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + template + V8_INLINE Persistent(Isolate* isolate, Local that) + : PersistentBase( + PersistentBase::New(isolate, reinterpret_cast(&that))) { + static_assert(std::is_base_of::value, "type check"); + } +#else template V8_INLINE Persistent(Isolate* isolate, Local that) : PersistentBase(PersistentBase::New(isolate, *that)) { static_assert(std::is_base_of::value, "type check"); } +#endif + /** * Construct a Persistent from a Persistent. * When the Persistent is non-empty, a new storage cell is created @@ -379,11 +404,20 @@ class Global : public PersistentBase { * When the Local is non-empty, a new storage cell is created * pointing to the same object, and no flags are set. */ +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + template + V8_INLINE Global(Isolate* isolate, Local that) + : PersistentBase( + PersistentBase::New(isolate, reinterpret_cast(&that))) { + static_assert(std::is_base_of::value, "type check"); + } +#else template V8_INLINE Global(Isolate* isolate, Local that) : PersistentBase(PersistentBase::New(isolate, *that)) { static_assert(std::is_base_of::value, "type check"); } +#endif /** * Construct a Global from a PersistentBase. @@ -486,7 +520,11 @@ void PersistentBase::Reset(Isolate* isolate, const Local& other) { static_assert(std::is_base_of::value, "type check"); Reset(); if (other.IsEmpty()) return; +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + this->val_ = New(isolate, const_cast(reinterpret_cast(&other))); +#else this->val_ = New(isolate, other.val_); +#endif } /** diff --git a/deps/v8/include/v8-platform.h b/deps/v8/include/v8-platform.h index 32a82f881e7f93..750131d4c978ff 100644 --- a/deps/v8/include/v8-platform.h +++ b/deps/v8/include/v8-platform.h @@ -5,9 +5,11 @@ #ifndef V8_V8_PLATFORM_H_ #define V8_V8_PLATFORM_H_ +#include #include #include #include // For abort. + #include #include @@ -285,6 +287,8 @@ class ConvertableToTraceFormat { * V8 Tracing controller. * * Can be implemented by an embedder to record trace events from V8. + * + * Will become obsolete in Perfetto SDK build (v8_use_perfetto = true). */ class TracingController { public: @@ -348,10 +352,16 @@ class TracingController { virtual void OnTraceDisabled() = 0; }; - /** Adds tracing state change observer. */ + /** + * Adds tracing state change observer. + * Does nothing in Perfetto SDK build (v8_use_perfetto = true). + */ virtual void AddTraceStateObserver(TraceStateObserver*) {} - /** Removes tracing state change observer. */ + /** + * Removes tracing state change observer. + * Does nothing in Perfetto SDK build (v8_use_perfetto = true). + */ virtual void RemoveTraceStateObserver(TraceStateObserver*) {} }; @@ -534,7 +544,7 @@ static constexpr PlatformSharedMemoryHandle kInvalidSharedMemoryHandle = -1; // to avoid pulling in large OS header files into this header file. Instead, // the users of these routines are expected to include the respecitve OS // headers in addition to this one. -#if V8_OS_MACOS +#if V8_OS_DARWIN // Convert between a shared memory handle and a mach_port_t referencing a memory // entry object. inline PlatformSharedMemoryHandle SharedMemoryHandleFromMachMemoryEntry( @@ -1074,11 +1084,28 @@ class Platform { virtual double MonotonicallyIncreasingTime() = 0; /** - * Current wall-clock time in milliseconds since epoch. - * This function is expected to return at least millisecond-precision values. + * Current wall-clock time in milliseconds since epoch. Use + * CurrentClockTimeMillisHighResolution() when higher precision is + * required. + */ + virtual int64_t CurrentClockTimeMilliseconds() { + return floor(CurrentClockTimeMillis()); + } + + /** + * This function is deprecated and will be deleted. Use either + * CurrentClockTimeMilliseconds() or + * CurrentClockTimeMillisecondsHighResolution(). */ virtual double CurrentClockTimeMillis() = 0; + /** + * Same as CurrentClockTimeMilliseconds(), but with more precision. + */ + virtual double CurrentClockTimeMillisecondsHighResolution() { + return CurrentClockTimeMillis(); + } + typedef void (*StackTracePrinter)(); /** diff --git a/deps/v8/include/v8-primitive.h b/deps/v8/include/v8-primitive.h index 4fef8da7f8d5e7..e2b8d6fececd5c 100644 --- a/deps/v8/include/v8-primitive.h +++ b/deps/v8/include/v8-primitive.h @@ -777,13 +777,13 @@ Local String::Empty(Isolate* isolate) { using I = internal::Internals; I::CheckInitialized(isolate); S* slot = I::GetRoot(isolate, I::kEmptyStringRootIndex); - return Local(reinterpret_cast(slot)); + return Local::New(reinterpret_cast(slot)); } String::ExternalStringResource* String::GetExternalStringResource() const { using A = internal::Address; using I = internal::Internals; - A obj = *reinterpret_cast(this); + A obj = internal::ValueHelper::ValueToAddress(this); ExternalStringResource* result; if (I::IsExternalTwoByteString(I::GetInstanceType(obj))) { @@ -804,7 +804,7 @@ String::ExternalStringResourceBase* String::GetExternalStringResourceBase( String::Encoding* encoding_out) const { using A = internal::Address; using I = internal::Internals; - A obj = *reinterpret_cast(this); + A obj = internal::ValueHelper::ValueToAddress(this); int type = I::GetInstanceType(obj) & I::kStringRepresentationAndEncodingMask; *encoding_out = static_cast(type & I::kStringEncodingMask); ExternalStringResourceBase* resource; @@ -830,7 +830,7 @@ V8_INLINE Local Undefined(Isolate* isolate) { using I = internal::Internals; I::CheckInitialized(isolate); S* slot = I::GetRoot(isolate, I::kUndefinedValueRootIndex); - return Local(reinterpret_cast(slot)); + return Local::New(reinterpret_cast(slot)); } V8_INLINE Local Null(Isolate* isolate) { @@ -838,7 +838,7 @@ V8_INLINE Local Null(Isolate* isolate) { using I = internal::Internals; I::CheckInitialized(isolate); S* slot = I::GetRoot(isolate, I::kNullValueRootIndex); - return Local(reinterpret_cast(slot)); + return Local::New(reinterpret_cast(slot)); } V8_INLINE Local True(Isolate* isolate) { @@ -846,7 +846,7 @@ V8_INLINE Local True(Isolate* isolate) { using I = internal::Internals; I::CheckInitialized(isolate); S* slot = I::GetRoot(isolate, I::kTrueValueRootIndex); - return Local(reinterpret_cast(slot)); + return Local::New(reinterpret_cast(slot)); } V8_INLINE Local False(Isolate* isolate) { @@ -854,7 +854,7 @@ V8_INLINE Local False(Isolate* isolate) { using I = internal::Internals; I::CheckInitialized(isolate); S* slot = I::GetRoot(isolate, I::kFalseValueRootIndex); - return Local(reinterpret_cast(slot)); + return Local::New(reinterpret_cast(slot)); } Local Boolean::New(Isolate* isolate, bool value) { diff --git a/deps/v8/include/v8-profiler.h b/deps/v8/include/v8-profiler.h index 6b73fc60bf2c21..d3941512218342 100644 --- a/deps/v8/include/v8-profiler.h +++ b/deps/v8/include/v8-profiler.h @@ -596,6 +596,7 @@ class V8_EXPORT HeapGraphNode { kBigInt = 13, // BigInt. kObjectShape = 14, // Internal data used for tracking the shapes (or // "hidden classes") of JS objects. + kWasmObject = 15, // A WasmGC struct or array. }; /** Returns node type (see HeapGraphNode::Type). */ diff --git a/deps/v8/include/v8-script.h b/deps/v8/include/v8-script.h index e2ba845268d921..ea4933dc44ab72 100644 --- a/deps/v8/include/v8-script.h +++ b/deps/v8/include/v8-script.h @@ -347,6 +347,12 @@ class V8_EXPORT Script { * ScriptOrigin. This can be either a v8::String or v8::Undefined. */ Local GetResourceName(); + + /** + * If the script was compiled, returns the positions of lazy functions which + * were eventually compiled and executed. + */ + std::vector GetProducedCompileHints() const; }; enum class ScriptType { kClassic, kModule }; @@ -562,7 +568,8 @@ class V8_EXPORT ScriptCompiler { enum CompileOptions { kNoCompileOptions = 0, kConsumeCodeCache, - kEagerCompile + kEagerCompile, + kProduceCompileHints }; /** diff --git a/deps/v8/include/v8-snapshot.h b/deps/v8/include/v8-snapshot.h index 2400357cf6e069..8a6209c561c026 100644 --- a/deps/v8/include/v8-snapshot.h +++ b/deps/v8/include/v8-snapshot.h @@ -91,7 +91,7 @@ class V8_EXPORT SnapshotCreator { */ SnapshotCreator(Isolate* isolate, const intptr_t* external_references = nullptr, - StartupData* existing_blob = nullptr); + const StartupData* existing_blob = nullptr); /** * Create and enter an isolate, and set it up for serialization. @@ -102,7 +102,7 @@ class V8_EXPORT SnapshotCreator { * that must be equivalent to CreateParams::external_references. */ SnapshotCreator(const intptr_t* external_references = nullptr, - StartupData* existing_blob = nullptr); + const StartupData* existing_blob = nullptr); /** * Destroy the snapshot creator, and exit and dispose of the Isolate @@ -177,18 +177,27 @@ class V8_EXPORT SnapshotCreator { void* data_; }; +class SnapshotHelper { + using A = internal::Address; + + public: + static A ObjectToAddress(const Data* value) { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + return reinterpret_cast(value); +#else + return *reinterpret_cast(value); +#endif + } +}; + template size_t SnapshotCreator::AddData(Local context, Local object) { - T* object_ptr = *object; - internal::Address* p = reinterpret_cast(object_ptr); - return AddData(context, *p); + return AddData(context, SnapshotHelper::ObjectToAddress(*object)); } template size_t SnapshotCreator::AddData(Local object) { - T* object_ptr = *object; - internal::Address* p = reinterpret_cast(object_ptr); - return AddData(*p); + return AddData(SnapshotHelper::ObjectToAddress(*object)); } } // namespace v8 diff --git a/deps/v8/include/v8-template.h b/deps/v8/include/v8-template.h index 669012a9814465..11296cd48896dd 100644 --- a/deps/v8/include/v8-template.h +++ b/deps/v8/include/v8-template.h @@ -30,7 +30,9 @@ class Signature; F(AsyncIteratorPrototype, initial_async_iterator_prototype) \ F(ErrorPrototype, initial_error_prototype) \ F(IteratorPrototype, initial_iterator_prototype) \ - F(ObjProto_valueOf, object_value_of_function) + F(MapIteratorPrototype, initial_map_iterator_prototype) \ + F(ObjProto_valueOf, object_value_of_function) \ + F(SetIteratorPrototype, initial_set_iterator_prototype) enum Intrinsic { #define V8_DECL_INTRINSIC(name, iname) k##name, diff --git a/deps/v8/include/v8-traced-handle.h b/deps/v8/include/v8-traced-handle.h index e0fd57c49d4c55..41203b5671c523 100644 --- a/deps/v8/include/v8-traced-handle.h +++ b/deps/v8/include/v8-traced-handle.h @@ -62,7 +62,11 @@ class TracedReferenceBase { */ V8_INLINE v8::Local Get(v8::Isolate* isolate) const { if (IsEmpty()) return Local(); +#if V8_ENABLE_CONSERVATIVE_STACK_SCANNING + return Local::New(isolate, *reinterpret_cast(val_)); +#else return Local::New(isolate, reinterpret_cast(val_)); +#endif } /** @@ -117,11 +121,11 @@ class TracedReferenceBase { /** * A traced handle with copy and move semantics. The handle is to be used - * together with |v8::EmbedderHeapTracer| or as part of GarbageCollected objects - * (see v8-cppgc.h) and specifies edges from C++ objects to JavaScript. + * together as part of GarbageCollected objects (see v8-cppgc.h) or from stack + * and specifies edges from C++ objects to JavaScript. * * The exact semantics are: - * - Tracing garbage collections use |v8::EmbedderHeapTracer| or cppgc. + * - Tracing garbage collections using CppHeap. * - Non-tracing garbage collections refer to * |v8::EmbedderRootsHandler::IsRoot()| whether the handle should * be treated as root or not. @@ -135,7 +139,16 @@ class BasicTracedReference : public TracedReferenceBase { /** * Construct a Local from this handle. */ - Local Get(Isolate* isolate) const { return Local::New(isolate, *this); } + Local Get(Isolate* isolate) const { +#if V8_ENABLE_CONSERVATIVE_STACK_SCANNING + if (val_ == nullptr) { + return Local(); + } + return Local::New(isolate, *this); +#else + return Local::New(isolate, *this); +#endif + } template V8_INLINE BasicTracedReference& As() const { @@ -166,7 +179,6 @@ class BasicTracedReference : public TracedReferenceBase { Isolate* isolate, T* that, void* slot, internal::GlobalHandleStoreMode store_mode); - friend class EmbedderHeapTracer; template friend class Local; friend class Object; @@ -181,13 +193,7 @@ class BasicTracedReference : public TracedReferenceBase { /** * A traced handle without destructor that clears the handle. The embedder needs * to ensure that the handle is not accessed once the V8 object has been - * reclaimed. This can happen when the handle is not passed through the - * EmbedderHeapTracer. For more details see BasicTracedReference. - * - * The reference assumes the embedder has precise knowledge about references at - * all times. In case V8 needs to separately handle on-stack references, the - * embedder is required to set the stack start through - * |EmbedderHeapTracer::SetStackStart|. + * reclaimed. For more details see BasicTracedReference. */ template class TracedReference : public BasicTracedReference { @@ -291,7 +297,13 @@ template internal::Address* BasicTracedReference::New( Isolate* isolate, T* that, void* slot, internal::GlobalHandleStoreMode store_mode) { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + if (reinterpret_cast(that) == + internal::kLocalTaggedNullAddress) + return nullptr; +#else if (that == nullptr) return nullptr; +#endif internal::Address* p = reinterpret_cast(that); return internal::GlobalizeTracedReference( reinterpret_cast(isolate), p, diff --git a/deps/v8/include/v8-util.h b/deps/v8/include/v8-util.h index 159027d31786ff..90942c3e188c6a 100644 --- a/deps/v8/include/v8-util.h +++ b/deps/v8/include/v8-util.h @@ -181,7 +181,15 @@ class PersistentValueMapBase { * Get value stored in map. */ Local Get(const K& key) { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + auto p = FromVal(Traits::Get(&impl_, key)); + if (p == nullptr) { + return Local(); + } + return Local::New(p); +#else return Local::New(isolate_, FromVal(Traits::Get(&impl_, key))); +#endif } /** @@ -236,7 +244,11 @@ class PersistentValueMapBase { : value_(other.value_) { } Local NewLocal(Isolate* isolate) const { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + return Local::New(FromVal(value_)); +#else return Local::New(isolate, FromVal(value_)); +#endif } bool IsEmpty() const { return value_ == kPersistentContainerNotFound; @@ -613,7 +625,12 @@ class V8_DEPRECATE_SOON("Use std::vector>.") PersistentValueVector { * Retrieve the i-th value in the vector. */ Local Get(size_t index) const { +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + return Local::New( + isolate_, *reinterpret_cast(FromVal(Traits::Get(&impl_, index)))); +#else return Local::New(isolate_, FromVal(Traits::Get(&impl_, index))); +#endif } /** diff --git a/deps/v8/include/v8-value.h b/deps/v8/include/v8-value.h index 866da201245877..d3ef2030987cb6 100644 --- a/deps/v8/include/v8-value.h +++ b/deps/v8/include/v8-value.h @@ -344,6 +344,11 @@ class V8_EXPORT Value : public Data { */ bool IsWasmModuleObject() const; + /** + * Returns true if this value is the WasmNull object. + */ + bool IsWasmNull() const; + /** * Returns true if the value is a Module Namespace Object. */ @@ -469,7 +474,7 @@ bool Value::IsUndefined() const { bool Value::QuickIsUndefined() const { using A = internal::Address; using I = internal::Internals; - A obj = *reinterpret_cast(this); + A obj = internal::ValueHelper::ValueToAddress(this); if (!I::HasHeapObjectTag(obj)) return false; if (I::GetInstanceType(obj) != I::kOddballType) return false; return (I::GetOddballKind(obj) == I::kUndefinedOddballKind); @@ -486,7 +491,7 @@ bool Value::IsNull() const { bool Value::QuickIsNull() const { using A = internal::Address; using I = internal::Internals; - A obj = *reinterpret_cast(this); + A obj = internal::ValueHelper::ValueToAddress(this); if (!I::HasHeapObjectTag(obj)) return false; if (I::GetInstanceType(obj) != I::kOddballType) return false; return (I::GetOddballKind(obj) == I::kNullOddballKind); @@ -503,7 +508,7 @@ bool Value::IsNullOrUndefined() const { bool Value::QuickIsNullOrUndefined() const { using A = internal::Address; using I = internal::Internals; - A obj = *reinterpret_cast(this); + A obj = internal::ValueHelper::ValueToAddress(this); if (!I::HasHeapObjectTag(obj)) return false; if (I::GetInstanceType(obj) != I::kOddballType) return false; int kind = I::GetOddballKind(obj); @@ -521,7 +526,7 @@ bool Value::IsString() const { bool Value::QuickIsString() const { using A = internal::Address; using I = internal::Internals; - A obj = *reinterpret_cast(this); + A obj = internal::ValueHelper::ValueToAddress(this); if (!I::HasHeapObjectTag(obj)) return false; return (I::GetInstanceType(obj) < I::kFirstNonstringType); } diff --git a/deps/v8/include/v8-version.h b/deps/v8/include/v8-version.h index a9d6f92aff4599..80259952966c8f 100644 --- a/deps/v8/include/v8-version.h +++ b/deps/v8/include/v8-version.h @@ -8,9 +8,9 @@ // 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 10 -#define V8_MINOR_VERSION 9 -#define V8_BUILD_NUMBER 194 +#define V8_MAJOR_VERSION 11 +#define V8_MINOR_VERSION 2 +#define V8_BUILD_NUMBER 214 #define V8_PATCH_LEVEL 9 // Use 1 for candidates and 0 otherwise. diff --git a/deps/v8/include/v8config.h b/deps/v8/include/v8config.h index 2ac27b36b47ee3..9410eb41355567 100644 --- a/deps/v8/include/v8config.h +++ b/deps/v8/include/v8config.h @@ -173,6 +173,7 @@ path. Add it with -I to the command line // V8_TARGET_OS_LINUX // V8_TARGET_OS_MACOS // V8_TARGET_OS_WIN +// V8_TARGET_OS_CHROMEOS // // If not set explicitly, these fall back to corresponding V8_OS_ values. @@ -184,7 +185,8 @@ path. Add it with -I to the command line && !defined(V8_TARGET_OS_IOS) \ && !defined(V8_TARGET_OS_LINUX) \ && !defined(V8_TARGET_OS_MACOS) \ - && !defined(V8_TARGET_OS_WIN) + && !defined(V8_TARGET_OS_WIN) \ + && !defined(V8_TARGET_OS_CHROMEOS) # error No known target OS defined. # endif @@ -195,7 +197,8 @@ path. Add it with -I to the command line || defined(V8_TARGET_OS_IOS) \ || defined(V8_TARGET_OS_LINUX) \ || defined(V8_TARGET_OS_MACOS) \ - || defined(V8_TARGET_OS_WIN) + || defined(V8_TARGET_OS_WIN) \ + || defined(V8_TARGET_OS_CHROMEOS) # error A target OS is defined but V8_HAVE_TARGET_OS is unset. # endif @@ -308,6 +311,9 @@ path. Add it with -I to the command line // V8_HAS_BUILTIN_EXPECT - __builtin_expect() supported // V8_HAS_BUILTIN_FRAME_ADDRESS - __builtin_frame_address() supported // V8_HAS_BUILTIN_POPCOUNT - __builtin_popcount() supported +// V8_HAS_BUILTIN_ADD_OVERFLOW - __builtin_add_overflow() supported +// V8_HAS_BUILTIN_SUB_OVERFLOW - __builtin_sub_overflow() supported +// V8_HAS_BUILTIN_MUL_OVERFLOW - __builtin_mul_overflow() supported // V8_HAS_BUILTIN_SADD_OVERFLOW - __builtin_sadd_overflow() supported // V8_HAS_BUILTIN_SSUB_OVERFLOW - __builtin_ssub_overflow() supported // V8_HAS_BUILTIN_UADD_OVERFLOW - __builtin_uadd_overflow() supported @@ -339,9 +345,25 @@ path. Add it with -I to the command line # define V8_HAS_ATTRIBUTE_ALWAYS_INLINE (__has_attribute(always_inline)) # define V8_HAS_ATTRIBUTE_CONSTINIT \ (__has_attribute(require_constant_initialization)) +# define V8_HAS_ATTRIBUTE_CONST (__has_attribute(const)) # define V8_HAS_ATTRIBUTE_NONNULL (__has_attribute(nonnull)) # define V8_HAS_ATTRIBUTE_NOINLINE (__has_attribute(noinline)) # define V8_HAS_ATTRIBUTE_UNUSED (__has_attribute(unused)) +// Support for the "preserve_most" attribute is limited: +// - 32-bit platforms do not implement it, +// - component builds fail because _dl_runtime_resolve clobbers registers, +// - we see crashes on arm64 on Windows (https://crbug.com/1409934), which can +// hopefully be fixed in the future. +// Additionally, the initial implementation in clang <= 16 overwrote the return +// register(s) in the epilogue of a preserve_most function, so we only use +// preserve_most in clang >= 17 (see https://reviews.llvm.org/D143425). +#if (defined(_M_X64) || defined(__x86_64__) /* x64 (everywhere) */ \ + || ((defined(__AARCH64EL__) || defined(_M_ARM64)) /* arm64, but ... */ \ + && !defined(_WIN32))) /* not on windows */ \ + && !defined(COMPONENT_BUILD) /* no component build */\ + && __clang_major__ >= 17 /* clang >= 17 */ +# define V8_HAS_ATTRIBUTE_PRESERVE_MOST (__has_attribute(preserve_most)) +#endif # define V8_HAS_ATTRIBUTE_VISIBILITY (__has_attribute(visibility)) # define V8_HAS_ATTRIBUTE_WARN_UNUSED_RESULT \ (__has_attribute(warn_unused_result)) @@ -360,6 +382,9 @@ path. Add it with -I to the command line # define V8_HAS_BUILTIN_EXPECT (__has_builtin(__builtin_expect)) # define V8_HAS_BUILTIN_FRAME_ADDRESS (__has_builtin(__builtin_frame_address)) # define V8_HAS_BUILTIN_POPCOUNT (__has_builtin(__builtin_popcount)) +# define V8_HAS_BUILTIN_ADD_OVERFLOW (__has_builtin(__builtin_add_overflow)) +# define V8_HAS_BUILTIN_SUB_OVERFLOW (__has_builtin(__builtin_sub_overflow)) +# define V8_HAS_BUILTIN_MUL_OVERFLOW (__has_builtin(__builtin_mul_overflow)) # define V8_HAS_BUILTIN_SADD_OVERFLOW (__has_builtin(__builtin_sadd_overflow)) # define V8_HAS_BUILTIN_SSUB_OVERFLOW (__has_builtin(__builtin_ssub_overflow)) # define V8_HAS_BUILTIN_UADD_OVERFLOW (__has_builtin(__builtin_uadd_overflow)) @@ -455,6 +480,16 @@ path. Add it with -I to the command line #endif +// A macro to mark functions whose values don't change (e.g. across calls) +// and thereby compiler is free to hoist and fold multiple calls together. +// Use like: +// V8_CONST int foo() { ... } +#if V8_HAS_ATTRIBUTE_CONST +# define V8_CONST __attribute__((const)) +#else +# define V8_CONST +#endif + // A macro to mark a declaration as requiring constant initialization. // Use like: // int* foo V8_CONSTINIT; @@ -487,6 +522,21 @@ path. Add it with -I to the command line #endif +// A macro used to change the calling conventions to preserve all registers (no +// caller-saved registers). Use this for cold functions called from hot +// functions. +// Note: The attribute is considered experimental, so apply with care. Also, +// "preserve_most" is currently not handling the return value correctly, so only +// use it for functions returning void (see https://reviews.llvm.org/D141020). +// Use like: +// V8_NOINLINE V8_PRESERVE_MOST void UnlikelyMethod(); +#if V8_HAS_ATTRIBUTE_PRESERVE_MOST +# define V8_PRESERVE_MOST __attribute__((preserve_most)) +#else +# define V8_PRESERVE_MOST /* NOT SUPPORTED */ +#endif + + // A macro (V8_DEPRECATED) to mark classes or functions as deprecated. #if defined(V8_DEPRECATION_WARNINGS) # define V8_DEPRECATED(message) [[deprecated(message)]] diff --git a/deps/v8/infra/mb/gn_isolate_map.pyl b/deps/v8/infra/mb/gn_isolate_map.pyl index 5732d862189c1a..934ff59b2ff985 100644 --- a/deps/v8/infra/mb/gn_isolate_map.pyl +++ b/deps/v8/infra/mb/gn_isolate_map.pyl @@ -31,6 +31,10 @@ "label": "//test:v8_d8_default", "type": "script", }, + "d8_pgo": { + "label": "//test:d8_pgo", + "type": "script", + }, "generate-bytecode-expectations": { "label": "//test/unittests:generate-bytecode-expectations", "type": "script", diff --git a/deps/v8/infra/mb/mb_config.pyl b/deps/v8/infra/mb/mb_config.pyl index b5d6231600488a..10bfce89a16893 100644 --- a/deps/v8/infra/mb/mb_config.pyl +++ b/deps/v8/infra/mb/mb_config.pyl @@ -52,6 +52,10 @@ 'linux-v8-dr': 'release_x64', }, 'client.v8': { + # PGO + 'V8 Linux PGO instrumentation - builder' : 'builtins_profiling_x86', + 'V8 Linux64 PGO instrumentation - builder' : 'builtins_profiling_x64', + # Linux. 'V8 Linux - builder': 'release_x86_gcmole', 'V8 Linux - debug builder': 'debug_x86', @@ -59,14 +63,13 @@ 'V8 Linux - noi18n - debug builder': 'debug_x86_no_i18n', 'V8 Linux - verify csa - builder': 'release_x86_verify_csa', # Linux64. - 'V8 Linux64 - builder': 'release_x64', + 'V8 Linux64 - builder': 'release_x64_gcmole', 'V8 Linux64 - builder (goma cache silo)': 'release_x64', 'V8 Linux64 - builder (reclient)': 'release_x64_reclient', 'V8 Linux64 - builder (reclient compare)': 'release_x64_reclient', 'V8 Linux64 - debug builder': 'debug_x64', 'V8 Linux64 - external code space - debug - builder': 'debug_x64_external_code_space', 'V8 Linux64 - custom snapshot - debug builder': 'debug_x64_custom', - 'V8 Linux64 - heap sandbox - debug - builder': 'debug_x64_heap_sandbox', 'V8 Linux64 - internal snapshot - builder': 'release_x64_internal', 'V8 Linux64 - debug - header includes - builder': 'debug_x64_header_includes', 'V8 Linux64 - no sandbox - debug builder': 'debug_x64_no_sandbox', @@ -80,6 +83,7 @@ 'V8 Win32 - builder (reclient)': 'release_x86_minimal_symbols_reclient', 'V8 Win32 - builder (reclient compare)': 'release_x86_minimal_symbols_reclient', 'V8 Win32 - debug builder': 'debug_x86_minimal_symbols', + 'V8 Win32 - msvc - debug builder': 'debug_x86_msvc', # TODO(machenbach): Remove after switching to x64 on infra side. 'V8 Win64 ASAN - builder': 'release_x64_asan_no_lsan', 'V8 Win64 - builder': 'release_x64_minimal_symbols', @@ -103,14 +107,15 @@ # Sanitizers. 'V8 Linux64 ASAN - builder': 'release_x64_asan', 'V8 Linux64 TSAN - builder': 'release_x64_tsan', + 'V8 Linux64 TSAN - debug builder': 'debug_x64_tsan_minimal_symbols', 'V8 Linux64 TSAN - no-concurrent-marking - builder': 'release_x64_tsan_no_cm', 'V8 Linux - arm64 - sim - CFI - builder': 'release_simulate_arm64_cfi', 'V8 Linux - arm64 - sim - MSAN - builder': 'release_simulate_arm64_msan', # FYI. 'V8 iOS - sim - builder': 'release_x64_ios_simulator', - 'V8 Linux64 - arm64 - sim - heap sandbox - debug - builder': 'debug_x64_heap_sandbox_arm64_sim', 'V8 Linux64 - arm64 - sim - no pointer compression - builder': 'release_simulate_arm64_no_pointer_compression', + 'V8 Linux64 - coverage': 'release_x64_coverage', 'V8 Linux64 - cppgc-non-default - debug - builder': 'debug_x64_non_default_cppgc', 'V8 Linux64 - debug - perfetto - builder': 'debug_x64_perfetto', 'V8 Linux64 - disable runtime call stats - builder': 'release_x64_disable_runtime_call_stats', @@ -168,22 +173,28 @@ 'V8 Clusterfuzz Linux64 UBSan - release builder': 'release_x64_ubsan_recover', 'V8 Clusterfuzz Linux64 ASAN sandbox testing - release builder': - 'release_x64_asan_sandbox_testing', + 'release_x64_asan_symbolized_expose_memory_corruption', }, 'client.v8.perf' : { 'V8 Arm - builder - perf': 'official_arm', + 'V8 Arm - builder - pgo - perf': 'official_arm', 'V8 Android Arm - builder - perf': 'official_android_arm', + 'V8 Android Arm - builder - pgo - perf': 'official_android_arm', 'V8 Android Arm64 - builder - perf': 'official_android_arm64', + 'V8 Android Arm64 - builder - pgo - perf': 'official_android_arm64', 'V8 Linux - builder - perf': 'official_x86', + 'V8 Linux - builder - pgo - perf': 'official_x86', 'V8 Linux64 - builder - perf': 'official_x64', + 'V8 Linux64 - builder - pgo - perf': 'official_x64', 'V8 Mac Arm64 - builder - perf': 'official_mac_arm64', + 'V8 Mac Arm64 - builder - pgo - perf': 'official_mac_arm64', }, 'client.v8.ports': { # Arm. 'V8 Arm - builder': 'release_arm', 'V8 Arm - debug builder': 'debug_arm', 'V8 Android Arm - builder': 'release_android_arm', - 'V8 Linux - arm - sim - builder': 'release_simulate_arm', + 'V8 Linux - arm - sim - builder': 'release_simulate_arm_gcmole', 'V8 Linux - arm - sim - debug builder': 'debug_simulate_arm', 'V8 Linux - arm - sim - lite - builder': 'release_simulate_arm_lite', 'V8 Linux - arm - sim - lite - debug builder': 'debug_simulate_arm_lite', @@ -191,7 +202,7 @@ 'V8 Android Arm64 - builder': 'release_android_arm64', 'V8 Android Arm64 - debug builder': 'debug_android_arm64', 'V8 Arm64 - builder': 'release_arm64_hard_float', - 'V8 Linux - arm64 - sim - builder': 'release_simulate_arm64', + 'V8 Linux - arm64 - sim - builder': 'release_simulate_arm64_gcmole', 'V8 Linux - arm64 - sim - debug builder': 'debug_simulate_arm64', 'V8 Linux - arm64 - sim - gc stress - builder': 'debug_simulate_arm64', # Mips. @@ -225,6 +236,7 @@ 'release_simulate_arm64_no_pointer_compression', 'v8_linux64_cppgc_non_default_compile_dbg': 'debug_x64_non_default_cppgc', 'v8_linux64_compile_dbg': 'debug_x64_trybot', + 'v8_linux64_coverage': 'release_x64_coverage', 'v8_linux64_no_sandbox_compile_dbg': 'debug_x64_no_sandbox', 'v8_linux64_dict_tracking_compile_dbg': 'debug_x64_dict_tracking_trybot', 'v8_linux64_disable_runtime_call_stats_compile_rel': 'release_x64_disable_runtime_call_stats', @@ -237,14 +249,12 @@ 'v8_linux64_gcc_compile_rel': 'release_x64_gcc', 'v8_linux64_gcov_coverage': 'release_x64_gcc_coverage', 'v8_linux64_header_includes_dbg': 'debug_x64_header_includes', - 'v8_linux64_heap_sandbox_compile_dbg': 'debug_x64_heap_sandbox', 'v8_linux64_minor_mc_compile_dbg': 'debug_x64_trybot', - 'v8_linux_arm64_sim_heap_sandbox_compile_dbg': 'debug_x64_heap_sandbox_arm64_sim', 'v8_linux64_fyi_compile_rel': 'release_x64_test_features_trybot', 'v8_linux64_nodcheck_compile_rel': 'release_x64', 'v8_linux64_perfetto_compile_dbg': 'debug_x64_perfetto', 'v8_linux64_no_pointer_compression_compile_rel': 'release_x64_no_pointer_compression', - 'v8_linux64_compile_rel': 'release_x64_test_features_trybot', + 'v8_linux64_compile_rel': 'release_x64_test_features_gcmole_trybot', 'v8_linux64_no_sandbox_compile_rel': 'release_x64_no_sandbox', 'v8_linux64_predictable_compile_rel': 'release_x64_predictable', 'v8_linux64_shared_compile_rel': 'release_x64_shared_verify_heap', @@ -259,6 +269,7 @@ 'v8_linux_riscv32_compile_rel': 'release_simulate_riscv32', 'v8_linux64_riscv64_compile_rel': 'release_simulate_riscv64', 'v8_linux64_tsan_compile_rel': 'release_x64_tsan_minimal_symbols', + 'v8_linux64_tsan_compile_dbg': 'debug_x64_tsan_minimal_symbols', 'v8_linux64_tsan_no_cm_compile_rel': 'release_x64_tsan_no_cm', 'v8_linux64_tsan_isolates_compile_rel': 'release_x64_tsan_minimal_symbols', @@ -268,6 +279,7 @@ # TODO(machenbach): Remove after switching to x64 on infra side. 'v8_win_compile_dbg': 'debug_x86_trybot', 'v8_win_compile_rel': 'release_x86_trybot', + 'v8_win_msvc_light_compile_dbg': 'debug_x86_msvc', 'v8_win64_asan_compile_rel': 'release_x64_asan_no_lsan', 'v8_win64_msvc_light_compile_rel': 'release_x64_msvc', 'v8_win64_compile_dbg': 'debug_x64_minimal_symbols', @@ -284,15 +296,15 @@ 'v8_mac64_compile_rel': 'release_x64_trybot', 'v8_mac64_dbg': 'debug_x64', 'v8_mac64_compile_dbg': 'debug_x64', - 'v8_mac64_compile_full_compile_dbg': 'full_debug_x64', + 'v8_mac64_noopt_compile_dbg': 'full_debug_x64', 'v8_mac64_asan_compile_rel': 'release_x64_asan_no_lsan', - 'v8_linux_arm_compile_rel': 'release_simulate_arm_trybot', + 'v8_linux_arm_compile_rel': 'release_simulate_arm_gcmole_trybot', 'v8_linux_arm_lite_compile_dbg': 'debug_simulate_arm_lite', 'v8_linux_arm_lite_compile_rel': 'release_simulate_arm_lite_trybot', 'v8_linux_arm_compile_dbg': 'debug_simulate_arm', 'v8_linux_arm_armv8a_rel': 'release_simulate_arm_trybot', 'v8_linux_arm_armv8a_dbg': 'debug_simulate_arm', - 'v8_linux_arm64_compile_rel': 'release_simulate_arm64_trybot', + 'v8_linux_arm64_compile_rel': 'release_simulate_arm64_gcmole_trybot', 'v8_linux_arm64_cfi_compile_rel' : 'release_simulate_arm64_cfi', 'v8_linux_arm64_compile_dbg': 'debug_simulate_arm64', 'v8_linux_arm64_gc_stress_compile_dbg': 'debug_simulate_arm64', @@ -399,20 +411,26 @@ 'debug_bot', 'simulate_arm64', 'asan', 'lsan'], # Release configs for simulators. - 'release_simulate_arm': [ - 'release_bot', 'simulate_arm'], + 'release_simulate_arm_gcmole': [ + 'release_bot', 'simulate_arm', 'gcmole'], 'release_simulate_arm_lite': [ 'release_bot', 'simulate_arm', 'v8_enable_lite_mode'], - 'release_simulate_arm_trybot': [ - 'release_trybot', 'simulate_arm'], + 'release_simulate_arm_gcmole_trybot': [ + 'release_trybot', 'simulate_arm', 'gcmole'], 'release_simulate_arm_lite_trybot': [ 'release_trybot', 'simulate_arm', 'v8_enable_lite_mode'], + 'release_simulate_arm_trybot': [ + 'release_trybot', 'simulate_arm'], 'release_simulate_arm64': [ 'release_bot', 'simulate_arm64'], 'release_simulate_arm64_cfi': [ 'release_bot', 'simulate_arm64', 'v8_control_flow_integrity'], + 'release_simulate_arm64_gcmole': [ + 'release_bot', 'simulate_arm64', 'gcmole'], + 'release_simulate_arm64_gcmole_trybot': [ + 'release_trybot', 'simulate_arm64', 'gcmole'], 'release_simulate_arm64_no_pointer_compression': [ - 'release_bot', 'simulate_arm64_no_sandbox', 'dcheck_always_on', + 'release_bot', 'simulate_arm64', 'no_sandbox', 'dcheck_always_on', 'v8_enable_slow_dchecks', 'v8_disable_pointer_compression'], 'release_simulate_arm64_msan': [ 'release_bot', 'simulate_arm64', 'msan'], @@ -445,7 +463,7 @@ 'debug_arm64': [ 'debug_bot', 'arm64'], 'debug_arm64_no_pointer_compression': [ - 'debug_bot', 'arm64_no_sandbox', 'dcheck_always_on', 'v8_enable_slow_dchecks', 'v8_enable_javascript_promise_hooks', + 'debug_bot', 'arm64', 'no_sandbox', 'dcheck_always_on', 'v8_enable_slow_dchecks', 'v8_enable_javascript_promise_hooks', 'v8_disable_pointer_compression'], 'full_debug_arm64': [ 'debug_bot', 'arm64', 'v8_full_debug'], @@ -492,6 +510,9 @@ 'release_x64_asan_no_lsan_verify_heap_dchecks': [ 'release_bot', 'x64', 'asan', 'dcheck_always_on', 'v8_enable_slow_dchecks', 'v8_verify_heap'], + 'release_x64_asan_symbolized_expose_memory_corruption': [ + 'release_bot', 'x64', 'asan', 'symbolized', + 'v8_expose_memory_corruption_api'], 'release_x64_asan_symbolized_verify_heap': [ 'release_bot', 'x64', 'asan', 'lsan', 'symbolized', 'v8_verify_heap'], @@ -499,9 +520,13 @@ 'release_bot', 'x64', 'cfi'], 'release_x64_cfi_clusterfuzz': [ 'release_bot', 'x64', 'cfi_clusterfuzz'], + 'release_x64_coverage': [ + 'release_bot', 'x64', 'clang_coverage'], 'release_x64_fuzzilli': [ 'release_bot', 'x64', 'dcheck_always_on', 'v8_enable_slow_dchecks', 'v8_verify_heap', 'v8_verify_csa', 'fuzzilli'], + 'release_x64_gcmole': [ + 'release_bot', 'x64', 'gcmole'], 'release_x64_msvc': [ 'release_bot_no_goma', 'x64', 'minimal_symbols', 'msvc'], 'release_x64_correctness_fuzzer' : [ @@ -526,14 +551,16 @@ 'release_x64_minimal_symbols_reclient': [ 'release_bot_reclient', 'x64', 'minimal_symbols'], 'release_x64_no_pointer_compression': [ - 'release_bot', 'x64_no_sandbox', 'dcheck_always_on', 'v8_enable_slow_dchecks', 'v8_enable_javascript_promise_hooks', - 'v8_disable_pointer_compression'], + 'release_bot', 'x64', 'no_sandbox', 'dcheck_always_on', 'v8_enable_slow_dchecks', + 'v8_enable_javascript_promise_hooks', 'v8_disable_pointer_compression'], 'release_x64_reclient': [ 'release_bot_reclient', 'x64'], 'release_x64_no_sandbox': [ - 'release_bot', 'x64_no_sandbox'], + 'release_bot', 'x64', 'no_sandbox'], 'release_x64_trybot': [ 'release_trybot', 'x64'], + 'release_x64_test_features_gcmole_trybot': [ + 'release_trybot', 'x64', 'v8_enable_test_features', 'gcmole'], 'release_x64_test_features_trybot': [ 'release_trybot', 'x64', 'v8_enable_test_features'], 'release_x64_tsan': [ @@ -555,9 +582,6 @@ 'v8_enable_slow_dchecks', 'v8_verify_csa'], 'release_x64_webassembly_disabled': [ 'release_bot', 'x64', 'webassembly_disabled'], - 'release_x64_asan_sandbox_testing': [ - 'release_bot', 'x64', 'asan', 'symbolized', 'v8_enable_sandbox_future', - 'v8_expose_memory_corruption_api'], # Official configs for x64. 'official_x64': [ @@ -583,10 +607,6 @@ 'debug_bot_no_goma', 'x64', 'gcc', 'lld', 'no_custom_libcxx'], 'debug_x64_header_includes': [ 'debug_bot', 'x64', 'v8_check_header_includes'], - 'debug_x64_heap_sandbox': [ - 'debug_bot', 'x64', 'v8_enable_sandbox_future', 'v8_expose_memory_corruption_api'], - 'debug_x64_heap_sandbox_arm64_sim': [ - 'debug_bot', 'simulate_arm64', 'v8_enable_sandbox_future', 'v8_expose_memory_corruption_api'], 'debug_x64_minimal_symbols': [ 'debug_bot', 'x64', 'minimal_symbols'], 'debug_x64_non_default_cppgc': [ @@ -594,7 +614,7 @@ 'debug_x64_perfetto': [ 'debug_bot', 'x64', 'perfetto'], 'debug_x64_no_sandbox': [ - 'debug_bot', 'x64_no_sandbox'], + 'debug_bot', 'x64', 'no_sandbox'], 'debug_x64_single_generation': [ 'debug_bot', 'x64', 'v8_enable_single_generation'], 'debug_x64_trybot': [ @@ -603,6 +623,9 @@ 'debug_trybot', 'x64', 'v8_enable_dict_property_const_tracking'], 'debug_x64_trybot_custom': [ 'debug_trybot', 'x64', 'v8_snapshot_custom'], + 'debug_x64_tsan_minimal_symbols': [ + 'debug_bot_no_slow_dchecks', 'minimal_symbols', 'x64', 'dcheck_always_on', + 'tsan', 'v8_disable_verify_heap', 'v8_fast_mksnapshot'], 'full_debug_x64': [ 'debug_bot', 'x64', 'v8_full_debug'], @@ -613,6 +636,8 @@ 'debug_bot', 'x86', 'asan', 'lsan'], 'debug_x86_minimal_symbols': [ 'debug_bot', 'x86', 'minimal_symbols'], + 'debug_x86_msvc': [ + 'debug_bot_no_goma', 'x86', 'minimal_symbols', 'msvc'], 'debug_x86_no_i18n': [ 'debug_bot', 'x86', 'v8_no_i18n'], 'debug_x86_trybot': [ @@ -654,7 +679,11 @@ # Torque compare test 'torque_compare': [ - 'release_bot', 'verify_torque'] + 'release_bot', 'verify_torque'], + + # PGO + 'builtins_profiling_x86': ['builtins_profiling', 'x86'], + 'builtins_profiling_x64': ['builtins_profiling', 'x64'], }, 'mixins': { @@ -671,11 +700,7 @@ }, 'arm64': { - 'gn_args': 'target_cpu="arm64" v8_enable_sandbox=true', - }, - - 'arm64_no_sandbox': { - 'gn_args': 'target_cpu="arm64" v8_enable_sandbox=false', + 'gn_args': 'target_cpu="arm64"', }, 'asan': { @@ -683,6 +708,11 @@ 'gn_args': 'is_asan=true', }, + 'builtins_profiling': { + 'mixins' : ['release_bot_reclient'], + 'gn_args': 'v8_enable_builtins_profiling=true', + }, + 'cfi': { 'mixins': ['v8_enable_test_features'], 'gn_args': ('is_cfi=true use_cfi_cast=true use_cfi_icall=true ' @@ -699,6 +729,10 @@ 'gn_args': 'is_clang=true', }, + 'clang_coverage': { + 'gn_args': 'use_clang_coverage=true', + }, + 'conservative_stack_scanning': { 'gn_args': 'v8_enable_conservative_stack_scanning=true ' 'v8_enable_inner_pointer_resolution_mb=true', @@ -716,6 +750,12 @@ 'gn_args': 'is_debug=true v8_enable_backtrace=true', }, + 'debug_bot_no_slow_dchecks': { + 'mixins': [ + 'debug', 'shared', 'goma', 'v8_disable_slow_dchecks', + 'v8_optimized_debug', 'v8_enable_google_benchmark'], + }, + 'debug_bot': { 'mixins': [ 'debug', 'shared', 'goma', 'v8_enable_slow_dchecks', @@ -793,12 +833,12 @@ 'msan': { 'mixins': ['v8_enable_test_features'], - 'gn_args': 'is_msan=true msan_track_origins=2', + 'gn_args': 'is_msan=true msan_track_origins=2 instrumented_libraries_release="focal"', }, 'msan_no_origins': { 'mixins': ['v8_enable_test_features'], - 'gn_args': 'is_msan=true msan_track_origins=0', + 'gn_args': 'is_msan=true msan_track_origins=0 instrumented_libraries_release="focal"', }, 'msvc': { @@ -813,6 +853,10 @@ 'gn_args': 'use_goma=false', }, + 'no_sandbox': { + 'gn_args': 'v8_enable_sandbox=false', + }, + 'no_sysroot': { 'gn_args': 'use_sysroot=false', }, @@ -862,11 +906,7 @@ }, 'simulate_arm64': { - 'gn_args': 'target_cpu="x64" v8_target_cpu="arm64" v8_enable_sandbox=true', - }, - - 'simulate_arm64_no_sandbox': { - 'gn_args': 'target_cpu="x64" v8_target_cpu="arm64" v8_enable_sandbox=false', + 'gn_args': 'target_cpu="x64" v8_target_cpu="arm64"', }, 'simulate_loong64': { @@ -938,8 +978,8 @@ 'gn_args': 'v8_enable_runtime_call_stats=false', }, - 'v8_enable_sandbox_future': { - 'gn_args': 'v8_enable_sandbox_future=true', + 'v8_disable_verify_heap': { + 'gn_args': 'v8_enable_verify_heap=false', }, 'v8_expose_memory_corruption_api': { @@ -954,6 +994,10 @@ 'gn_args': 'v8_enable_slow_dchecks=true', }, + 'v8_disable_slow_dchecks': { + 'gn_args': 'v8_enable_slow_dchecks=false', + }, + 'v8_enable_javascript_promise_hooks': { 'gn_args': 'v8_enable_javascript_promise_hooks=true', }, @@ -989,6 +1033,10 @@ 'gn_args': 'v8_enable_vtunejit=true v8_enable_vtunetracemark=true', }, + 'v8_fast_mksnapshot': { + 'gn_args': 'v8_enable_fast_mksnapshot=true', + }, + 'v8_full_debug': { 'gn_args': 'v8_optimized_debug=false', }, @@ -1031,11 +1079,7 @@ }, 'x64': { - 'gn_args': 'target_cpu="x64" v8_enable_sandbox=true', - }, - - 'x64_no_sandbox': { - 'gn_args': 'target_cpu="x64" v8_enable_sandbox=false', + 'gn_args': 'target_cpu="x64"', }, 'x86': { diff --git a/deps/v8/infra/testing/builders.pyl b/deps/v8/infra/testing/builders.pyl index 19d5e1845249ec..837d2f5aeed816 100644 --- a/deps/v8/infra/testing/builders.pyl +++ b/deps/v8/infra/testing/builders.pyl @@ -89,7 +89,8 @@ 'name': 'test262', 'suffix': 'noavx', 'variant': 'default', - 'test_args': ['--extra-flags', '--noenable-avx'] + 'test_args': ['--extra-flags', '--noenable-avx'], + 'shards': 2 }, { 'name': 'v8testing', @@ -149,7 +150,7 @@ }, 'tests': [ {'name': 'mozilla', 'variant': 'default'}, - {'name': 'test262', 'variant': 'default'}, + {'name': 'test262', 'variant': 'default', 'shards': 2}, {'name': 'v8testing', 'variant': 'default', 'shards': 2}, ], }, @@ -179,7 +180,7 @@ ], 'shards': 4, }, - {'name': 'gcmole'}, + {'name': 'gcmole_v3', 'variant': 'ia32', 'shards': 4}, ], }, 'v8_linux_optional_rel': { @@ -210,6 +211,7 @@ '--extra-flags', '--noenable-sse3 --noenable-ssse3 --noenable-sse4-1 --noenable-avx', ], + 'shards': 2, }, { 'name': 'v8testing', @@ -237,6 +239,7 @@ '--extra-flags', '--noenable-ssse3 --noenable-sse4-1 --noenable-avx', ], + 'shards': 2, }, { 'name': 'v8testing', @@ -258,6 +261,7 @@ 'suffix': 'nosse4', 'variant': 'default', 'test_args': ['--extra-flags', '--noenable-sse4-1 --noenable-avx'], + 'shards': 2, }, { 'name': 'v8testing', @@ -275,7 +279,8 @@ 'name': 'test262', 'suffix': 'noavx', 'variant': 'default', - 'test_args': ['--extra-flags', '--noenable-avx'] + 'test_args': ['--extra-flags', '--noenable-avx'], + 'shards': 2, }, { 'name': 'v8testing', @@ -325,6 +330,7 @@ {'name': 'test262', 'variant': 'default', 'shards': 2}, {'name': 'v8testing', 'shards': 10}, {'name': 'v8testing', 'variant': 'extra', 'shards': 10}, + {'name': 'gcmole_v3', 'variant': 'arm', 'shards': 4}, ], }, ############################################################################## @@ -348,10 +354,22 @@ {'name': 'benchmarks'}, {'name': 'mozilla'}, {'name': 'optimize_for_size'}, - {'name': 'test262', 'variant': 'default'}, + {'name': 'test262', 'variant': 'default', 'shards': 2}, {'name': 'v8testing', 'shards': 3}, ], }, + 'v8_linux64_coverage': { + 'swarming_dimensions' : { + 'os': 'Ubuntu-18.04', + }, + 'tests': [ + # TODO(https://crbug.com/1265931): Speed things up for now. Later replace + # mjsunit and unittests with full v8testing. + # {'name': 'v8testing'}, + {'name': 'mjsunit', 'variant': 'default'}, + {'name': 'unittests', 'variant': 'default'}, + ], + }, 'v8_linux64_cppgc_non_default_dbg': { 'swarming_dimensions' : { 'cpu': 'x86-64-avx2', @@ -361,6 +379,14 @@ {'name': 'v8testing', 'shards': 3}, ], }, + 'v8_linux64_css_dbg': { + 'swarming_dimensions' : { + 'os': 'Ubuntu-18.04', + }, + 'tests': [ + {'name': 'v8testing', 'shards': 5}, + ], + }, 'v8_linux64_dbg': { 'swarming_dimensions' : { 'cpu': 'x86-64-avx2', @@ -430,14 +456,12 @@ {'name': 'webkit', 'variant': 'stress_sampling'}, # Stress snapshot. {'name': 'mjsunit', 'variant': 'stress_snapshot'}, - # Maglev. - {'name': 'mjsunit', 'variant': 'maglev'}, # Stress maglev. {'name': 'mjsunit', 'variant': 'stress_maglev'}, + # Stress maglev-inlining. + {'name': 'mjsunit', 'variant': 'maglev_inlining'}, # Experimental regexp engine. {'name': 'mjsunit', 'variant': 'experimental_regexp'}, - # Wasm write protect code space. - {'name': 'mjsunit', 'variant': 'wasm_write_protect_code'}, ], }, 'v8_linux64_gc_stress_custom_snapshot_dbg': { @@ -489,14 +513,6 @@ {'name': 'v8testing'}, ], }, - 'v8_linux64_heap_sandbox_dbg': { - 'swarming_dimensions' : { - 'os': 'Ubuntu-18.04', - }, - 'tests': [ - {'name': 'v8testing', 'shards': 4}, - ], - }, 'v8_linux64_minor_mc_dbg': { 'swarming_dimensions' : { 'cpu': 'x86-64-avx2', @@ -512,7 +528,7 @@ }, 'v8_linux64_msan_rel': { 'swarming_dimensions' : { - 'os': 'Ubuntu-18.04', + 'os': 'Ubuntu-20.04', }, 'tests': [ {'name': 'test262', 'variant': 'default', 'shards': 2}, @@ -599,6 +615,20 @@ {'name': 'v8testing', 'variant': 'stress_instruction_scheduling'}, # Maglev -- move to extra once more architectures are supported. {'name': 'mjsunit', 'variant': 'maglev'}, + # GCMole. + {'name': 'gcmole_v3', 'variant': 'x64', 'shards': 4}, + { + 'name': 'gcmole_v2', + 'variant': 'x64', + 'suffix': 'test single host', + 'test_args': ['--test-run'], + }, + { + 'name': 'gcmole_v3', + 'variant': 'x64', + 'suffix': 'test multi host', + 'test_args': ['--test-run'], + }, ], }, 'v8_linux64_predictable_rel': { @@ -635,6 +665,18 @@ {'name': 'v8testing', 'variant': 'stress_concurrent_allocation', 'shards': 2}, ], }, + 'v8_linux64_tsan_dbg': { + 'swarming_dimensions' : { + 'os': 'Ubuntu-18.04', + }, + 'tests': [ + {'name': 'benchmarks', 'shards': 2}, + {'name': 'mozilla', 'shards': 4}, + {'name': 'test262', 'variant': 'default', 'shards': 5}, + {'name': 'v8testing', 'shards': 12}, + {'name': 'v8testing', 'variant': 'extra', 'shards': 10}, + ], + }, 'v8_linux64_tsan_no_cm_rel': { 'swarming_dimensions' : { 'os': 'Ubuntu-18.04', @@ -699,14 +741,6 @@ {'name': 'd8testing', 'test_args': ['--gc-stress'], 'shards': 12}, ], }, - 'v8_linux_arm64_sim_heap_sandbox_dbg': { - 'swarming_dimensions' : { - 'os': 'Ubuntu-18.04', - }, - 'tests': [ - {'name': 'v8testing', 'shards': 14}, - ], - }, 'v8_linux_arm64_rel': { 'swarming_dimensions' : { 'os': 'Ubuntu-18.04', @@ -717,6 +751,7 @@ {'name': 'test262', 'variant': 'default', 'shards': 4}, {'name': 'v8testing', 'shards': 14}, {'name': 'v8testing', 'variant': 'extra', 'shards': 14}, + {'name': 'gcmole_v3', 'variant': 'arm64', 'shards': 4}, ], }, 'v8_linux_arm64_cfi_rel': { @@ -787,7 +822,7 @@ 'v8_win_dbg': { 'swarming_dimensions' : { 'cpu': 'x86-64', - 'os': 'Windows-7-SP1', + 'os': 'Windows-10-19045', }, 'tests': [ {'name': 'mozilla'}, @@ -797,7 +832,7 @@ 'v8_win_rel': { 'swarming_dimensions' : { 'cpu': 'x86-64', - 'os': 'Windows-7-SP1', + 'os': 'Windows-10-19045', }, 'tests': [ {'name': 'mozilla'}, @@ -809,7 +844,7 @@ # Win64 'v8_win64_asan_rel': { 'swarming_dimensions' : { - 'os': 'Windows-10-19042', + 'os': 'Windows-10-19045', }, 'tests': [ {'name': 'v8testing', 'shards': 5}, @@ -818,7 +853,7 @@ 'v8_win64_dbg': { 'swarming_dimensions' : { 'cpu': 'x86-64', - 'os': 'Windows-10-19042', + 'os': 'Windows-10-19045', }, 'tests': [ {'name': 'mozilla'}, @@ -830,7 +865,7 @@ 'v8_win64_msvc_rel': { 'swarming_dimensions' : { 'cpu': 'x86-64', - 'os': 'Windows-10-19042', + 'os': 'Windows-10-19045', }, 'tests': [ {'name': 'mozilla'}, @@ -841,7 +876,7 @@ 'v8_win64_rel': { 'swarming_dimensions' : { 'cpu': 'x86-64', - 'os': 'Windows-10-19042', + 'os': 'Windows-10-19045', }, 'tests': [ {'name': 'mozilla'}, @@ -855,7 +890,7 @@ 'v8_mac64_asan_rel': { 'swarming_dimensions' : { 'cpu': 'x86-64', - 'os': 'Mac-10.15', + 'os': 'Mac-12', }, 'tests': [ {'name': 'v8testing', 'shards': 8}, @@ -864,7 +899,7 @@ 'v8_mac64_dbg': { 'swarming_dimensions' : { 'cpu': 'x86-64', - 'os': 'Mac-10.15', + 'os': 'Mac-12', }, 'tests': [ {'name': 'mozilla'}, @@ -876,16 +911,25 @@ 'v8_mac64_gc_stress_dbg': { 'swarming_dimensions' : { 'cpu': 'x86-64', - 'os': 'Mac-10.15', + 'os': 'Mac-12', }, 'tests': [ {'name': 'd8testing', 'test_args': ['--gc-stress'], 'shards': 6}, ], }, + 'v8_mac64_noopt_dbg': { + 'swarming_dimensions' : { + 'cpu': 'x86-64', + 'os': 'Mac-12', + }, + 'tests': [ + {'name': 'v8testing', 'shards': 6}, + ], + }, 'v8_mac64_rel': { 'swarming_dimensions' : { 'cpu': 'x86-64', - 'os': 'Mac-10.15', + 'os': 'Mac-12', }, 'tests': [ {'name': 'mozilla'}, @@ -902,6 +946,8 @@ }, 'tests': [ {'name': 'v8testing'}, + # Maglev -- move to extra once more architectures are supported. + {'name': 'mjsunit', 'variant': 'maglev'}, ], }, 'v8_mac_arm64_dbg': { @@ -912,6 +958,8 @@ }, 'tests': [ {'name': 'v8testing'}, + # Maglev -- move to extra once more architectures are supported. + {'name': 'mjsunit', 'variant': 'maglev'}, ], }, 'v8_mac_arm64_full_dbg': { @@ -922,6 +970,8 @@ }, 'tests': [ {'name': 'v8testing'}, + # Maglev -- move to extra once more architectures are supported. + {'name': 'mjsunit', 'variant': 'maglev'}, ], }, 'v8_mac_arm64_no_pointer_compression_dbg': { @@ -937,7 +987,7 @@ 'v8_mac_arm64_sim_rel': { 'swarming_dimensions' : { 'cpu': 'x86-64', - 'os': 'Mac-10.15', + 'os': 'Mac-12', }, 'tests': [ {'name': 'v8testing', 'shards': 8}, @@ -947,7 +997,7 @@ 'v8_mac_arm64_sim_dbg': { 'swarming_dimensions' : { 'cpu': 'x86-64', - 'os': 'Mac-10.15', + 'os': 'Mac-12', }, 'tests': [ {'name': 'v8testing', 'shards': 8}, @@ -957,7 +1007,7 @@ 'v8_mac_arm64_sim_nodcheck_rel': { 'swarming_dimensions' : { 'cpu': 'x86-64', - 'os': 'Mac-10.15', + 'os': 'Mac-12', }, 'tests': [ {'name': 'v8testing', 'shards': 8}, @@ -1042,7 +1092,8 @@ 'name': 'test262', 'suffix': 'noavx', 'variant': 'default', - 'test_args': ['--extra-flags', '--noenable-avx'] + 'test_args': ['--extra-flags', '--noenable-avx'], + 'shards': 2 }, { 'name': 'v8testing', @@ -1050,7 +1101,7 @@ 'test_args': ['--extra-flags', '--noenable-avx'], 'shards': 2 }, - {'name': 'gcmole'}, + {'name': 'gcmole_v3', 'variant': 'ia32', 'shards': 4}, ], }, 'V8 Linux - arm64 - sim - CFI': { @@ -1064,7 +1115,7 @@ }, 'V8 Linux - arm64 - sim - MSAN': { 'swarming_dimensions': { - 'os': 'Ubuntu-18.04', + 'os': 'Ubuntu-20.04', }, 'tests': [ {'name': 'test262', 'variant': 'default', 'shards': 3}, @@ -1086,9 +1137,9 @@ {'name': 'mozilla', 'variant': 'code_serializer', 'shards': 1}, {'name': 'mozilla', 'variant': 'extra'}, {'name': 'optimize_for_size'}, - {'name': 'test262', 'shards': 6}, + {'name': 'test262', 'shards': 12}, {'name': 'test262', 'variant': 'code_serializer', 'shards': 2}, - {'name': 'test262', 'variant': 'extra', 'shards': 5}, + {'name': 'test262', 'variant': 'extra', 'shards': 10}, {'name': 'v8testing', 'shards': 3}, { 'name': 'v8testing', @@ -1096,7 +1147,7 @@ 'test_args': ['--isolates'], 'shards': 4 }, - {'name': 'v8testing', 'variant': 'extra', 'shards': 2}, + {'name': 'v8testing', 'variant': 'extra', 'shards': 4}, # Nosse3. { 'name': 'mozilla', @@ -1107,7 +1158,8 @@ 'name': 'test262', 'suffix': 'nosse3', 'variant': 'default', - 'test_args': ['--extra-flags', '--noenable-sse3 --noenable-ssse3 --noenable-sse4-1 --noenable-avx'] + 'test_args': ['--extra-flags', '--noenable-sse3 --noenable-ssse3 --noenable-sse4-1 --noenable-avx'], + 'shards': 2 }, { 'name': 'v8testing', @@ -1125,7 +1177,8 @@ 'name': 'test262', 'suffix': 'nossse3', 'variant': 'default', - 'test_args': ['--extra-flags', '--noenable-ssse3 --noenable-sse4-1 --noenable-avx'] + 'test_args': ['--extra-flags', '--noenable-ssse3 --noenable-sse4-1 --noenable-avx'], + 'shards': 2 }, { 'name': 'v8testing', @@ -1143,7 +1196,8 @@ 'name': 'test262', 'suffix': 'nosse4', 'variant': 'default', - 'test_args': ['--extra-flags', '--noenable-sse4-1 --noenable-avx'] + 'test_args': ['--extra-flags', '--noenable-sse4-1 --noenable-avx'], + 'shards': 2 }, { 'name': 'v8testing', @@ -1161,7 +1215,8 @@ 'name': 'test262', 'suffix': 'noavx', 'variant': 'default', - 'test_args': ['--extra-flags', '--noenable-avx'] + 'test_args': ['--extra-flags', '--noenable-avx'], + 'shards': 2 }, { 'name': 'v8testing', @@ -1203,7 +1258,7 @@ }, 'tests': [ {'name': 'mozilla', 'variant': 'default'}, - {'name': 'test262', 'variant': 'default'}, + {'name': 'test262', 'variant': 'default', 'shards': 2}, {'name': 'v8testing', 'variant': 'default'}, ], }, @@ -1224,7 +1279,7 @@ }, 'tests': [ {'name': 'mozilla'}, - {'name': 'test262', 'variant': 'default'}, + {'name': 'test262', 'variant': 'default', 'shards': 2}, {'name': 'v8testing'}, ], }, @@ -1236,6 +1291,14 @@ {'name': 'v8testing'}, ], }, + 'V8 Linux PGO instrumentation - builder' : { + 'swarming_dimensions': { + 'os': 'Ubuntu-18.04', + }, + 'tests': [ + {'name': 'pgo_instrumentation'} + ], + }, 'V8 Linux64': { 'swarming_dimensions': { 'cpu': 'x86-64-avx2', @@ -1253,7 +1316,7 @@ {'name': 'optimize_for_size'}, {'name': 'perf_integration'}, {'name': 'test262', 'shards': 2}, - {'name': 'test262', 'variant': 'assert_types'}, + {'name': 'test262', 'variant': 'assert_types', 'shards': 2}, {'name': 'test262', 'variant': 'extra', 'shards': 2}, {'name': 'v8initializers'}, {'name': 'v8testing'}, @@ -1274,13 +1337,28 @@ 'name': 'test262', 'suffix': 'noavx', 'variant': 'default', - 'test_args': ['--extra-flags', '--noenable-avx'] + 'test_args': ['--extra-flags', '--noenable-avx'], + 'shards': 2 }, { 'name': 'v8testing', 'suffix': 'noavx', 'test_args': ['--extra-flags', '--noenable-avx'] }, + # GCMole. + {'name': 'gcmole_v3', 'variant': 'x64', 'shards': 4}, + { + 'name': 'gcmole_v2', + 'variant': 'x64', + 'suffix': 'test single host', + 'test_args': ['--test-run'], + }, + { + 'name': 'gcmole_v3', + 'variant': 'x64', + 'suffix': 'test multi host', + 'test_args': ['--test-run'], + }, ], }, 'V8 Linux64 - cfi': { @@ -1291,10 +1369,22 @@ {'name': 'benchmarks'}, {'name': 'mozilla'}, {'name': 'optimize_for_size'}, - {'name': 'test262', 'variant': 'default'}, + {'name': 'test262', 'variant': 'default', 'shards': 2}, {'name': 'v8testing', 'shards': 2}, ], }, + 'V8 Linux64 - coverage': { + 'swarming_dimensions' : { + 'os': 'Ubuntu-18.04', + }, + 'tests': [ + # TODO(https://crbug.com/1265931): Speed things up for now. Later replace + # mjsunit and unittests with full v8testing. + # {'name': 'v8testing'}, + {'name': 'mjsunit', 'variant': 'default'}, + {'name': 'unittests', 'variant': 'default'}, + ], + }, 'V8 Linux64 - custom snapshot - debug': { 'swarming_dimensions' : { 'os': 'Ubuntu-18.04', @@ -1318,13 +1408,13 @@ {'name': 'test262', 'shards': 7}, {'name': 'test262', 'variant': 'extra', 'shards': 5}, {'name': 'v8testing', 'shards': 2}, - {'name': 'v8testing', 'variant': 'extra', 'shards': 2}, + {'name': 'v8testing', 'variant': 'extra', 'shards': 4}, {'name': 'v8testing', 'variant': 'minor_mc'}, {'name': 'v8testing', 'variant': 'no_lfa'}, {'name': 'v8testing', 'variant': 'slow_path'}, {'name': 'v8testing', 'variant': 'stress_instruction_scheduling'}, {'name': 'v8testing', 'variant': 'stress_concurrent_allocation'}, - {'name': 'v8testing', 'variant': 'stress_concurrent_inlining'}, + {'name': 'v8testing', 'variant': 'stress_concurrent_inlining', 'shards': 2}, # Maglev -- move to extra once more architectures are supported. {'name': 'mjsunit', 'variant': 'maglev'}, # Noavx. @@ -1337,7 +1427,8 @@ 'name': 'test262', 'suffix': 'noavx', 'variant': 'default', - 'test_args': ['--extra-flags', '--noenable-avx'] + 'test_args': ['--extra-flags', '--noenable-avx'], + 'shards': 2 }, { 'name': 'v8testing', @@ -1380,14 +1471,12 @@ {'name': 'webkit', 'variant': 'stress_sampling'}, # Stress snapshot. {'name': 'mjsunit', 'variant': 'stress_snapshot'}, - # Maglev. - {'name': 'mjsunit', 'variant': 'maglev'}, # Stress maglev. {'name': 'mjsunit', 'variant': 'stress_maglev'}, + # Stress maglev-inlining. + {'name': 'mjsunit', 'variant': 'maglev_inlining'}, # Experimental regexp engine. {'name': 'mjsunit', 'variant': 'experimental_regexp'}, - # Wasm write protect code space. - {'name': 'mjsunit', 'variant': 'wasm_write_protect_code'}, ], }, 'V8 Linux64 - cppgc-non-default - debug': { @@ -1446,14 +1535,12 @@ {'name': 'webkit', 'variant': 'stress_sampling'}, # Stress snapshot. {'name': 'mjsunit', 'variant': 'stress_snapshot'}, - # Maglev. - {'name': 'mjsunit', 'variant': 'maglev'}, # Stress maglev. {'name': 'mjsunit', 'variant': 'stress_maglev'}, + # Stress maglev-inlining. + {'name': 'mjsunit', 'variant': 'maglev_inlining'}, # Experimental regexp engine. {'name': 'mjsunit', 'variant': 'experimental_regexp'}, - # Wasm write protect code space. - {'name': 'mjsunit', 'variant': 'wasm_write_protect_code'}, ], }, 'V8 Linux64 gcc': { @@ -1497,14 +1584,6 @@ {'name': 'v8testing'}, ], }, - 'V8 Linux64 - heap sandbox - debug': { - 'swarming_dimensions' : { - 'os': 'Ubuntu-18.04', - }, - 'tests': [ - {'name': 'v8testing', 'shards': 2}, - ], - }, 'V8 Linux64 - internal snapshot': { 'swarming_dimensions' : { 'os': 'Ubuntu-18.04', @@ -1545,7 +1624,7 @@ }, 'tests': [ {'name': 'mozilla'}, - {'name': 'test262', 'variant': 'default'}, + {'name': 'test262', 'variant': 'default', 'shards': 2}, {'name': 'v8testing'}, ], }, @@ -1568,6 +1647,14 @@ {'name': 'v8testing', 'variant': 'slow_path', 'shards': 1}, ], }, + 'V8 Linux64 css - debug': { + 'swarming_dimensions' : { + 'os': 'Ubuntu-18.04', + }, + 'tests': [ + {'name': 'v8testing', 'shards': 5}, + ], + }, 'V8 Linux64 GC Stress - custom snapshot': { 'swarming_dimensions' : { 'os': 'Ubuntu-18.04', @@ -1580,6 +1667,14 @@ }, ], }, + 'V8 Linux64 PGO instrumentation - builder' : { + 'swarming_dimensions' : { + 'os': 'Ubuntu-18.04', + }, + 'tests': [ + {'name': 'pgo_instrumentation'} + ], + }, 'V8 Linux64 TSAN': { 'swarming_dimensions' : { 'os': 'Ubuntu-18.04', @@ -1594,6 +1689,18 @@ {'name': 'v8testing', 'variant': 'stress_concurrent_allocation', 'shards': 2}, ], }, + 'V8 Linux64 TSAN - debug': { + 'swarming_dimensions' : { + 'os': 'Ubuntu-18.04', + }, + 'tests': [ + {'name': 'benchmarks', 'shards': 2}, + {'name': 'mozilla', 'shards': 4}, + {'name': 'test262', 'variant': 'default', 'shards': 5}, + {'name': 'v8testing', 'shards': 12}, + {'name': 'v8testing', 'variant': 'extra', 'shards': 10}, + ], + }, 'V8 Linux64 TSAN - stress-incremental-marking': { 'swarming_dimensions' : { 'os': 'Ubuntu-18.04', @@ -1667,7 +1774,7 @@ 'V8 Mac64': { 'swarming_dimensions': { 'cpu': 'x86-64', - 'os': 'Mac-10.15', + 'os': 'Mac-12', }, 'tests': [ {'name': 'mozilla'}, @@ -1679,7 +1786,7 @@ 'V8 Mac64 - debug': { 'swarming_dimensions': { 'cpu': 'x86-64', - 'os': 'Mac-10.15', + 'os': 'Mac-12', }, 'tests': [ {'name': 'mozilla'}, @@ -1691,7 +1798,7 @@ 'V8 Mac64 ASAN': { 'swarming_dimensions': { 'cpu': 'x86-64', - 'os': 'Mac-10.15', + 'os': 'Mac-12', }, 'tests': [ {'name': 'v8testing', 'shards': 10}, @@ -1700,7 +1807,7 @@ 'V8 Mac64 GC Stress': { 'swarming_dimensions': { 'cpu': 'x86-64', - 'os': 'Mac-10.15', + 'os': 'Mac-12', }, 'tests': [ {'name': 'd8testing', 'test_args': ['--gc-stress'], 'shards': 6}, @@ -1720,6 +1827,8 @@ 'tests': [ {'name': 'v8testing'}, {'name': 'v8testing', 'variant': 'extra'}, + # Maglev -- move to extra once more architectures are supported. + {'name': 'mjsunit', 'variant': 'maglev'}, ], }, 'V8 Mac - arm64 - debug': { @@ -1736,6 +1845,8 @@ 'tests': [ {'name': 'v8testing', 'shards': 2}, {'name': 'v8testing', 'variant': 'extra', 'shards': 2}, + # Maglev -- move to extra once more architectures are supported. + {'name': 'mjsunit', 'variant': 'maglev'}, ], }, 'V8 Mac - arm64 - no pointer compression debug': { @@ -1751,7 +1862,7 @@ 'V8 Mac - arm64 - sim - debug': { 'swarming_dimensions' : { 'cpu': 'x86-64', - 'os': 'Mac-10.15', + 'os': 'Mac-12', }, 'swarming_task_attrs': { 'expiration': 14400, @@ -1766,7 +1877,7 @@ 'V8 Mac - arm64 - sim - release': { 'swarming_dimensions' : { 'cpu': 'x86-64', - 'os': 'Mac-10.15', + 'os': 'Mac-12', }, 'swarming_task_attrs': { 'expiration': 14400, @@ -1781,39 +1892,39 @@ 'V8 Win32': { 'swarming_dimensions': { 'cpu': 'x86-64', - 'os': 'Windows-7-SP1', + 'os': 'Windows-10-19045', }, 'tests': [ {'name': 'mozilla'}, - {'name': 'test262', 'variant': 'default'}, + {'name': 'test262', 'variant': 'default', 'shards': 2}, {'name': 'v8testing'}, ], }, 'V8 Win32 - debug': { 'swarming_dimensions': { 'cpu': 'x86-64', - 'os': 'Windows-7-SP1', + 'os': 'Windows-10-19045', }, 'tests': [ {'name': 'mozilla'}, - {'name': 'test262', 'variant': 'default'}, + {'name': 'test262', 'variant': 'default', 'shards': 2}, {'name': 'v8testing', 'shards': 5}, ], }, 'V8 Win64': { 'swarming_dimensions': { - 'os': 'Windows-10-19042', + 'os': 'Windows-10-19045', }, 'tests': [ {'name': 'mozilla'}, - {'name': 'test262', 'variant': 'default'}, + {'name': 'test262', 'variant': 'default', 'shards': 2}, {'name': 'v8testing', 'shards': 2}, {'name': 'v8testing', 'variant': 'extra', 'shards': 2}, ], }, 'V8 Win64 - debug': { 'swarming_dimensions': { - 'os': 'Windows-10-19042', + 'os': 'Windows-10-19045', }, 'tests': [ {'name': 'mozilla'}, @@ -1824,17 +1935,17 @@ }, 'V8 Win64 - msvc': { 'swarming_dimensions': { - 'os': 'Windows-10-19042', + 'os': 'Windows-10-19045', }, 'tests': [ {'name': 'mozilla'}, - {'name': 'test262', 'variant': 'default'}, + {'name': 'test262', 'variant': 'default', 'shards': 2}, {'name': 'v8testing', 'shards': 2}, ], }, 'V8 Win64 ASAN': { 'swarming_dimensions': { - 'os': 'Windows-10-19042', + 'os': 'Windows-10-19045', }, 'tests': [ {'name': 'v8testing', 'shards': 5}, @@ -1951,7 +2062,8 @@ 'name': 'test262', 'suffix': 'armv8-a', 'variant': 'default', - 'test_args': ['--extra-flags', '--enable-armv8'] + 'test_args': ['--extra-flags', '--enable-armv8'], + 'shards': 2 }, { 'name': 'v8testing', @@ -1970,6 +2082,7 @@ 'suffix': 'novfp3', 'variant': 'default', 'test_args': ['--novfp3'], + 'shards': 2 }, { 'name': 'v8testing', @@ -1977,6 +2090,8 @@ 'test_args': ['--novfp3'], 'shards': 6 }, + # GCMole. + {'name': 'gcmole_v3', 'variant': 'arm', 'shards': 4}, ], }, 'V8 Linux - arm - sim - debug': { @@ -2055,9 +2170,10 @@ 'tests': [ {'name': 'mjsunit_sp_frame_access'}, {'name': 'mozilla'}, - {'name': 'test262', 'variant': 'default'}, + {'name': 'test262', 'variant': 'default', 'shards': 2}, {'name': 'v8testing', 'shards': 3}, {'name': 'v8testing', 'variant': 'extra', 'shards': 2}, + {'name': 'gcmole_v3', 'variant': 'arm64', 'shards': 4}, ], }, 'V8 Linux - arm64 - sim - debug': { @@ -2093,19 +2209,6 @@ }, ], }, - 'V8 Linux64 - arm64 - sim - heap sandbox - debug': { - 'swarming_dimensions' : { - 'os': 'Ubuntu-18.04', - }, - 'swarming_task_attrs': { - 'expiration': 14400, - 'hard_timeout': 7200, - 'priority': 35, - }, - 'tests': [ - {'name': 'v8testing', 'shards': 14}, - ], - }, 'V8 Linux - loong64 - sim': { 'swarming_dimensions': { 'os': 'Ubuntu-18.04', @@ -2129,7 +2232,7 @@ 'priority': 35, }, 'tests': [ - {'name': 'test262', 'variant': 'default'}, + {'name': 'test262', 'variant': 'default', 'shards': 2}, {'name': 'v8testing', 'shards': 4}, ], }, diff --git a/deps/v8/src/DEPS b/deps/v8/src/DEPS index 8912d7fb25186c..ebe2dd0dc5442c 100644 --- a/deps/v8/src/DEPS +++ b/deps/v8/src/DEPS @@ -10,19 +10,20 @@ include_rules = [ "-src/bigint", "+src/bigint/bigint.h", "-src/compiler", - "+src/compiler/pipeline.h", "+src/compiler/code-assembler.h", + "+src/compiler/turbofan.h", "+src/compiler/wasm-compiler-definitions.h", "+src/compiler/wasm-compiler.h", "-src/heap", "+src/heap/basic-memory-chunk.h", "+src/heap/code-range.h", "+src/heap/combined-heap.h", - "+src/heap/embedder-tracing.h", "+src/heap/factory.h", "+src/heap/factory-inl.h", # TODO(v8:10496): Don't expose so much (through transitive includes) outside # of heap/. + "+src/heap/gc-tracer.h", + "+src/heap/gc-tracer-inl.h", "+src/heap/heap.h", "+src/heap/heap-verifier.h", "+src/heap/heap-inl.h", @@ -76,6 +77,7 @@ include_rules = [ "+starboard", # Using cppgc inside v8 is not (yet) allowed. "-include/cppgc", + "+include/cppgc/common.h", "+include/cppgc/platform.h", "+include/cppgc/source-location.h", ] @@ -84,7 +86,8 @@ specific_include_rules = { "d8\.cc": [ "+include/libplatform/libplatform.h", "+include/libplatform/v8-tracing.h", - "+perfetto/tracing.h" + "+perfetto/tracing/track_event.h", + "+perfetto/tracing/track_event_legacy.h" ], "d8-platforms\.cc": [ "+include/libplatform/libplatform.h", diff --git a/deps/v8/src/api/api-arguments-inl.h b/deps/v8/src/api/api-arguments-inl.h index 470ab95e181e84..0a54c6c86af110 100644 --- a/deps/v8/src/api/api-arguments-inl.h +++ b/deps/v8/src/api/api-arguments-inl.h @@ -11,21 +11,21 @@ #include "src/execution/vm-state-inl.h" #include "src/logging/runtime-call-stats-scope.h" #include "src/objects/api-callbacks.h" +#include "src/objects/instance-type.h" #include "src/objects/slots-inl.h" +#include "v8-isolate.h" namespace v8 { namespace internal { -void Object::VerifyApiCallResultType() { #if DEBUG - if (IsSmi()) return; +bool Object::IsApiCallResultType() const { + if (IsSmi()) return true; DCHECK(IsHeapObject()); - if (!(IsString() || IsSymbol() || IsJSReceiver() || IsHeapNumber() || - IsBigInt() || IsUndefined() || IsTrue() || IsFalse() || IsNull())) { - FATAL("API call returned invalid object"); - } -#endif // DEBUG + return (IsString() || IsSymbol() || IsJSReceiver() || IsHeapNumber() || + IsBigInt() || IsUndefined() || IsTrue() || IsFalse() || IsNull()); } +#endif // DEBUG CustomArgumentsBase::CustomArgumentsBase(Isolate* isolate) : Relocatable(isolate) {} @@ -37,25 +37,25 @@ CustomArguments::~CustomArguments() { template template -Handle CustomArguments::GetReturnValue(Isolate* isolate) { +Handle CustomArguments::GetReturnValue(Isolate* isolate) const { // Check the ReturnValue. FullObjectSlot slot = slot_at(kReturnValueOffset); // Nothing was set, return empty handle as per previous behaviour. - if ((*slot).IsTheHole(isolate)) return Handle(); - Handle result = Handle::cast(Handle(slot.location())); - result->VerifyApiCallResultType(); - return result; + Object raw_object = *slot; + if (raw_object.IsTheHole(isolate)) return Handle(); + DCHECK(raw_object.IsApiCallResultType()); + return Handle::cast(Handle(slot.location())); } -inline JSObject PropertyCallbackArguments::holder() { +inline JSObject PropertyCallbackArguments::holder() const { return JSObject::cast(*slot_at(T::kHolderIndex)); } -inline Object PropertyCallbackArguments::receiver() { +inline Object PropertyCallbackArguments::receiver() const { return *slot_at(T::kThisIndex); } -inline JSReceiver FunctionCallbackArguments::holder() { +inline JSReceiver FunctionCallbackArguments::holder() const { return JSReceiver::cast(*slot_at(T::kHolderIndex)); } diff --git a/deps/v8/src/api/api-arguments.h b/deps/v8/src/api/api-arguments.h index 39958964fd4233..baa4a394f7d812 100644 --- a/deps/v8/src/api/api-arguments.h +++ b/deps/v8/src/api/api-arguments.h @@ -38,13 +38,13 @@ class CustomArguments : public CustomArgumentsBase { : CustomArgumentsBase(isolate) {} template - Handle GetReturnValue(Isolate* isolate); + Handle GetReturnValue(Isolate* isolate) const; - inline Isolate* isolate() { + inline Isolate* isolate() const { return reinterpret_cast((*slot_at(T::kIsolateIndex)).ptr()); } - inline FullObjectSlot slot_at(int index) { + inline FullObjectSlot slot_at(int index) const { // This allows index == T::kArgsLength so "one past the end" slots // can be retrieved for iterating purposes. DCHECK_LE(static_cast(index), @@ -161,8 +161,8 @@ class PropertyCallbackArguments final GenericNamedPropertyGetterCallback f, Handle name, Handle info, Handle receiver = Handle()); - inline JSObject holder(); - inline Object receiver(); + inline JSObject holder() const; + inline Object receiver() const; #ifdef DEBUG // This stores current value of Isolate::javascript_execution_counter(). @@ -199,10 +199,10 @@ class FunctionCallbackArguments inline Handle Call(CallHandlerInfo handler); private: - inline JSReceiver holder(); + inline JSReceiver holder() const; internal::Address* argv_; - int argc_; + int const argc_; }; } // namespace internal diff --git a/deps/v8/src/api/api-inl.h b/deps/v8/src/api/api-inl.h index ac675a87fc82ba..b7d783dc19bf68 100644 --- a/deps/v8/src/api/api-inl.h +++ b/deps/v8/src/api/api-inl.h @@ -7,6 +7,7 @@ #include "include/v8-fast-api-calls.h" #include "src/api/api.h" +#include "src/common/assert-scope.h" #include "src/execution/interrupts-scope.h" #include "src/execution/microtask-queue.h" #include "src/handles/handles-inl.h" @@ -51,7 +52,12 @@ inline v8::internal::Handle FromCData( template inline Local Utils::Convert(v8::internal::Handle obj) { DCHECK(obj.is_null() || (obj->IsSmi() || !obj->IsTheHole())); +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + if (obj.is_null()) return Local(); + return Local(reinterpret_cast(*obj.location())); +#else return Local(reinterpret_cast(obj.location())); +#endif } // Implementations of ToLocal @@ -86,6 +92,7 @@ MAKE_TO_LOCAL(ToLocal, JSProxy, Proxy) MAKE_TO_LOCAL(ToLocal, JSArrayBuffer, ArrayBuffer) MAKE_TO_LOCAL(ToLocal, JSArrayBufferView, ArrayBufferView) MAKE_TO_LOCAL(ToLocal, JSDataView, DataView) +MAKE_TO_LOCAL(ToLocal, JSRabGsabDataView, DataView) MAKE_TO_LOCAL(ToLocal, JSTypedArray, TypedArray) MAKE_TO_LOCAL(ToLocalShared, JSArrayBuffer, SharedArrayBuffer) @@ -114,6 +121,29 @@ MAKE_TO_LOCAL(ToLocal, ScriptOrModule, ScriptOrModule) // Implementations of OpenHandle +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + +#define MAKE_OPEN_HANDLE(From, To) \ + v8::internal::Handle Utils::OpenHandle( \ + const v8::From* that, bool allow_empty_handle) { \ + DCHECK(allow_empty_handle || \ + reinterpret_cast(that) != \ + v8::internal::kLocalTaggedNullAddress); \ + DCHECK(reinterpret_cast(that) == \ + v8::internal::kLocalTaggedNullAddress || \ + v8::internal::Object(reinterpret_cast(that)) \ + .Is##To()); \ + if (reinterpret_cast(that) == \ + v8::internal::kLocalTaggedNullAddress) { \ + return v8::internal::Handle::null(); \ + } \ + return v8::internal::Handle( \ + v8::HandleScope::CreateHandleForCurrentIsolate( \ + reinterpret_cast(that))); \ + } + +#else + #define MAKE_OPEN_HANDLE(From, To) \ v8::internal::Handle Utils::OpenHandle( \ const v8::From* that, bool allow_empty_handle) { \ @@ -127,6 +157,8 @@ MAKE_TO_LOCAL(ToLocal, ScriptOrModule, ScriptOrModule) const_cast(that))); \ } +#endif + OPEN_HANDLE_LIST(MAKE_OPEN_HANDLE) #undef MAKE_OPEN_HANDLE @@ -150,12 +182,13 @@ class V8_NODISCARD CallDepthScope { isolate_->thread_local_top()->IncrementCallDepth(this); isolate_->set_next_v8_call_is_safe_for_termination(false); if (!context.IsEmpty()) { - i::Handle env = Utils::OpenHandle(*context); + i::DisallowGarbageCollection no_gc; + i::Context env = *Utils::OpenHandle(*context); i::HandleScopeImplementer* impl = isolate->handle_scope_implementer(); if (isolate->context().is_null() || - isolate->context().native_context() != env->native_context()) { + isolate->context().native_context() != env.native_context()) { impl->SaveContext(isolate->context()); - isolate->set_context(*env); + isolate->set_context(env); did_enter_context_ = true; } } diff --git a/deps/v8/src/api/api-macros.h b/deps/v8/src/api/api-macros.h index 149dd0555a69be..93a25e9ac98c1e 100644 --- a/deps/v8/src/api/api-macros.h +++ b/deps/v8/src/api/api-macros.h @@ -91,26 +91,15 @@ bailout_value, HandleScopeClass, false); \ i::DisallowJavascriptExecutionDebugOnly __no_script__((i_isolate)) -#define DCHECK_NO_SCRIPT_NO_EXCEPTION_MAYBE_TEARDOWN(i_isolate) \ +// Lightweight version for APIs that don't require an active context. +#define DCHECK_NO_SCRIPT_NO_EXCEPTION(i_isolate) \ i::DisallowJavascriptExecutionDebugOnly __no_script__((i_isolate)); \ i::DisallowExceptions __no_exceptions__((i_isolate)) -// Lightweight version for APIs that don't require an active context. -#define DCHECK_NO_SCRIPT_NO_EXCEPTION(i_isolate) \ - /* Embedders should never enter V8 after terminating it */ \ - DCHECK(!i_isolate->is_execution_terminating()); \ - DCHECK_NO_SCRIPT_NO_EXCEPTION_MAYBE_TEARDOWN(i_isolate) - #define ENTER_V8_NO_SCRIPT_NO_EXCEPTION(i_isolate) \ i::VMState __state__((i_isolate)); \ DCHECK_NO_SCRIPT_NO_EXCEPTION(i_isolate) -// Used instead of ENTER_V8_NO_SCRIPT_NO_EXCEPTION where the V8 Api is entered -// during termination sequences. -#define ENTER_V8_MAYBE_TEARDOWN(i_isolate) \ - i::VMState __state__((i_isolate)); \ - DCHECK_NO_SCRIPT_NO_EXCEPTION_MAYBE_TEARDOWN(i_isolate) - #define ENTER_V8_FOR_NEW_CONTEXT(i_isolate) \ DCHECK(!(i_isolate)->is_execution_terminating()); \ i::VMState __state__((i_isolate)); \ @@ -122,14 +111,10 @@ bailout_value, HandleScopeClass, false) #define DCHECK_NO_SCRIPT_NO_EXCEPTION(i_isolate) -#define DCHECK_NO_SCRIPT_NO_EXCEPTION_MAYBE_TEARDOWN(i_isolate) #define ENTER_V8_NO_SCRIPT_NO_EXCEPTION(i_isolate) \ i::VMState __state__((i_isolate)); -#define ENTER_V8_MAYBE_TEARDOWN(i_isolate) \ - i::VMState __state__((i_isolate)); - #define ENTER_V8_FOR_NEW_CONTEXT(i_isolate) \ i::VMState __state__((i_isolate)); #endif // DEBUG diff --git a/deps/v8/src/api/api-natives.cc b/deps/v8/src/api/api-natives.cc index d0b298723423e9..05a883f2d560e3 100644 --- a/deps/v8/src/api/api-natives.cc +++ b/deps/v8/src/api/api-natives.cc @@ -83,7 +83,7 @@ MaybeHandle DefineAccessorProperty(Isolate* isolate, InstantiateFunction(isolate, Handle::cast(getter)), Object); - Handle trampoline = BUILTIN_CODE(isolate, DebugBreakTrampoline); + Handle trampoline = BUILTIN_CODE(isolate, DebugBreakTrampoline); Handle::cast(getter)->set_code(*trampoline); } if (setter->IsFunctionTemplateInfo() && @@ -93,7 +93,7 @@ MaybeHandle DefineAccessorProperty(Isolate* isolate, InstantiateFunction(isolate, Handle::cast(setter)), Object); - Handle trampoline = BUILTIN_CODE(isolate, DebugBreakTrampoline); + Handle trampoline = BUILTIN_CODE(isolate, DebugBreakTrampoline); Handle::cast(setter)->set_code(*trampoline); } RETURN_ON_EXCEPTION( diff --git a/deps/v8/src/api/api.cc b/deps/v8/src/api/api.cc index da75db119baf10..fac24bae124fc5 100644 --- a/deps/v8/src/api/api.cc +++ b/deps/v8/src/api/api.cc @@ -38,6 +38,7 @@ #include "src/baseline/baseline-batch-compiler.h" #include "src/builtins/accessors.h" #include "src/builtins/builtins-utils.h" +#include "src/codegen/compilation-cache.h" #include "src/codegen/compiler.h" #include "src/codegen/cpu-features.h" #include "src/codegen/script-details.h" @@ -46,6 +47,7 @@ #include "src/compiler-dispatcher/lazy-compile-dispatcher.h" #include "src/date/date.h" #include "src/objects/primitive-heap-object.h" +#include "src/utils/identity-map.h" #if V8_ENABLE_WEBASSEMBLY #include "src/debug/debug-wasm-objects.h" #endif // V8_ENABLE_WEBASSEMBLY @@ -64,7 +66,6 @@ #include "src/handles/persistent-handles.h" #include "src/handles/shared-object-conveyor-handles.h" #include "src/handles/traced-handles.h" -#include "src/heap/embedder-tracing.h" #include "src/heap/heap-inl.h" #include "src/heap/heap-write-barrier.h" #include "src/heap/safepoint.h" @@ -85,6 +86,7 @@ #include "src/objects/embedder-data-slot-inl.h" #include "src/objects/hash-table-inl.h" #include "src/objects/heap-object.h" +#include "src/objects/instance-type.h" #include "src/objects/js-array-buffer-inl.h" #include "src/objects/js-array-inl.h" #include "src/objects/js-collection-inl.h" @@ -128,7 +130,6 @@ #include "src/tracing/trace-event.h" #include "src/utils/detachable-vector.h" #include "src/utils/version.h" -#include "src/web-snapshot/web-snapshot.h" #if V8_ENABLE_WEBASSEMBLY #include "src/trap-handler/trap-handler.h" @@ -358,19 +359,12 @@ void V8::SetSnapshotDataBlob(StartupData* snapshot_blob) { namespace { #ifdef V8_ENABLE_SANDBOX -// ArrayBufferAllocator to use when sandboxed pointers are used in which case -// all ArrayBuffer backing stores need to be allocated inside the sandbox. -// Note, the current implementation is extremely inefficient as it uses the -// BoundedPageAllocator. In the future, we'll need a proper allocator -// implementation. +// ArrayBufferAllocator to use when the sandbox is enabled in which case all +// ArrayBuffer backing stores need to be allocated inside the sandbox. class ArrayBufferAllocator : public v8::ArrayBuffer::Allocator { public: - ArrayBufferAllocator() { CHECK(page_allocator_); } - void* Allocate(size_t length) override { - return page_allocator_->AllocatePages(nullptr, RoundUp(length, page_size_), - page_size_, - PageAllocator::kReadWrite); + return allocator_->Allocate(length); } void* AllocateUninitialized(size_t length) override { @@ -378,12 +372,136 @@ class ArrayBufferAllocator : public v8::ArrayBuffer::Allocator { } void Free(void* data, size_t length) override { - page_allocator_->FreePages(data, RoundUp(length, page_size_)); + return allocator_->Free(data); } private: - PageAllocator* page_allocator_ = internal::GetArrayBufferPageAllocator(); - const size_t page_size_ = page_allocator_->AllocatePageSize(); + // Backend allocator shared by all ArrayBufferAllocator instances. This way, + // there is a single region of virtual addres space reserved inside the + // sandbox from which all ArrayBufferAllocators allocate their memory, + // instead of each allocator creating their own region, which may cause + // address space exhaustion inside the sandbox. + // TODO(chromium:1340224): replace this with a more efficient allocator. + class BackendAllocator { + public: + BackendAllocator() { + CHECK(i::GetProcessWideSandbox()->is_initialized()); + VirtualAddressSpace* vas = i::GetProcessWideSandbox()->address_space(); + constexpr size_t max_backing_memory_size = 8ULL * i::GB; + constexpr size_t min_backing_memory_size = 1ULL * i::GB; + size_t backing_memory_size = max_backing_memory_size; + i::Address backing_memory_base = 0; + while (!backing_memory_base && + backing_memory_size >= min_backing_memory_size) { + backing_memory_base = vas->AllocatePages( + VirtualAddressSpace::kNoHint, backing_memory_size, kChunkSize, + PagePermissions::kNoAccess); + if (!backing_memory_base) { + backing_memory_size /= 2; + } + } + if (!backing_memory_base) { + i::V8::FatalProcessOutOfMemory( + nullptr, + "Could not reserve backing memory for ArrayBufferAllocators"); + } + DCHECK(IsAligned(backing_memory_base, kChunkSize)); + + region_alloc_ = std::make_unique( + backing_memory_base, backing_memory_size, kAllocationGranularity); + end_of_accessible_region_ = region_alloc_->begin(); + + // Install a on-merge callback to discard or decommit unused pages. + region_alloc_->set_on_merge_callback([this](i::Address start, + size_t size) { + mutex_.AssertHeld(); + VirtualAddressSpace* vas = i::GetProcessWideSandbox()->address_space(); + i::Address end = start + size; + if (end == region_alloc_->end() && + start <= end_of_accessible_region_ - kChunkSize) { + // Can shrink the accessible region. + i::Address new_end_of_accessible_region = RoundUp(start, kChunkSize); + size_t size = + end_of_accessible_region_ - new_end_of_accessible_region; + CHECK(vas->DecommitPages(new_end_of_accessible_region, size)); + end_of_accessible_region_ = new_end_of_accessible_region; + } else if (size >= 2 * kChunkSize) { + // Can discard pages. The pages stay accessible, so the size of the + // accessible region doesn't change. + i::Address chunk_start = RoundUp(start, kChunkSize); + i::Address chunk_end = RoundDown(start + size, kChunkSize); + CHECK(vas->DiscardSystemPages(chunk_start, chunk_end - chunk_start)); + } + }); + } + + ~BackendAllocator() { + // The sandbox may already have been torn down, in which case there's no + // need to free any memory. + if (i::GetProcessWideSandbox()->is_initialized()) { + VirtualAddressSpace* vas = i::GetProcessWideSandbox()->address_space(); + vas->FreePages(region_alloc_->begin(), region_alloc_->size()); + } + } + + BackendAllocator(const BackendAllocator&) = delete; + BackendAllocator& operator=(const BackendAllocator&) = delete; + + void* Allocate(size_t length) { + base::MutexGuard guard(&mutex_); + + length = RoundUp(length, kAllocationGranularity); + i::Address region = region_alloc_->AllocateRegion(length); + if (region == base::RegionAllocator::kAllocationFailure) return nullptr; + + // Check if the memory is inside the accessible region. If not, grow it. + i::Address end = region + length; + size_t length_to_memset = length; + if (end > end_of_accessible_region_) { + VirtualAddressSpace* vas = i::GetProcessWideSandbox()->address_space(); + i::Address new_end_of_accessible_region = RoundUp(end, kChunkSize); + size_t size = new_end_of_accessible_region - end_of_accessible_region_; + if (!vas->SetPagePermissions(end_of_accessible_region_, size, + PagePermissions::kReadWrite)) { + CHECK(region_alloc_->FreeRegion(region)); + return nullptr; + } + + // The pages that were inaccessible are guaranteed to be zeroed, so only + // memset until the previous end of the accessible region. + length_to_memset = end_of_accessible_region_ - region; + end_of_accessible_region_ = new_end_of_accessible_region; + } + + void* mem = reinterpret_cast(region); + memset(mem, 0, length_to_memset); + return mem; + } + + void Free(void* data) { + base::MutexGuard guard(&mutex_); + region_alloc_->FreeRegion(reinterpret_cast(data)); + } + + static BackendAllocator* SharedInstance() { + static base::LeakyObject instance; + return instance.get(); + } + + private: + // Use a region allocator with a "page size" of 128 bytes as a reasonable + // compromise between the number of regions it has to manage and the amount + // of memory wasted due to rounding allocation sizes up to the page size. + static constexpr size_t kAllocationGranularity = 128; + // The backing memory's accessible region is grown in chunks of this size. + static constexpr size_t kChunkSize = 1 * i::MB; + + std::unique_ptr region_alloc_; + size_t end_of_accessible_region_; + base::Mutex mutex_; + }; + + BackendAllocator* allocator_ = BackendAllocator::SharedInstance(); }; #else @@ -429,7 +547,7 @@ struct SnapshotCreatorData { SnapshotCreator::SnapshotCreator(Isolate* v8_isolate, const intptr_t* external_references, - StartupData* existing_snapshot) { + const StartupData* existing_snapshot) { SnapshotCreatorData* data = new SnapshotCreatorData(v8_isolate); i::Isolate* i_isolate = reinterpret_cast(v8_isolate); i_isolate->set_array_buffer_allocator(&data->allocator_); @@ -451,7 +569,7 @@ SnapshotCreator::SnapshotCreator(Isolate* v8_isolate, } SnapshotCreator::SnapshotCreator(const intptr_t* external_references, - StartupData* existing_snapshot) + const StartupData* existing_snapshot) : SnapshotCreator(Isolate::Allocate(), external_references, existing_snapshot) {} @@ -617,7 +735,7 @@ StartupData SnapshotCreator::CreateBlob( i::Snapshot::ClearReconstructableDataForSerialization( i_isolate, function_code_handling == FunctionCodeHandling::kClear); - i::SafepointKind safepoint_kind = i_isolate->has_shared_heap() + i::SafepointKind safepoint_kind = i_isolate->has_shared_space() ? i::SafepointKind::kGlobal : i::SafepointKind::kIsolate; i::SafepointScope safepoint_scope(i_isolate, safepoint_kind); @@ -792,14 +910,21 @@ i::Address* GlobalizeTracedReference(i::Isolate* i_isolate, i::Address* obj, internal::Address* slot, GlobalHandleStoreMode store_mode) { API_RCS_SCOPE(i_isolate, TracedGlobal, New); + +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + i::Address obj_addr = reinterpret_cast(obj); +#else + i::Address obj_addr = *obj; +#endif + #ifdef DEBUG Utils::ApiCheck((slot != nullptr), "v8::GlobalizeTracedReference", "the address slot must be not null"); #endif - auto result = i_isolate->traced_handles()->Create(*obj, slot, store_mode); + auto result = i_isolate->traced_handles()->Create(obj_addr, slot, store_mode); #ifdef VERIFY_HEAP if (i::v8_flags.verify_heap) { - i::Object(*obj).ObjectVerify(i_isolate); + i::Object(obj_addr).ObjectVerify(i_isolate); } #endif // VERIFY_HEAP return result.location(); @@ -930,6 +1055,15 @@ i::Address* HandleScope::CreateHandle(i::Isolate* i_isolate, i::Address value) { return i::HandleScope::CreateHandle(i_isolate, value); } +#ifdef V8_ENABLE_CONSERVATIVE_STACK_SCANNING + +i::Address* HandleScope::CreateHandleForCurrentIsolate(i::Address value) { + i::Isolate* i_isolate = i::Isolate::Current(); + return i::HandleScope::CreateHandle(i_isolate, value); +} + +#endif + EscapableHandleScope::EscapableHandleScope(Isolate* v8_isolate) { i::Isolate* i_isolate = reinterpret_cast(v8_isolate); escape_slot_ = CreateHandle( @@ -1013,10 +1147,7 @@ void Context::Enter() { i::DisallowGarbageCollection no_gc; i::Context env = *Utils::OpenHandle(this); i::Isolate* i_isolate = env.GetIsolate(); - // TODO(cbruni): Use ENTER_V8_NO_SCRIPT_NO_EXCEPTION which also checks - // Isolate::is_execution_terminating - // ENTER_V8_NO_SCRIPT_NO_EXCEPTION(i_isolate); - ENTER_V8_MAYBE_TEARDOWN(i_isolate); + ENTER_V8_NO_SCRIPT_NO_EXCEPTION(i_isolate); i::HandleScopeImplementer* impl = i_isolate->handle_scope_implementer(); impl->EnterContext(env); impl->SaveContext(i_isolate->context()); @@ -1026,7 +1157,7 @@ void Context::Enter() { void Context::Exit() { i::Handle env = Utils::OpenHandle(this); i::Isolate* i_isolate = env->GetIsolate(); - ENTER_V8_MAYBE_TEARDOWN(i_isolate); + ENTER_V8_NO_SCRIPT_NO_EXCEPTION(i_isolate); i::HandleScopeImplementer* impl = i_isolate->handle_scope_implementer(); if (!Utils::ApiCheck(impl->LastEnteredContextWas(*env), "v8::Context::Exit()", "Cannot exit non-entered context")) { @@ -1069,7 +1200,7 @@ static i::Handle EmbedderDataFor(Context* context, const char* location) { i::Handle env = Utils::OpenHandle(context); i::Isolate* i_isolate = env->GetIsolate(); - DCHECK_NO_SCRIPT_NO_EXCEPTION_MAYBE_TEARDOWN(i_isolate); + DCHECK_NO_SCRIPT_NO_EXCEPTION(i_isolate); bool ok = Utils::ApiCheck(env->IsNativeContext(), location, "Not a native context") && Utils::ApiCheck(index >= 0, location, "Negative index"); @@ -2108,42 +2239,6 @@ MaybeLocal Script::Run(Local context, } #endif auto fun = i::Handle::cast(Utils::OpenHandle(this)); - - // TODO(crbug.com/1193459): remove once ablation study is completed - base::ElapsedTimer timer; - base::TimeDelta delta; - if (i::v8_flags.script_delay > 0) { - delta = v8::base::TimeDelta::FromMillisecondsD(i::v8_flags.script_delay); - } - if (i::v8_flags.script_delay_once > 0 && !i_isolate->did_run_script_delay()) { - delta = - v8::base::TimeDelta::FromMillisecondsD(i::v8_flags.script_delay_once); - i_isolate->set_did_run_script_delay(true); - } - if (i::v8_flags.script_delay_fraction > 0.0) { - timer.Start(); - } else if (delta.InMicroseconds() > 0) { - timer.Start(); - while (timer.Elapsed() < delta) { - // Busy wait. - } - } - - if (V8_UNLIKELY(i::v8_flags.experimental_web_snapshots)) { - i::Handle maybe_script = - handle(fun->shared().script(), i_isolate); - if (maybe_script->IsScript() && - i::Script::cast(*maybe_script).type() == i::Script::TYPE_WEB_SNAPSHOT) { - i::WebSnapshotDeserializer deserializer( - reinterpret_cast(v8_isolate), - i::Handle::cast(maybe_script)); - deserializer.Deserialize(); - RETURN_ON_FAILED_EXECUTION(Value); - Local result = v8::Undefined(v8_isolate); - RETURN_ESCAPED(result); - } - } - i::Handle receiver = i_isolate->global_proxy(); // TODO(cbruni, chromium:1244145): Remove once migrated to the context. i::Handle options( @@ -2153,15 +2248,6 @@ MaybeLocal Script::Run(Local context, has_pending_exception = !ToLocal( i::Execution::CallScript(i_isolate, fun, receiver, options), &result); - if (i::v8_flags.script_delay_fraction > 0.0) { - delta = v8::base::TimeDelta::FromMillisecondsD( - timer.Elapsed().InMillisecondsF() * i::v8_flags.script_delay_fraction); - timer.Restart(); - while (timer.Elapsed() < delta) { - // Busy wait. - } - } - RETURN_ON_FAILED_EXECUTION(Value); RETURN_ESCAPED(result); } @@ -2200,6 +2286,31 @@ Local Script::GetResourceName() { i::handle(i::Script::cast(sfi.script()).name(), i_isolate)); } +std::vector Script::GetProducedCompileHints() const { + i::DisallowGarbageCollection no_gc; + i::Handle func = Utils::OpenHandle(this); + i::Isolate* i_isolate = func->GetIsolate(); + i::SharedFunctionInfo sfi = (*func).shared(); + CHECK(sfi.script().IsScript()); + i::Script script = i::Script::cast(sfi.script()); + i::Object maybe_array_list = script.compiled_lazy_function_positions(); + std::vector result; + if (!maybe_array_list.IsUndefined(i_isolate)) { + i::ArrayList array_list = i::ArrayList::cast(maybe_array_list); + result.reserve(array_list.Length()); + for (int i = 0; i < array_list.Length(); ++i) { + i::Object item = array_list.Get(i); + CHECK(item.IsSmi()); + result.push_back(i::Smi::ToInt(item)); + } + // Clear the data; the embedder can still request more data later, but it'll + // have to keep track of the original data itself. + script.set_compiled_lazy_function_positions( + i::ReadOnlyRoots(i_isolate).undefined_value()); + } + return result; +} + // static Local PrimitiveArray::New(Isolate* v8_isolate, int length) { i::Isolate* i_isolate = reinterpret_cast(v8_isolate); @@ -2304,7 +2415,7 @@ Local Module::GetException() const { "Module status must be kErrored"); i::Handle self = Utils::OpenHandle(this); i::Isolate* i_isolate = self->GetIsolate(); - ENTER_V8_MAYBE_TEARDOWN(i_isolate); + ENTER_V8_NO_SCRIPT_NO_EXCEPTION(i_isolate); return ToApiHandle(i::handle(self->GetException(), i_isolate)); } @@ -2606,9 +2717,10 @@ MaybeLocal