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

Side by Side Diff: gin/isolate_holder.cc

Issue 2841443005: [Bindings] Create and use V8 context snapshots (Closed)
Patch Set: Work for yuki's comments Created 3 years, 6 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 unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium 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 #include "gin/public/isolate_holder.h" 5 #include "gin/public/isolate_holder.h"
6 6
7 #include <stddef.h> 7 #include <stddef.h>
8 #include <stdlib.h> 8 #include <stdlib.h>
9 #include <string.h> 9 #include <string.h>
10 10
(...skipping 17 matching lines...) Expand all
28 v8::ArrayBuffer::Allocator* g_array_buffer_allocator = nullptr; 28 v8::ArrayBuffer::Allocator* g_array_buffer_allocator = nullptr;
29 } // namespace 29 } // namespace
30 30
31 IsolateHolder::IsolateHolder( 31 IsolateHolder::IsolateHolder(
32 scoped_refptr<base::SingleThreadTaskRunner> task_runner) 32 scoped_refptr<base::SingleThreadTaskRunner> task_runner)
33 : IsolateHolder(std::move(task_runner), AccessMode::kSingleThread) {} 33 : IsolateHolder(std::move(task_runner), AccessMode::kSingleThread) {}
34 34
35 IsolateHolder::IsolateHolder( 35 IsolateHolder::IsolateHolder(
36 scoped_refptr<base::SingleThreadTaskRunner> task_runner, 36 scoped_refptr<base::SingleThreadTaskRunner> task_runner,
37 AccessMode access_mode) 37 AccessMode access_mode)
38 : IsolateHolder(std::move(task_runner), access_mode, kAllowAtomicsWait) {} 38 : IsolateHolder(std::move(task_runner),
39 access_mode,
40 kAllowAtomicsWait,
41 nullptr,
42 nullptr) {}
39 43
40 IsolateHolder::IsolateHolder( 44 IsolateHolder::IsolateHolder(
41 scoped_refptr<base::SingleThreadTaskRunner> task_runner, 45 scoped_refptr<base::SingleThreadTaskRunner> task_runner,
42 AccessMode access_mode, 46 AccessMode access_mode,
43 AllowAtomicsWaitMode atomics_wait_mode) 47 AllowAtomicsWaitMode atomics_wait_mode,
48 intptr_t* reference,
49 v8::StartupData* startup_data)
44 : access_mode_(access_mode) { 50 : access_mode_(access_mode) {
45 v8::ArrayBuffer::Allocator* allocator = g_array_buffer_allocator; 51 v8::ArrayBuffer::Allocator* allocator = g_array_buffer_allocator;
46 CHECK(allocator) << "You need to invoke gin::IsolateHolder::Initialize first"; 52 CHECK(allocator) << "You need to invoke gin::IsolateHolder::Initialize first";
53
47 v8::Isolate::CreateParams params; 54 v8::Isolate::CreateParams params;
48 params.entry_hook = DebugImpl::GetFunctionEntryHook(); 55 params.entry_hook = DebugImpl::GetFunctionEntryHook();
49 params.code_event_handler = DebugImpl::GetJitCodeEventHandler(); 56 params.code_event_handler = DebugImpl::GetJitCodeEventHandler();
50 params.constraints.ConfigureDefaults(base::SysInfo::AmountOfPhysicalMemory(), 57 params.constraints.ConfigureDefaults(base::SysInfo::AmountOfPhysicalMemory(),
51 base::SysInfo::AmountOfVirtualMemory()); 58 base::SysInfo::AmountOfVirtualMemory());
52 params.array_buffer_allocator = allocator; 59 params.array_buffer_allocator = allocator;
53 params.allow_atomics_wait = atomics_wait_mode == kAllowAtomicsWait; 60 params.allow_atomics_wait = atomics_wait_mode == kAllowAtomicsWait;
61 params.external_references = reference;
62
63 if (startup_data) {
64 CHECK(reference);
65 V8Initializer::GetBlinkV8SnapshotData(&startup_data->data,
66 &startup_data->raw_size);
67 if (startup_data->data) {
68 params.snapshot_blob = startup_data;
69 }
70 }
54 isolate_ = v8::Isolate::New(params); 71 isolate_ = v8::Isolate::New(params);
55 isolate_data_.reset( 72
56 new PerIsolateData(isolate_, allocator, access_mode, task_runner)); 73 SetUp(std::move(task_runner));
57 isolate_memory_dump_provider_.reset(new V8IsolateMemoryDumpProvider(this));
58 #if defined(OS_WIN)
59 {
60 void* code_range;
61 size_t size;
62 isolate_->GetCodeRange(&code_range, &size);
63 Debug::CodeRangeCreatedCallback callback =
64 DebugImpl::GetCodeRangeCreatedCallback();
65 if (code_range && size && callback)
66 callback(code_range, size);
67 }
68 #endif
69 } 74 }
70 75
71 IsolateHolder::IsolateHolder(intptr_t* reference_table, 76 IsolateHolder::IsolateHolder(intptr_t* reference_table,
72 v8::StartupData* existing_blob) 77 v8::StartupData* existing_blob)
73 : snapshot_creator_( 78 : snapshot_creator_(
74 new v8::SnapshotCreator(reference_table, existing_blob)), 79 new v8::SnapshotCreator(reference_table, existing_blob)),
75 access_mode_(kSingleThread) { 80 isolate_(snapshot_creator_->GetIsolate()),
76 v8::ArrayBuffer::Allocator* allocator = g_array_buffer_allocator; 81 access_mode_(AccessMode::kSingleThread) {
77 CHECK(allocator) << "You need to invoke gin::IsolateHolder::Initialize first"; 82 SetUp(nullptr);
78 isolate_ = snapshot_creator_->GetIsolate();
79 isolate_data_.reset(
80 new PerIsolateData(isolate_, allocator, access_mode_, nullptr));
81 isolate_memory_dump_provider_.reset(new V8IsolateMemoryDumpProvider(this));
82 #if defined(OS_WIN)
83 {
84 void* code_range;
85 size_t size;
86 isolate_->GetCodeRange(&code_range, &size);
87 Debug::CodeRangeCreatedCallback callback =
88 DebugImpl::GetCodeRangeCreatedCallback();
89 if (code_range && size && callback)
90 callback(code_range, size);
91 }
92 #endif
93 } 83 }
94 84
95 IsolateHolder::~IsolateHolder() { 85 IsolateHolder::~IsolateHolder() {
96 if (task_observer_.get()) 86 if (task_observer_.get())
97 base::MessageLoop::current()->RemoveTaskObserver(task_observer_.get()); 87 base::MessageLoop::current()->RemoveTaskObserver(task_observer_.get());
98 #if defined(OS_WIN) 88 #if defined(OS_WIN)
99 { 89 {
100 void* code_range; 90 void* code_range;
101 size_t size; 91 size_t size;
102 isolate_->GetCodeRange(&code_range, &size); 92 isolate_->GetCodeRange(&code_range, &size);
103 Debug::CodeRangeDeletedCallback callback = 93 Debug::CodeRangeDeletedCallback callback =
104 DebugImpl::GetCodeRangeDeletedCallback(); 94 DebugImpl::GetCodeRangeDeletedCallback();
105 if (code_range && callback) 95 if (code_range && callback)
106 callback(code_range); 96 callback(code_range);
107 } 97 }
108 #endif 98 #endif
109 isolate_memory_dump_provider_.reset(); 99 isolate_memory_dump_provider_.reset();
110 isolate_data_.reset(); 100 isolate_data_.reset();
111 isolate_->Dispose(); 101 isolate_->Dispose();
112 isolate_ = NULL; 102 isolate_ = nullptr;
113 } 103 }
114 104
115 // static 105 // static
116 void IsolateHolder::Initialize(ScriptMode mode, 106 void IsolateHolder::Initialize(ScriptMode mode,
117 V8ExtrasMode v8_extras_mode, 107 V8ExtrasMode v8_extras_mode,
118 v8::ArrayBuffer::Allocator* allocator) { 108 v8::ArrayBuffer::Allocator* allocator) {
119 CHECK(allocator); 109 CHECK(allocator);
120 V8Initializer::Initialize(mode, v8_extras_mode); 110 V8Initializer::Initialize(mode, v8_extras_mode);
121 g_array_buffer_allocator = allocator; 111 g_array_buffer_allocator = allocator;
122 } 112 }
123 113
124 void IsolateHolder::AddRunMicrotasksObserver() { 114 void IsolateHolder::AddRunMicrotasksObserver() {
125 DCHECK(!task_observer_.get()); 115 DCHECK(!task_observer_.get());
126 task_observer_.reset(new RunMicrotasksObserver(isolate_)); 116 task_observer_.reset(new RunMicrotasksObserver(isolate_));
127 base::MessageLoop::current()->AddTaskObserver(task_observer_.get()); 117 base::MessageLoop::current()->AddTaskObserver(task_observer_.get());
128 } 118 }
129 119
130 void IsolateHolder::RemoveRunMicrotasksObserver() { 120 void IsolateHolder::RemoveRunMicrotasksObserver() {
131 DCHECK(task_observer_.get()); 121 DCHECK(task_observer_.get());
132 base::MessageLoop::current()->RemoveTaskObserver(task_observer_.get()); 122 base::MessageLoop::current()->RemoveTaskObserver(task_observer_.get());
133 task_observer_.reset(); 123 task_observer_.reset();
134 } 124 }
135 125
136 void IsolateHolder::EnableIdleTasks( 126 void IsolateHolder::EnableIdleTasks(
137 std::unique_ptr<V8IdleTaskRunner> idle_task_runner) { 127 std::unique_ptr<V8IdleTaskRunner> idle_task_runner) {
138 DCHECK(isolate_data_.get()); 128 DCHECK(isolate_data_.get());
139 isolate_data_->EnableIdleTasks(std::move(idle_task_runner)); 129 isolate_data_->EnableIdleTasks(std::move(idle_task_runner));
140 } 130 }
141 131
132 void IsolateHolder::SetUp(
133 scoped_refptr<base::SingleThreadTaskRunner> task_runner) {
134 v8::ArrayBuffer::Allocator* allocator = g_array_buffer_allocator;
135 CHECK(allocator) << "You need to invoke gin::IsolateHolder::Initialize first";
136 isolate_data_.reset(
137 new PerIsolateData(isolate_, allocator, access_mode_, task_runner));
138 isolate_memory_dump_provider_.reset(new V8IsolateMemoryDumpProvider(this));
139 #if defined(OS_WIN)
140 {
141 void* code_range;
142 size_t size;
143 isolate_->GetCodeRange(&code_range, &size);
144 Debug::CodeRangeCreatedCallback callback =
145 DebugImpl::GetCodeRangeCreatedCallback();
146 if (code_range && size && callback)
147 callback(code_range, size);
148 }
149 #endif
150 }
151
142 } // namespace gin 152 } // namespace gin
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698