Commit 5acef050 authored by Santiago Aboy Solanes's avatar Santiago Aboy Solanes Committed by Commit Bot

[compiler] Move GetPropertyDetails to DescriptorArrayRef

Also access the DescriptorArray through GetPropertyDetails concurrently
if the FLAG_turbo_direct_heap_access is on.

Bug: v8:7790
Change-Id: I13d12786399443ca1590dd87da7f371720acaa18
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2640421
Commit-Queue: Santiago Aboy Solanes <solanes@chromium.org>
Reviewed-by: 's avatarGeorg Neis <neis@chromium.org>
Cr-Commit-Position: refs/heads/master@{#72290}
parent 29006bb3
...@@ -536,6 +536,8 @@ class DescriptorArrayRef : public HeapObjectRef { ...@@ -536,6 +536,8 @@ class DescriptorArrayRef : public HeapObjectRef {
DEFINE_REF_CONSTRUCTOR(DescriptorArray, HeapObjectRef) DEFINE_REF_CONSTRUCTOR(DescriptorArray, HeapObjectRef)
Handle<DescriptorArray> object() const; Handle<DescriptorArray> object() const;
PropertyDetails GetPropertyDetails(InternalIndex descriptor_index) const;
}; };
class FeedbackCellRef : public HeapObjectRef { class FeedbackCellRef : public HeapObjectRef {
...@@ -681,6 +683,8 @@ class V8_EXPORT_PRIVATE MapRef : public HeapObjectRef { ...@@ -681,6 +683,8 @@ class V8_EXPORT_PRIVATE MapRef : public HeapObjectRef {
base::Optional<ObjectRef> GetStrongValue( base::Optional<ObjectRef> GetStrongValue(
InternalIndex descriptor_number) const; InternalIndex descriptor_number) const;
DescriptorArrayRef instance_descriptors() const;
void SerializeRootMap(); void SerializeRootMap();
base::Optional<MapRef> FindRootMap() const; base::Optional<MapRef> FindRootMap() const;
......
...@@ -2227,9 +2227,11 @@ void MapData::SerializeOwnDescriptor(JSHeapBroker* broker, ...@@ -2227,9 +2227,11 @@ void MapData::SerializeOwnDescriptor(JSHeapBroker* broker,
broker->GetOrCreateData(map->instance_descriptors(kRelaxedLoad)); broker->GetOrCreateData(map->instance_descriptors(kRelaxedLoad));
} }
DescriptorArrayData* descriptor_array = if (!instance_descriptors()->should_access_heap()) {
instance_descriptors()->AsDescriptorArray(); DescriptorArrayData* descriptors =
descriptor_array->SerializeDescriptor(broker, map, descriptor_index); instance_descriptors()->AsDescriptorArray();
descriptors->SerializeDescriptor(broker, map, descriptor_index);
}
} }
void MapData::SerializeRootMap(JSHeapBroker* broker) { void MapData::SerializeRootMap(JSHeapBroker* broker) {
...@@ -3145,14 +3147,7 @@ int MapRef::GetInObjectPropertyOffset(int i) const { ...@@ -3145,14 +3147,7 @@ int MapRef::GetInObjectPropertyOffset(int i) const {
PropertyDetails MapRef::GetPropertyDetails( PropertyDetails MapRef::GetPropertyDetails(
InternalIndex descriptor_index) const { InternalIndex descriptor_index) const {
if (data_->should_access_heap()) { return instance_descriptors().GetPropertyDetails(descriptor_index);
return object()
->instance_descriptors(kRelaxedLoad)
.GetDetails(descriptor_index);
}
DescriptorArrayData* descriptors =
data()->AsMap()->instance_descriptors()->AsDescriptorArray();
return descriptors->GetPropertyDetails(descriptor_index);
} }
NameRef MapRef::GetPropertyKey(InternalIndex descriptor_index) const { NameRef MapRef::GetPropertyKey(InternalIndex descriptor_index) const {
...@@ -3659,6 +3654,16 @@ base::Optional<ObjectRef> MapRef::GetStrongValue( ...@@ -3659,6 +3654,16 @@ base::Optional<ObjectRef> MapRef::GetStrongValue(
return ObjectRef(broker(), value); return ObjectRef(broker(), value);
} }
DescriptorArrayRef MapRef::instance_descriptors() const {
if (data_->should_access_heap()) {
return DescriptorArrayRef(
broker(), broker()->CanonicalPersistentHandle(
object()->instance_descriptors(kRelaxedLoad)));
}
return DescriptorArrayRef(broker(), data()->AsMap()->instance_descriptors());
}
void MapRef::SerializeRootMap() { void MapRef::SerializeRootMap() {
if (data_->should_access_heap()) return; if (data_->should_access_heap()) return;
CHECK_EQ(broker()->mode(), JSHeapBroker::kSerializing); CHECK_EQ(broker()->mode(), JSHeapBroker::kSerializing);
...@@ -4044,6 +4049,14 @@ Float64 FixedDoubleArrayData::Get(int i) const { ...@@ -4044,6 +4049,14 @@ Float64 FixedDoubleArrayData::Get(int i) const {
return contents_[i]; return contents_[i];
} }
PropertyDetails DescriptorArrayRef::GetPropertyDetails(
InternalIndex descriptor_index) const {
if (data_->should_access_heap() || FLAG_turbo_direct_heap_access) {
return object()->GetDetails(descriptor_index);
}
return data()->AsDescriptorArray()->GetPropertyDetails(descriptor_index);
}
base::Optional<SharedFunctionInfoRef> FeedbackCellRef::shared_function_info() base::Optional<SharedFunctionInfoRef> FeedbackCellRef::shared_function_info()
const { const {
if (value()) { if (value()) {
...@@ -4310,6 +4323,7 @@ void JSObjectRef::SerializeObjectCreateMap() { ...@@ -4310,6 +4323,7 @@ void JSObjectRef::SerializeObjectCreateMap() {
} }
void MapRef::SerializeOwnDescriptor(InternalIndex descriptor_index) { void MapRef::SerializeOwnDescriptor(InternalIndex descriptor_index) {
CHECK_LT(descriptor_index.as_int(), NumberOfOwnDescriptors());
if (data_->should_access_heap()) return; if (data_->should_access_heap()) return;
CHECK_EQ(broker()->mode(), JSHeapBroker::kSerializing); CHECK_EQ(broker()->mode(), JSHeapBroker::kSerializing);
data()->AsMap()->SerializeOwnDescriptor(broker(), descriptor_index); data()->AsMap()->SerializeOwnDescriptor(broker(), descriptor_index);
...@@ -4320,6 +4334,7 @@ bool MapRef::serialized_own_descriptor(InternalIndex descriptor_index) const { ...@@ -4320,6 +4334,7 @@ bool MapRef::serialized_own_descriptor(InternalIndex descriptor_index) const {
if (data_->should_access_heap()) return true; if (data_->should_access_heap()) return true;
ObjectData* maybe_desc_array_data = data()->AsMap()->instance_descriptors(); ObjectData* maybe_desc_array_data = data()->AsMap()->instance_descriptors();
if (!maybe_desc_array_data) return false; if (!maybe_desc_array_data) return false;
if (maybe_desc_array_data->should_access_heap()) return true;
DescriptorArrayData* desc_array_data = DescriptorArrayData* desc_array_data =
maybe_desc_array_data->AsDescriptorArray(); maybe_desc_array_data->AsDescriptorArray();
return desc_array_data->serialized_descriptor(descriptor_index); return desc_array_data->serialized_descriptor(descriptor_index);
......
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