Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1231)

Unified Diff: runtime/vm/raw_object_snapshot.cc

Issue 1345053003: Write the contents of ICData and ObjectPools more eagerly and the contents of Code and Functions (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: Created 5 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | runtime/vm/snapshot.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: runtime/vm/raw_object_snapshot.cc
diff --git a/runtime/vm/raw_object_snapshot.cc b/runtime/vm/raw_object_snapshot.cc
index 7f20153165aa3813c048b3b8c3864aee102a9da2..ea0dc35128dafd441dae6e8939084a5d71532e0c 100644
--- a/runtime/vm/raw_object_snapshot.cc
+++ b/runtime/vm/raw_object_snapshot.cc
@@ -129,7 +129,7 @@ void RawClass::WriteTo(SnapshotWriter* writer,
writer->Write<uint16_t>(ptr()->state_bits_);
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
} else {
if (writer->can_send_any_object() ||
@@ -185,7 +185,7 @@ void RawUnresolvedClass::WriteTo(SnapshotWriter* writer,
writer->Write<int32_t>(ptr()->token_pos_);
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
}
@@ -271,7 +271,7 @@ void RawType::WriteTo(SnapshotWriter* writer,
// the type object when reading it back we should write out all the fields
// inline and not as references.
ASSERT(ptr()->type_class_ != Object::null());
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
}
@@ -309,7 +309,7 @@ void RawTypeRef::WriteTo(SnapshotWriter* writer,
writer->WriteTags(writer->GetObjectTags(this));
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
}
@@ -360,7 +360,7 @@ void RawTypeParameter::WriteTo(SnapshotWriter* writer,
writer->Write<int8_t>(ptr()->type_state_);
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
}
@@ -398,7 +398,7 @@ void RawBoundedType::WriteTo(SnapshotWriter* writer,
writer->WriteTags(writer->GetObjectTags(this));
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
}
@@ -523,7 +523,7 @@ void RawPatchClass::WriteTo(SnapshotWriter* writer,
writer->WriteVMIsolateObject(kPatchClassCid);
writer->WriteTags(writer->GetObjectTags(this));
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
}
@@ -541,7 +541,9 @@ RawClosureData* ClosureData::ReadFrom(SnapshotReader* reader,
reader->AddBackRef(object_id, &data, kIsDeserialized);
// Set all the object fields.
- READ_OBJECT_FIELDS(data, data.raw()->from(), data.raw()->to(), kAsReference);
+ READ_OBJECT_FIELDS(data,
+ data.raw()->from(), data.raw()->to(),
+ kAsInlinedObject);
return data.raw();
}
@@ -597,7 +599,9 @@ RawRedirectionData* RedirectionData::ReadFrom(SnapshotReader* reader,
reader->AddBackRef(object_id, &data, kIsDeserialized);
// Set all the object fields.
- READ_OBJECT_FIELDS(data, data.raw()->from(), data.raw()->to(), kAsReference);
+ READ_OBJECT_FIELDS(data,
+ data.raw()->from(), data.raw()->to(),
+ kAsReference);
return data.raw();
}
@@ -617,7 +621,7 @@ void RawRedirectionData::WriteTo(SnapshotWriter* writer,
writer->WriteTags(writer->GetObjectTags(this));
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
}
@@ -654,7 +658,7 @@ RawFunction* Function::ReadFrom(SnapshotReader* reader,
func.raw()->to_snapshot());
READ_OBJECT_FIELDS(func,
func.raw()->from(), toobj,
- kAsInlinedObject);
+ kAsReference);
if (!reader->snapshot_code()) {
// Initialize all fields that are not part of the snapshot.
if (!is_optimized) {
@@ -726,7 +730,7 @@ void RawFunction::WriteTo(SnapshotWriter* writer,
RawObject** toobj =
writer->snapshot_code() ? to() :
(is_optimized ? to_optimized_snapshot() : to_snapshot());
- SnapshotWriterVisitor visitor(writer, kAsInlinedObject);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), toobj);
} else {
writer->WriteFunctionId(this, owner_is_class);
@@ -855,7 +859,7 @@ void RawLiteralToken::WriteTo(SnapshotWriter* writer,
writer->Write<int32_t>(ptr()->kind_);
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
}
@@ -975,7 +979,7 @@ void RawScript::WriteTo(SnapshotWriter* writer,
writer->Write<int8_t>(ptr()->kind_);
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to_snapshot());
}
@@ -1087,7 +1091,7 @@ void RawLibrary::WriteTo(SnapshotWriter* writer,
// Write out all the object pointer fields.
RawObject** toobj = (kind == Snapshot::kFull) ? to() : to_snapshot();
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), toobj);
}
}
@@ -1140,7 +1144,7 @@ void RawLibraryPrefix::WriteTo(SnapshotWriter* writer,
writer->Write<bool>(ptr()->is_loaded_);
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
}
@@ -1178,7 +1182,7 @@ void RawNamespace::WriteTo(SnapshotWriter* writer,
writer->WriteTags(writer->GetObjectTags(this));
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
}
@@ -1200,7 +1204,7 @@ RawCode* Code::ReadFrom(SnapshotReader* reader,
// Set all the object fields.
READ_OBJECT_FIELDS(result,
result.raw()->from(), result.raw()->to(),
- kAsInlinedObject);
+ kAsReference);
// Fix entry point.
uword new_entry = result.EntryPoint();
@@ -1237,7 +1241,7 @@ void RawCode::WriteTo(SnapshotWriter* writer,
writer->Write<int32_t>(ptr()->lazy_deopt_pc_offset_);
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer, kAsInlinedObject);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
writer->SetInstructionsCode(ptr()->instructions_, this);
@@ -1309,7 +1313,8 @@ RawObjectPool* ObjectPool::ReadFrom(SnapshotReader* reader,
*reinterpret_cast<int8_t*>(info_array.DataAddr(i)) = entry_type;
switch (entry_type) {
case ObjectPool::kTaggedObject: {
- (*reader->PassiveObjectHandle()) = reader->ReadObjectImpl(kAsReference);
+ (*reader->PassiveObjectHandle()) =
+ reader->ReadObjectImpl(kAsInlinedObject);
result.SetObjectAt(i, *(reader->PassiveObjectHandle()));
break;
}
@@ -1358,7 +1363,7 @@ void RawObjectPool::WriteTo(SnapshotWriter* writer,
Entry& entry = ptr()->data()[i];
switch (entry_type) {
case ObjectPool::kTaggedObject: {
- writer->WriteObjectImpl(entry.raw_obj_, kAsReference);
+ writer->WriteObjectImpl(entry.raw_obj_, kAsInlinedObject);
break;
}
case ObjectPool::kImmediate: {
@@ -1622,7 +1627,7 @@ void RawContext::WriteTo(SnapshotWriter* writer,
writer->Write<int32_t>(num_variables);
if (num_variables != 0) {
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to(num_variables));
}
}
@@ -1706,7 +1711,7 @@ RawICData* ICData::ReadFrom(SnapshotReader* reader,
// Set all the object fields.
READ_OBJECT_FIELDS(result,
result.raw()->from(), result.raw()->to(),
- kAsReference);
+ kAsInlinedObject);
return result.raw();
}
@@ -1729,7 +1734,7 @@ void RawICData::WriteTo(SnapshotWriter* writer,
writer->Write<uint32_t>(ptr()->state_bits_);
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsInlinedObject);
visitor.VisitPointers(from(), to());
}
@@ -1774,7 +1779,7 @@ void RawMegamorphicCache::WriteTo(SnapshotWriter* writer,
writer->Write<int32_t>(ptr()->filled_entry_count_);
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
}
@@ -1869,7 +1874,7 @@ void RawApiError::WriteTo(SnapshotWriter* writer,
writer->WriteTags(writer->GetObjectTags(this));
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
}
@@ -1915,7 +1920,7 @@ void RawLanguageError::WriteTo(SnapshotWriter* writer,
writer->Write<uint8_t>(ptr()->kind_);
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
}
@@ -1947,7 +1952,7 @@ void RawUnhandledException::WriteTo(SnapshotWriter* writer,
writer->WriteVMIsolateObject(kUnhandledExceptionCid);
writer->WriteTags(writer->GetObjectTags(this));
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
}
@@ -2117,7 +2122,7 @@ void RawBigint::WriteTo(SnapshotWriter* writer,
writer->WriteTags(writer->GetObjectTags(this));
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer, false);
+ SnapshotWriterVisitor visitor(writer, kAsInlinedObject);
visitor.VisitPointers(from(), to());
}
@@ -2230,7 +2235,7 @@ RawOneByteString* OneByteString::ReadFrom(SnapshotReader* reader,
ASSERT(reader != NULL);
intptr_t len = reader->ReadSmiValue();
intptr_t hash = reader->ReadSmiValue();
- String& str_obj = String::Handle(reader->zone(), String::null());
+ String& str_obj = String::ZoneHandle(reader->zone(), String::null());
if (kind == Snapshot::kFull) {
// We currently only expect the Dart mutator to read snapshots.
@@ -2264,7 +2269,7 @@ RawTwoByteString* TwoByteString::ReadFrom(SnapshotReader* reader,
ASSERT(reader != NULL);
intptr_t len = reader->ReadSmiValue();
intptr_t hash = reader->ReadSmiValue();
- String& str_obj = String::Handle(reader->zone(), String::null());
+ String& str_obj = String::ZoneHandle(reader->zone(), String::null());
if (kind == Snapshot::kFull) {
RawTwoByteString* obj = reader->NewTwoByteString(len);
@@ -2867,7 +2872,7 @@ RawExternalTypedData* ExternalTypedData::ReadFrom(SnapshotReader* reader,
intptr_t cid = RawObject::ClassIdTag::decode(tags);
intptr_t length = reader->ReadSmiValue();
uint8_t* data = reinterpret_cast<uint8_t*>(reader->ReadRawPointerValue());
- ExternalTypedData& obj = ExternalTypedData::Handle(
+ ExternalTypedData& obj = ExternalTypedData::ZoneHandle(
ExternalTypedData::New(cid, data, length));
reader->AddBackRef(object_id, &obj, kIsDeserialized);
void* peer = reinterpret_cast<void*>(reader->ReadRawPointerValue());
@@ -3142,7 +3147,7 @@ void RawStacktrace::WriteTo(SnapshotWriter* writer,
writer->Write(ptr()->expand_inlined_);
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
} else {
// Stacktraces are not allowed in other snapshot forms.
@@ -3234,7 +3239,7 @@ void RawWeakProperty::WriteTo(SnapshotWriter* writer,
writer->WriteTags(writer->GetObjectTags(this));
// Write out all the object pointer fields.
- SnapshotWriterVisitor visitor(writer);
+ SnapshotWriterVisitor visitor(writer, kAsReference);
visitor.VisitPointers(from(), to());
}
« no previous file with comments | « no previous file | runtime/vm/snapshot.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698