OLD | NEW |
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 Loading... |
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 |
OLD | NEW |