Commit 231c83ed authored by Georg Neis's avatar Georg Neis Committed by Commit Bot

[turbofan] Weaken --concurrent-compiler-frontend.

For the sake of incremental development it makes sense to still allow
serialization to happen even when the broker is in mode 'kSerialized'.
To locally obtain the stricter behavior, I'm adding the temporary flag
--strict-heap-broker.

Bug: v8:7790
Change-Id: Ie92f4f13d76bac9ce1f98bdd245829984d436d77
Reviewed-on: https://chromium-review.googlesource.com/1156603
Commit-Queue: Georg Neis <neis@chromium.org>
Reviewed-by: 's avatarJaroslav Sevcik <jarin@chromium.org>
Cr-Commit-Position: refs/heads/master@{#54824}
parent bb9cf1cb
...@@ -57,7 +57,7 @@ class HeapObjectData : public ObjectData { ...@@ -57,7 +57,7 @@ class HeapObjectData : public ObjectData {
map(broker->GetOrCreateData(handle(object_->map(), broker_->isolate())) map(broker->GetOrCreateData(handle(object_->map(), broker_->isolate()))
->AsMap()) { ->AsMap()) {
CHECK_NOT_NULL(map); CHECK_NOT_NULL(map);
CHECK_EQ(broker_->mode(), JSHeapBroker::kSerializing); CHECK(broker_->SerializingAllowed());
} }
}; };
...@@ -100,8 +100,7 @@ class NativeContextData : public ContextData { ...@@ -100,8 +100,7 @@ class NativeContextData : public ContextData {
: ContextData(broker_, object_, type_), sloppy_arguments_map_(nullptr) { : ContextData(broker_, object_, type_), sloppy_arguments_map_(nullptr) {
// There's no NativeContext class, so we take object_ as Context. // There's no NativeContext class, so we take object_ as Context.
CHECK(object_->IsNativeContext()); CHECK(object_->IsNativeContext());
CHECK_EQ(broker->mode(), JSHeapBroker::kSerializing); CHECK(broker->SerializingAllowed());
Handle<Map> map(object_->sloppy_arguments_map(), broker->isolate()); Handle<Map> map(object_->sloppy_arguments_map(), broker->isolate());
sloppy_arguments_map_ = broker->GetOrCreateData(map)->AsMap(); sloppy_arguments_map_ = broker->GetOrCreateData(map)->AsMap();
CHECK_NOT_NULL(sloppy_arguments_map_); CHECK_NOT_NULL(sloppy_arguments_map_);
...@@ -146,7 +145,7 @@ HEAP_BROKER_OBJECT_LIST(DEFINE_IS_AND_AS) ...@@ -146,7 +145,7 @@ HEAP_BROKER_OBJECT_LIST(DEFINE_IS_AND_AS)
#undef DEFINE_IS_AND_AS #undef DEFINE_IS_AND_AS
ObjectData* ObjectData::Serialize(JSHeapBroker* broker, Handle<Object> object) { ObjectData* ObjectData::Serialize(JSHeapBroker* broker, Handle<Object> object) {
CHECK_EQ(broker->mode(), JSHeapBroker::kSerializing); CHECK(broker->SerializingAllowed());
return object->IsSmi() ? new (broker->zone()) ObjectData(broker, object, true) return object->IsSmi() ? new (broker->zone()) ObjectData(broker, object, true)
: HeapObjectData::Serialize( : HeapObjectData::Serialize(
broker, Handle<HeapObject>::cast(object)); broker, Handle<HeapObject>::cast(object));
...@@ -154,7 +153,7 @@ ObjectData* ObjectData::Serialize(JSHeapBroker* broker, Handle<Object> object) { ...@@ -154,7 +153,7 @@ ObjectData* ObjectData::Serialize(JSHeapBroker* broker, Handle<Object> object) {
HeapObjectData* HeapObjectData::Serialize(JSHeapBroker* broker, HeapObjectData* HeapObjectData::Serialize(JSHeapBroker* broker,
Handle<HeapObject> object) { Handle<HeapObject> object) {
CHECK_EQ(broker->mode(), JSHeapBroker::kSerializing); CHECK(broker->SerializingAllowed());
Handle<Map> map(object->map(), broker->isolate()); Handle<Map> map(object->map(), broker->isolate());
HeapObjectType type = broker->HeapObjectTypeFromMap(map); HeapObjectType type = broker->HeapObjectTypeFromMap(map);
...@@ -228,6 +227,11 @@ JSHeapBroker::JSHeapBroker(Isolate* isolate, Zone* zone) ...@@ -228,6 +227,11 @@ JSHeapBroker::JSHeapBroker(Isolate* isolate, Zone* zone)
} }
} }
bool JSHeapBroker::SerializingAllowed() const {
return mode() == kSerializing ||
(!FLAG_strict_heap_broker && mode() == kSerialized);
}
void JSHeapBroker::SerializeStandardObjects() { void JSHeapBroker::SerializeStandardObjects() {
if (FLAG_trace_heap_broker) { if (FLAG_trace_heap_broker) {
PrintF("[%p] Serializing standard objects.\n", this); PrintF("[%p] Serializing standard objects.\n", this);
...@@ -287,13 +291,12 @@ ObjectData* JSHeapBroker::GetData(Handle<Object> object) const { ...@@ -287,13 +291,12 @@ ObjectData* JSHeapBroker::GetData(Handle<Object> object) const {
} }
ObjectData* JSHeapBroker::GetOrCreateData(Handle<Object> object) { ObjectData* JSHeapBroker::GetOrCreateData(Handle<Object> object) {
CHECK_EQ(mode(), JSHeapBroker::kSerializing); CHECK(SerializingAllowed());
ObjectData* data = GetData(object); ObjectData* data = GetData(object);
if (data == nullptr) { if (data == nullptr) {
// TODO(neis): Remove these Allow* once we serialize everything upfront. // TODO(neis): Remove these Allow* once we serialize everything upfront.
AllowHandleAllocation handle_allocation; AllowHandleAllocation handle_allocation;
AllowHandleDereference handle_dereference; AllowHandleDereference handle_dereference;
CHECK_EQ(mode(), JSHeapBroker::kSerializing);
data = ObjectData::Serialize(this, object); data = ObjectData::Serialize(this, object);
} }
CHECK_NOT_NULL(data); CHECK_NOT_NULL(data);
...@@ -1115,7 +1118,8 @@ PropertyDetails PropertyCellRef::property_details() const { ...@@ -1115,7 +1118,8 @@ PropertyDetails PropertyCellRef::property_details() const {
ObjectRef::ObjectRef(JSHeapBroker* broker, Handle<Object> object) { ObjectRef::ObjectRef(JSHeapBroker* broker, Handle<Object> object) {
switch (broker->mode()) { switch (broker->mode()) {
case JSHeapBroker::kSerialized: case JSHeapBroker::kSerialized:
data_ = broker->GetData(object); data_ = FLAG_strict_heap_broker ? broker->GetData(object)
: broker->GetOrCreateData(object);
break; break;
case JSHeapBroker::kSerializing: case JSHeapBroker::kSerializing:
data_ = broker->GetOrCreateData(object); data_ = broker->GetOrCreateData(object);
......
...@@ -424,6 +424,7 @@ class V8_EXPORT_PRIVATE JSHeapBroker : public NON_EXPORTED_BASE(ZoneObject) { ...@@ -424,6 +424,7 @@ class V8_EXPORT_PRIVATE JSHeapBroker : public NON_EXPORTED_BASE(ZoneObject) {
CHECK_EQ(mode_, kSerializing); CHECK_EQ(mode_, kSerializing);
mode_ = kSerialized; mode_ = kSerialized;
} }
bool SerializingAllowed() const;
// Returns nullptr iff handle unknown. // Returns nullptr iff handle unknown.
ObjectData* GetData(Handle<Object>) const; ObjectData* GetData(Handle<Object>) const;
......
...@@ -383,6 +383,7 @@ DEFINE_BOOL(block_concurrent_recompilation, false, ...@@ -383,6 +383,7 @@ DEFINE_BOOL(block_concurrent_recompilation, false,
"block queued jobs until released") "block queued jobs until released")
DEFINE_BOOL(concurrent_compiler_frontend, false, DEFINE_BOOL(concurrent_compiler_frontend, false,
"run optimizing compiler's frontend phases on a separate thread") "run optimizing compiler's frontend phases on a separate thread")
DEFINE_BOOL(strict_heap_broker, false, "fail on incomplete serialization")
DEFINE_BOOL(trace_heap_broker, false, "trace the heap broker") DEFINE_BOOL(trace_heap_broker, false, "trace the heap broker")
// Flags for stress-testing the compiler. // Flags for stress-testing the compiler.
......
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