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

Side by Side Diff: src/snapshot-common.cc

Issue 780833002: Revert of Encode reservation meta data in the snapshot blob. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@snapshotformat
Patch Set: Created 6 years 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 unified diff | Download patch
« no previous file with comments | « src/snapshot.h ('k') | src/snapshot-empty.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2006-2008 the V8 project authors. All rights reserved. 1 // Copyright 2006-2008 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 // The common functionality when building with or without snapshots. 5 // The common functionality when building with or without snapshots.
6 6
7 #include "src/v8.h" 7 #include "src/v8.h"
8 8
9 #include "src/api.h" 9 #include "src/api.h"
10 #include "src/base/platform/platform.h" 10 #include "src/base/platform/platform.h"
11 #include "src/serialize.h" 11 #include "src/serialize.h"
12 #include "src/snapshot.h" 12 #include "src/snapshot.h"
13 13
14 namespace v8 { 14 namespace v8 {
15 namespace internal { 15 namespace internal {
16 16
17 void Snapshot::ReserveSpaceForLinkedInSnapshot(Deserializer* deserializer) {
18 deserializer->AddReservation(NEW_SPACE, new_space_used_);
19 deserializer->AddReservation(OLD_POINTER_SPACE, pointer_space_used_);
20 deserializer->AddReservation(OLD_DATA_SPACE, data_space_used_);
21 deserializer->AddReservation(CODE_SPACE, code_space_used_);
22 deserializer->AddReservation(MAP_SPACE, map_space_used_);
23 deserializer->AddReservation(CELL_SPACE, cell_space_used_);
24 deserializer->AddReservation(PROPERTY_CELL_SPACE, property_cell_space_used_);
25 deserializer->AddReservation(LO_SPACE, lo_space_used_);
26 }
27
17 28
18 bool Snapshot::Initialize(Isolate* isolate) { 29 bool Snapshot::Initialize(Isolate* isolate) {
19 if (size_ > 0) { 30 if (size_ > 0) {
20 base::ElapsedTimer timer; 31 base::ElapsedTimer timer;
21 if (FLAG_profile_deserialization) timer.Start(); 32 if (FLAG_profile_deserialization) {
22 33 timer.Start();
23 SnapshotData snapshot_data(data_, size_); 34 }
24 Deserializer deserializer(&snapshot_data); 35 SnapshotByteSource source(raw_data_, raw_size_);
36 Deserializer deserializer(&source);
37 ReserveSpaceForLinkedInSnapshot(&deserializer);
25 bool success = isolate->Init(&deserializer); 38 bool success = isolate->Init(&deserializer);
26 if (FLAG_profile_deserialization) { 39 if (FLAG_profile_deserialization) {
27 double ms = timer.Elapsed().InMillisecondsF(); 40 double ms = timer.Elapsed().InMillisecondsF();
28 PrintF("[Snapshot loading and deserialization took %0.3f ms]\n", ms); 41 PrintF("[Snapshot loading and deserialization took %0.3f ms]\n", ms);
29 } 42 }
30 return success; 43 return success;
31 } 44 }
32 return false; 45 return false;
33 } 46 }
34 47
35 48
36 bool Snapshot::HaveASnapshotToStartFrom() { 49 bool Snapshot::HaveASnapshotToStartFrom() {
37 return size_ != 0; 50 return size_ != 0;
38 } 51 }
39 52
40 53
41 Handle<Context> Snapshot::NewContextFromSnapshot(Isolate* isolate) { 54 Handle<Context> Snapshot::NewContextFromSnapshot(Isolate* isolate) {
42 if (context_size_ == 0) return Handle<Context>(); 55 if (context_size_ == 0) {
43 56 return Handle<Context>();
44 SnapshotData snapshot_data(context_data_, context_size_); 57 }
45 Deserializer deserializer(&snapshot_data); 58 SnapshotByteSource source(context_raw_data_,
59 context_raw_size_);
60 Deserializer deserializer(&source);
46 Object* root; 61 Object* root;
62 deserializer.AddReservation(NEW_SPACE, context_new_space_used_);
63 deserializer.AddReservation(OLD_POINTER_SPACE, context_pointer_space_used_);
64 deserializer.AddReservation(OLD_DATA_SPACE, context_data_space_used_);
65 deserializer.AddReservation(CODE_SPACE, context_code_space_used_);
66 deserializer.AddReservation(MAP_SPACE, context_map_space_used_);
67 deserializer.AddReservation(CELL_SPACE, context_cell_space_used_);
68 deserializer.AddReservation(PROPERTY_CELL_SPACE,
69 context_property_cell_space_used_);
70 deserializer.AddReservation(LO_SPACE, context_lo_space_used_);
47 deserializer.DeserializePartial(isolate, &root); 71 deserializer.DeserializePartial(isolate, &root);
48 CHECK(root->IsContext()); 72 CHECK(root->IsContext());
49 return Handle<Context>(Context::cast(root)); 73 return Handle<Context>(Context::cast(root));
50 } 74 }
51 75
52 76
53 #ifdef V8_USE_EXTERNAL_STARTUP_DATA 77 #ifdef V8_USE_EXTERNAL_STARTUP_DATA
54 // Dummy implementations of Set*FromFile(..) APIs. 78 // Dummy implementations of Set*FromFile(..) APIs.
55 // 79 //
56 // These are meant for use with snapshot-external.cc. Should this file 80 // These are meant for use with snapshot-external.cc. Should this file
57 // be compiled with those options we just supply these dummy implementations 81 // be compiled with those options we just supply these dummy implementations
58 // below. This happens when compiling the mksnapshot utility. 82 // below. This happens when compiling the mksnapshot utility.
59 void SetNativesFromFile(StartupData* data) { CHECK(false); } 83 void SetNativesFromFile(StartupData* data) { CHECK(false); }
60 void SetSnapshotFromFile(StartupData* data) { CHECK(false); } 84 void SetSnapshotFromFile(StartupData* data) { CHECK(false); }
61 #endif // V8_USE_EXTERNAL_STARTUP_DATA 85 #endif // V8_USE_EXTERNAL_STARTUP_DATA
62 86
63 } } // namespace v8::internal 87 } } // namespace v8::internal
OLDNEW
« no previous file with comments | « src/snapshot.h ('k') | src/snapshot-empty.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698