Chromium Code Reviews| 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 <stdlib.h> | 7 #include <stdlib.h> |
| 8 #include <string.h> | 8 #include <string.h> |
| 9 | 9 |
| 10 #include "base/logging.h" | 10 #include "base/logging.h" |
| 11 #ifdef V8_USE_EXTERNAL_STARTUP_DATA | |
| 12 | |
| 13 #ifdef OS_MACOSX | |
| 14 #include "base/mac/bundle_locations.h" | |
| 15 #endif | |
| 16 | |
|
rmcilroy
2014/09/23 14:05:40
nit - Generally Ifdef'ed defines are placed in a s
baixo
2014/09/23 19:30:30
Done.
| |
| 17 #include "base/path_service.h" | |
| 18 #endif // V8_USE_EXTERNAL_STARTUP_DATA | |
| 11 #include "base/rand_util.h" | 19 #include "base/rand_util.h" |
| 12 #include "base/sys_info.h" | 20 #include "base/sys_info.h" |
| 13 #include "gin/array_buffer.h" | 21 #include "gin/array_buffer.h" |
| 14 #include "gin/debug_impl.h" | 22 #include "gin/debug_impl.h" |
| 15 #include "gin/function_template.h" | 23 #include "gin/function_template.h" |
| 16 #include "gin/per_isolate_data.h" | 24 #include "gin/per_isolate_data.h" |
| 17 #include "gin/public/v8_platform.h" | 25 #include "gin/public/v8_platform.h" |
| 18 | 26 |
| 19 namespace gin { | 27 namespace gin { |
| 20 | 28 |
| 21 namespace { | 29 namespace { |
| 22 | 30 |
| 23 v8::ArrayBuffer::Allocator* g_array_buffer_allocator = NULL; | 31 v8::ArrayBuffer::Allocator* g_array_buffer_allocator = NULL; |
| 24 | 32 |
| 25 bool GenerateEntropy(unsigned char* buffer, size_t amount) { | 33 bool GenerateEntropy(unsigned char* buffer, size_t amount) { |
| 26 base::RandBytes(buffer, amount); | 34 base::RandBytes(buffer, amount); |
| 27 return true; | 35 return true; |
| 28 } | 36 } |
| 29 | 37 |
| 30 } // namespace | 38 } // namespace |
| 31 | 39 |
| 40 #ifdef V8_USE_EXTERNAL_STARTUP_DATA | |
| 41 // static | |
| 42 base::MemoryMappedFile* IsolateHolder::mapped_natives = NULL; | |
| 43 base::MemoryMappedFile* IsolateHolder::mapped_snapshot = NULL; | |
|
rmcilroy
2014/09/23 14:05:40
As mentioned, these should be globals, not static
baixo
2014/09/23 19:30:30
Done.
| |
| 44 #endif // V8_USE_EXTERNAL_STARTUP_DATA | |
| 45 | |
| 46 #if defined(V8_USE_EXTERNAL_STARTUP_DATA) && defined(OS_ANDROID) | |
| 47 //static | |
| 48 bool IsolateHolder::LoadV8SnapshotFD(int natives_fd, int snapshot_fd) { | |
| 49 if (mapped_natives && mapped_snapshot) | |
| 50 return true; | |
| 51 | |
| 52 mapped_natives = new base::MemoryMappedFile; | |
| 53 CHECK(mapped_natives); | |
| 54 if (!mapped_natives->IsValid()) { | |
| 55 if (!mapped_natives->Initialize(base::File(natives_fd))) { | |
|
rmcilroy
2014/09/23 14:05:39
create the new mapped_snapshot here rather than ab
baixo
2014/09/23 19:30:30
We need the created object to initialize the file
| |
| 56 LOG(ERROR) << "Couldn't mmap v8 natives data file"; | |
| 57 return false; | |
| 58 } | |
| 59 } | |
| 60 | |
| 61 mapped_snapshot = new base::MemoryMappedFile; | |
|
rmcilroy
2014/09/23 14:05:39
ditto
baixo
2014/09/23 19:30:30
Same as above.
| |
| 62 CHECK(mapped_snapshot); | |
| 63 if (!mapped_snapshot->IsValid()) { | |
| 64 if (!mapped_snapshot->Initialize(base::File(snapshot_fd))) { | |
| 65 LOG(ERROR) << "Couldn't mmap v8 snapshot data file"; | |
| 66 return false; | |
| 67 } | |
| 68 } | |
| 69 | |
| 70 return true; | |
| 71 } | |
| 72 #endif // V8_USE_EXTERNAL_STARTUP_DATA && OS_ANDROID | |
| 73 | |
| 74 #ifdef V8_USE_EXTERNAL_STARTUP_DATA | |
| 75 // static | |
| 76 bool IsolateHolder::LoadV8Snapshot() { | |
| 77 if (mapped_natives && mapped_snapshot) | |
| 78 return true; | |
| 79 | |
| 80 #if !defined(OS_MACOSX) | |
| 81 base::FilePath data_path; | |
| 82 PathService::Get( | |
| 83 #if defined(OS_ANDROID) | |
| 84 base::DIR_ANDROID_APP_DATA, | |
| 85 #elif defined(OS_POSIX) || defined(OS_WIN) | |
| 86 base::DIR_EXE, | |
| 87 #endif | |
| 88 &data_path); | |
| 89 #else | |
| 90 base::FilePath data_path = base::mac::FrameworkBundlePath(); | |
| 91 #endif | |
| 92 DCHECK(!data_path.empty()); | |
| 93 | |
| 94 mapped_natives = new base::MemoryMappedFile; | |
| 95 CHECK(mapped_natives); | |
| 96 if (!mapped_natives->IsValid()) { | |
| 97 base::FilePath natives_data_path = | |
| 98 data_path.AppendASCII("natives_blob.bin"); | |
| 99 if (!mapped_natives->Initialize(natives_data_path)) { | |
| 100 LOG(ERROR) << "Couldn't mmap v8 natives data file"; | |
| 101 return false; | |
| 102 } | |
| 103 } | |
|
rmcilroy
2014/09/23 14:05:39
There seems like a lot of duplication here between
baixo
2014/09/23 19:30:30
Done.
| |
| 104 | |
| 105 mapped_snapshot = new base::MemoryMappedFile; | |
| 106 CHECK(mapped_snapshot); | |
| 107 if (!mapped_snapshot->IsValid()) { | |
| 108 base::FilePath snapshot_data_path = | |
| 109 data_path.AppendASCII("snapshot_blob.bin"); | |
| 110 if (!mapped_snapshot->Initialize(snapshot_data_path)) { | |
| 111 LOG(ERROR) << "Couldn't mmap v8 snapshot data file"; | |
| 112 return false; | |
| 113 } | |
| 114 } | |
| 115 | |
| 116 return true; | |
| 117 } | |
| 118 #endif // V8_USE_EXTERNAL_STARTUP_DATA | |
| 119 | |
| 32 IsolateHolder::IsolateHolder() { | 120 IsolateHolder::IsolateHolder() { |
| 33 CHECK(g_array_buffer_allocator) | 121 CHECK(g_array_buffer_allocator) |
| 34 << "You need to invoke gin::IsolateHolder::Initialize first"; | 122 << "You need to invoke gin::IsolateHolder::Initialize first"; |
| 35 v8::Isolate::CreateParams params; | 123 v8::Isolate::CreateParams params; |
| 36 params.entry_hook = DebugImpl::GetFunctionEntryHook(); | 124 params.entry_hook = DebugImpl::GetFunctionEntryHook(); |
| 37 params.code_event_handler = DebugImpl::GetJitCodeEventHandler(); | 125 params.code_event_handler = DebugImpl::GetJitCodeEventHandler(); |
| 38 params.constraints.ConfigureDefaults(base::SysInfo::AmountOfPhysicalMemory(), | 126 params.constraints.ConfigureDefaults(base::SysInfo::AmountOfPhysicalMemory(), |
| 39 base::SysInfo::AmountOfVirtualMemory(), | 127 base::SysInfo::AmountOfVirtualMemory(), |
| 40 base::SysInfo::NumberOfProcessors()); | 128 base::SysInfo::NumberOfProcessors()); |
| 41 isolate_ = v8::Isolate::New(params); | 129 isolate_ = v8::Isolate::New(params); |
| (...skipping 13 matching lines...) Expand all Loading... | |
| 55 if (v8_is_initialized) | 143 if (v8_is_initialized) |
| 56 return; | 144 return; |
| 57 v8::V8::InitializePlatform(V8Platform::Get()); | 145 v8::V8::InitializePlatform(V8Platform::Get()); |
| 58 v8::V8::SetArrayBufferAllocator(allocator); | 146 v8::V8::SetArrayBufferAllocator(allocator); |
| 59 g_array_buffer_allocator = allocator; | 147 g_array_buffer_allocator = allocator; |
| 60 if (mode == gin::IsolateHolder::kStrictMode) { | 148 if (mode == gin::IsolateHolder::kStrictMode) { |
| 61 static const char v8_flags[] = "--use_strict"; | 149 static const char v8_flags[] = "--use_strict"; |
| 62 v8::V8::SetFlagsFromString(v8_flags, sizeof(v8_flags) - 1); | 150 v8::V8::SetFlagsFromString(v8_flags, sizeof(v8_flags) - 1); |
| 63 } | 151 } |
| 64 v8::V8::SetEntropySource(&GenerateEntropy); | 152 v8::V8::SetEntropySource(&GenerateEntropy); |
| 153 #ifdef V8_USE_EXTERNAL_STARTUP_DATA | |
| 154 v8::StartupData natives; | |
| 155 natives.data = reinterpret_cast<const char*>(mapped_natives->data()); | |
| 156 natives.raw_size = mapped_natives->length(); | |
| 157 natives.compressed_size = mapped_natives->length(); | |
| 158 v8::V8::SetNativesDataBlob(&natives); | |
| 159 | |
| 160 v8::StartupData snapshot; | |
| 161 snapshot.data = reinterpret_cast<const char*>(mapped_snapshot->data()); | |
| 162 snapshot.raw_size = mapped_snapshot->length(); | |
| 163 snapshot.compressed_size = mapped_snapshot->length(); | |
| 164 v8::V8::SetSnapshotDataBlob(&snapshot); | |
| 165 #endif // V8_USE_EXTERNAL_STARTUP_DATA | |
| 65 v8::V8::Initialize(); | 166 v8::V8::Initialize(); |
| 66 v8_is_initialized = true; | 167 v8_is_initialized = true; |
| 67 } | 168 } |
| 68 | 169 |
| 69 } // namespace gin | 170 } // namespace gin |
| OLD | NEW |