Commit 7ce5dd6e authored by Santiago Aboy Solanes's avatar Santiago Aboy Solanes Committed by Commit Bot

Reland "[compiler] Replace Symbol with direct reads"

This is a reland of d3b295fa

Got speculatively reverted in https://crrev.com/c/v8/v8/+/2403256 but
doesn't seem to have been causing the TSAN failures

Original change's description:
> [compiler] Replace Symbol with direct reads
>
> Bug: v8:7790
> Change-Id: I49120a6349777fd992a97d697940e79b2e71dbd1
> Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2400988
> Commit-Queue: Santiago Aboy Solanes <solanes@chromium.org>
> Reviewed-by: Georg Neis <neis@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#69812}

Bug: v8:7790
Change-Id: I459f4bfc881c641258dcc46fc55fce21f9e03dec
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2403921
Commit-Queue: Santiago Aboy Solanes <solanes@chromium.org>
Commit-Queue: Georg Neis <neis@chromium.org>
Auto-Submit: Santiago Aboy Solanes <solanes@chromium.org>
Reviewed-by: 's avatarGeorg Neis <neis@chromium.org>
Cr-Commit-Position: refs/heads/master@{#69822}
parent 669d4668
...@@ -59,6 +59,8 @@ enum class OddballType : uint8_t { ...@@ -59,6 +59,8 @@ enum class OddballType : uint8_t {
V(ObjectBoilerplateDescription) \ V(ObjectBoilerplateDescription) \
/* Subtypes of FixedArrayBase */ \ /* Subtypes of FixedArrayBase */ \
V(FixedDoubleArray) \ V(FixedDoubleArray) \
/* Subtypes of Name */ \
V(Symbol) \
/* Subtypes of HeapObject */ \ /* Subtypes of HeapObject */ \
V(ArrayBoilerplateDescription) \ V(ArrayBoilerplateDescription) \
V(HeapNumber) V(HeapNumber)
...@@ -87,7 +89,6 @@ enum class OddballType : uint8_t { ...@@ -87,7 +89,6 @@ enum class OddballType : uint8_t {
/* Subtypes of Name */ \ /* Subtypes of Name */ \
V(InternalizedString) \ V(InternalizedString) \
V(String) \ V(String) \
V(Symbol) \
/* Subtypes of JSReceiver */ \ /* Subtypes of JSReceiver */ \
V(JSObject) \ V(JSObject) \
/* Subtypes of HeapObject */ \ /* Subtypes of HeapObject */ \
......
...@@ -838,7 +838,9 @@ class StringData : public NameData { ...@@ -838,7 +838,9 @@ class StringData : public NameData {
class SymbolData : public NameData { class SymbolData : public NameData {
public: public:
SymbolData(JSHeapBroker* broker, ObjectData** storage, Handle<Symbol> object) SymbolData(JSHeapBroker* broker, ObjectData** storage, Handle<Symbol> object)
: NameData(broker, storage, object) {} : NameData(broker, storage, object) {
DCHECK(!FLAG_turbo_direct_heap_access);
}
}; };
StringData::StringData(JSHeapBroker* broker, ObjectData** storage, StringData::StringData(JSHeapBroker* broker, ObjectData** storage,
......
...@@ -1509,6 +1509,9 @@ struct TyperPhase { ...@@ -1509,6 +1509,9 @@ struct TyperPhase {
LoopVariableOptimizer induction_vars(data->jsgraph()->graph(), LoopVariableOptimizer induction_vars(data->jsgraph()->graph(),
data->common(), temp_zone); data->common(), temp_zone);
if (FLAG_turbo_loop_variable) induction_vars.Run(); if (FLAG_turbo_loop_variable) induction_vars.Run();
// The typer inspects heap objects, so we need to unpark the local heap.
UnparkedScopeIfNeeded scope(data->broker());
typer->Run(roots, &induction_vars); typer->Run(roots, &induction_vars);
} }
}; };
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment