From 1b8b11001002d71699cf6cc895823bef1a7d60e7 Mon Sep 17 00:00:00 2001 From: Stefan Stojanovic Date: Mon, 29 Jan 2024 11:18:19 +0100 Subject: [PATCH] V8 v12.2 Windows patch (#13) * Nightly patch * v12.1 patch * v12.2 patch --- .../src/builtins/builtins-collections-gen.cc | 7 ++- deps/v8/src/codegen/code-stub-assembler.cc | 2 +- deps/v8/src/compiler/turboshaft/assembler.h | 5 +- ...de-elimination-and-simplification-phase.cc | 3 +- .../src/compiler/turboshaft/copying-phase.h | 32 ++++++++---- .../compiler/turboshaft/csa-optimize-phase.cc | 10 ++-- .../debug-feature-lowering-phase.cc | 2 +- .../turboshaft/int64-lowering-phase.cc | 2 +- .../compiler/turboshaft/loop-peeling-phase.cc | 2 +- .../turboshaft/loop-unrolling-phase.cc | 2 +- .../turboshaft/machine-lowering-phase.cc | 4 +- .../turboshaft/machine-optimization-reducer.h | 50 ++++--------------- .../src/compiler/turboshaft/optimize-phase.cc | 2 +- .../turboshaft/simplified-lowering-phase.cc | 2 +- .../turboshaft/simplified-lowering-reducer.h | 14 +++--- .../store-store-elimination-phase.cc | 2 +- .../turboshaft/type-assertions-phase.cc | 3 +- .../turboshaft/typed-optimizations-phase.cc | 3 +- .../wasm-dead-code-elimination-phase.cc | 3 +- .../turboshaft/wasm-gc-optimize-phase.cc | 2 +- .../turboshaft/wasm-lowering-phase.cc | 2 +- .../turboshaft/wasm-optimize-phase.cc | 2 +- .../compiler/turboshaft/wasm-revec-phase.cc | 2 +- deps/v8/src/heap/heap.cc | 2 +- deps/v8/src/objects/dictionary.h | 5 +- deps/v8/src/objects/fixed-array.h | 18 ++++--- deps/v8/src/objects/hash-table-inl.h | 12 ++--- deps/v8/src/objects/hash-table.h | 11 ++-- deps/v8/src/objects/objects.cc | 42 ++++++++-------- deps/v8/src/objects/template-objects.cc | 2 +- 30 files changed, 121 insertions(+), 129 deletions(-) diff --git a/deps/v8/src/builtins/builtins-collections-gen.cc b/deps/v8/src/builtins/builtins-collections-gen.cc index e5e6026ce61632..6fea5c37e8c2f2 100644 --- a/deps/v8/src/builtins/builtins-collections-gen.cc +++ b/deps/v8/src/builtins/builtins-collections-gen.cc @@ -2782,10 +2782,9 @@ TNode WeakCollectionsBuiltinsAssembler::ShouldShrink( TNode WeakCollectionsBuiltinsAssembler::ValueIndexFromKeyIndex( TNode key_index) { - return IntPtrAdd( - key_index, - IntPtrConstant(EphemeronHashTable::TodoShape::kEntryValueIndex - - EphemeronHashTable::kEntryKeyIndex)); + return IntPtrAdd(key_index, + IntPtrConstant(EphemeronHashTable::ShapeT::kEntryValueIndex - + EphemeronHashTable::kEntryKeyIndex)); } TF_BUILTIN(WeakMapConstructor, WeakCollectionsBuiltinsAssembler) { diff --git a/deps/v8/src/codegen/code-stub-assembler.cc b/deps/v8/src/codegen/code-stub-assembler.cc index 170cf773d71c39..ec9f176f342d64 100644 --- a/deps/v8/src/codegen/code-stub-assembler.cc +++ b/deps/v8/src/codegen/code-stub-assembler.cc @@ -9455,7 +9455,7 @@ void CodeStubAssembler::NameDictionaryLookup( CAST(UnsafeLoadFixedArrayElement(dictionary, index)); GotoIf(TaggedEqual(current, undefined), if_not_found); if (mode == kFindExisting) { - if (Dictionary::TodoShape::kMatchNeedsHoleCheck) { + if (Dictionary::ShapeT::kMatchNeedsHoleCheck) { GotoIf(TaggedEqual(current, TheHoleConstant()), &next_probe); } current = LoadName(current); diff --git a/deps/v8/src/compiler/turboshaft/assembler.h b/deps/v8/src/compiler/turboshaft/assembler.h index 81a952bf580145..96303f68300024 100644 --- a/deps/v8/src/compiler/turboshaft/assembler.h +++ b/deps/v8/src/compiler/turboshaft/assembler.h @@ -3934,8 +3934,9 @@ class TSAssembler : public Assembler> { public: - using Assembler>::Assembler; + explicit TSAssembler(Graph& input_graph, Graph& output_graph, + Zone* phase_zone) + : Assembler(input_graph, output_graph, phase_zone) {} }; #include "src/compiler/turboshaft/undef-assembler-macros.inc" diff --git a/deps/v8/src/compiler/turboshaft/code-elimination-and-simplification-phase.cc b/deps/v8/src/compiler/turboshaft/code-elimination-and-simplification-phase.cc index 416d0da2ad3846..8871e72747fc0b 100644 --- a/deps/v8/src/compiler/turboshaft/code-elimination-and-simplification-phase.cc +++ b/deps/v8/src/compiler/turboshaft/code-elimination-and-simplification-phase.cc @@ -32,7 +32,8 @@ void CodeEliminationAndSimplificationPhase::Run(Zone* temp_zone) { // (which, for simplificy, doesn't use the Assembler helper // methods, but only calls Next::ReduceLoad/Store). DuplicationOptimizationReducer, - ValueNumberingReducer>::Run(temp_zone); + ValueNumberingReducer, + VariableReducerHotfix>::Run(temp_zone); } } // namespace v8::internal::compiler::turboshaft diff --git a/deps/v8/src/compiler/turboshaft/copying-phase.h b/deps/v8/src/compiler/turboshaft/copying-phase.h index 64893f7173cbf6..82c0e506935cb3 100644 --- a/deps/v8/src/compiler/turboshaft/copying-phase.h +++ b/deps/v8/src/compiler/turboshaft/copying-phase.h @@ -36,6 +36,16 @@ struct PaddingSpace { V8_EXPORT_PRIVATE std::ostream& operator<<(std::ostream& os, PaddingSpace padding); +template +class VariableReducerHotfix : public Next { +public: + void SetVariable(Variable var, OpIndex new_index) {} + Variable NewLoopInvariantVariable(MaybeRegisterRepresentation rep) { return Variable(); } + + OpIndex GetVariable(Variable var) { return OpIndex(); } + OpIndex GetPredecessorValue(Variable var, int predecessor_index) { return OpIndex(); } +}; + template class ReducerBaseForwarder; template @@ -46,6 +56,9 @@ class GraphVisitor : public Next { template friend class ReducerBaseForwarder; + private: + bool contains_variable_reducer_; + public: TURBOSHAFT_REDUCER_BOILERPLATE() @@ -66,7 +79,8 @@ class GraphVisitor : public Next { // `trace_reduction` is a template parameter to avoid paying for tracing at // runtime. template - void VisitGraph() { + void VisitGraph(bool contains_variable_reducer) { + contains_variable_reducer_ = contains_variable_reducer; Asm().Analyze(); // Creating initial old-to-new Block mapping. @@ -177,8 +191,7 @@ class GraphVisitor : public Next { DCHECK(old_index.valid()); OpIndex result = op_mapping_[old_index]; - if constexpr (reducer_list_contains::value) { + if (contains_variable_reducer_) { if (!result.valid()) { // {op_mapping} doesn't have a mapping for {old_index}. The assembler // should provide the mapping. @@ -1294,8 +1307,7 @@ class GraphVisitor : public Next { DCHECK(Asm().input_graph().BelongsToThisGraph(old_index)); DCHECK_IMPLIES(new_index.valid(), Asm().output_graph().BelongsToThisGraph(new_index)); - if constexpr (reducer_list_contains::value) { + if (contains_variable_reducer_) { if (current_block_needs_variables_) { MaybeVariable var = GetVariableFor(old_index); if (!var.has_value()) { @@ -1392,18 +1404,19 @@ class TSAssembler; template