Commit 7af52329 authored by Georg Neis's avatar Georg Neis Committed by Commit Bot

[turbofan] Serialize initial map's predicted instance size.

Bug: v8:7790
Change-Id: I3077883a8509a988090d2c051e5bd85c139a38e6
Reviewed-on: https://chromium-review.googlesource.com/1224326
Commit-Queue: Georg Neis <neis@chromium.org>
Reviewed-by: 's avatarJaroslav Sevcik <jarin@chromium.org>
Reviewed-by: 's avatarMaya Lekova <mslekova@chromium.org>
Cr-Commit-Position: refs/heads/master@{#55890}
parent 42231e43
...@@ -155,20 +155,25 @@ void JSObjectData::SerializeObjectCreateMap() { ...@@ -155,20 +155,25 @@ void JSObjectData::SerializeObjectCreateMap() {
class JSFunctionData : public JSObjectData { class JSFunctionData : public JSObjectData {
public: public:
JSFunctionData(JSHeapBroker* broker, Handle<JSFunction> object,
HeapObjectType type);
bool has_initial_map() const { return has_initial_map_; } bool has_initial_map() const { return has_initial_map_; }
bool has_prototype() const { return has_prototype_; } bool has_prototype() const { return has_prototype_; }
bool PrototypeRequiresRuntimeLookup() const { bool PrototypeRequiresRuntimeLookup() const {
return PrototypeRequiresRuntimeLookup_; return PrototypeRequiresRuntimeLookup_;
} }
void Serialize();
JSGlobalProxyData* global_proxy() const { return global_proxy_; } JSGlobalProxyData* global_proxy() const { return global_proxy_; }
MapData* initial_map() const { return initial_map_; } MapData* initial_map() const { return initial_map_; }
ObjectData* prototype() const { return prototype_; } ObjectData* prototype() const { return prototype_; }
SharedFunctionInfoData* shared() const { return shared_; } SharedFunctionInfoData* shared() const { return shared_; }
int initial_map_instance_size_with_min_slack() const {
JSFunctionData(JSHeapBroker* broker, Handle<JSFunction> object, CHECK(serialized_);
HeapObjectType type); return initial_map_instance_size_with_min_slack_;
void Serialize(); }
private: private:
bool has_initial_map_; bool has_initial_map_;
...@@ -181,6 +186,7 @@ class JSFunctionData : public JSObjectData { ...@@ -181,6 +186,7 @@ class JSFunctionData : public JSObjectData {
MapData* initial_map_ = nullptr; MapData* initial_map_ = nullptr;
ObjectData* prototype_ = nullptr; ObjectData* prototype_ = nullptr;
SharedFunctionInfoData* shared_ = nullptr; SharedFunctionInfoData* shared_ = nullptr;
int initial_map_instance_size_with_min_slack_;
}; };
class JSRegExpData : public JSObjectData { class JSRegExpData : public JSObjectData {
...@@ -588,6 +594,8 @@ void JSFunctionData::Serialize() { ...@@ -588,6 +594,8 @@ void JSFunctionData::Serialize() {
: nullptr; : nullptr;
if (initial_map_ != nullptr) { if (initial_map_ != nullptr) {
initial_map_instance_size_with_min_slack_ =
function->ComputeInstanceSizeWithMinSlack(broker()->isolate());
if (initial_map_->instance_type() == JS_ARRAY_TYPE) { if (initial_map_->instance_type() == JS_ARRAY_TYPE) {
initial_map_->SerializeElementsKindGeneralizations(); initial_map_->SerializeElementsKindGeneralizations();
} }
...@@ -1409,11 +1417,13 @@ base::Optional<MapRef> MapRef::AsElementsKind(ElementsKind kind) const { ...@@ -1409,11 +1417,13 @@ base::Optional<MapRef> MapRef::AsElementsKind(ElementsKind kind) const {
} }
int JSFunctionRef::InitialMapInstanceSizeWithMinSlack() const { int JSFunctionRef::InitialMapInstanceSizeWithMinSlack() const {
AllowHandleDereference allow_handle_dereference; if (broker()->mode() == JSHeapBroker::kDisabled) {
AllowHandleAllocation handle_allocation; AllowHandleDereference allow_handle_dereference;
AllowHandleAllocation handle_allocation;
return object<JSFunction>()->ComputeInstanceSizeWithMinSlack( return object<JSFunction>()->ComputeInstanceSizeWithMinSlack(
broker()->isolate()); broker()->isolate());
}
return data()->AsJSFunction()->initial_map_instance_size_with_min_slack();
} }
base::Optional<ScriptContextTableRef::LookupResult> base::Optional<ScriptContextTableRef::LookupResult>
......
...@@ -181,7 +181,6 @@ class JSFunctionRef : public JSObjectRef { ...@@ -181,7 +181,6 @@ class JSFunctionRef : public JSObjectRef {
bool has_prototype() const; bool has_prototype() const;
bool IsConstructor() const; bool IsConstructor() const;
bool PrototypeRequiresRuntimeLookup() const; bool PrototypeRequiresRuntimeLookup() const;
int InitialMapInstanceSizeWithMinSlack() const;
void Serialize(); void Serialize();
...@@ -190,6 +189,7 @@ class JSFunctionRef : public JSObjectRef { ...@@ -190,6 +189,7 @@ class JSFunctionRef : public JSObjectRef {
MapRef initial_map() const; MapRef initial_map() const;
JSGlobalProxyRef global_proxy() const; JSGlobalProxyRef global_proxy() const;
SharedFunctionInfoRef shared() const; SharedFunctionInfoRef shared() const;
int InitialMapInstanceSizeWithMinSlack() const;
}; };
class JSRegExpRef : public JSObjectRef { class JSRegExpRef : public JSObjectRef {
......
...@@ -13408,8 +13408,8 @@ MaybeHandle<Map> JSFunction::GetDerivedMap(Isolate* isolate, ...@@ -13408,8 +13408,8 @@ MaybeHandle<Map> JSFunction::GetDerivedMap(Isolate* isolate,
} }
int JSFunction::ComputeInstanceSizeWithMinSlack(Isolate* isolate) { int JSFunction::ComputeInstanceSizeWithMinSlack(Isolate* isolate) {
if (has_prototype_slot() && has_initial_map() && CHECK(has_initial_map());
initial_map()->IsInobjectSlackTrackingInProgress()) { if (initial_map()->IsInobjectSlackTrackingInProgress()) {
int slack = initial_map()->ComputeMinObjectSlack(isolate); int slack = initial_map()->ComputeMinObjectSlack(isolate);
return initial_map()->InstanceSizeFromSlack(slack); return initial_map()->InstanceSizeFromSlack(slack);
} }
......
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