From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: Samuel Attard Date: Thu, 18 Oct 2018 17:07:27 -0700 Subject: isolate_holder.patch Pass pre allocated isolate for initialization, node platform needs to register on an isolate so that it can be used later down in the initialization process of an isolate. Specifically, v8::Isolate::Initialize ends up calling NodePlatform::GetForegroundTaskRunner, which requires that the isolate has previously been registered with NodePlatform::RegisterIsolate. However, if we let gin allocate the isolate, there's no opportunity for us to register the isolate in between Isolate::Allocate and Isolate::Initialize. diff --git a/gin/isolate_holder.cc b/gin/isolate_holder.cc index 61d35042fcd0aa7b632c34253bce42a00c8d732d..db074920753e6a7aec4ffad82f8f4296f6ab854b 100644 --- a/gin/isolate_holder.cc +++ b/gin/isolate_holder.cc @@ -75,7 +75,8 @@ IsolateHolder::IsolateHolder( IsolateCreationMode isolate_creation_mode, v8::CreateHistogramCallback create_histogram_callback, v8::AddHistogramSampleCallback add_histogram_sample_callback, - scoped_refptr low_priority_task_runner) + scoped_refptr low_priority_task_runner, + v8::Isolate* isolate) : IsolateHolder(std::move(task_runner), access_mode, isolate_type, @@ -84,7 +85,8 @@ IsolateHolder::IsolateHolder( create_histogram_callback, add_histogram_sample_callback), isolate_creation_mode, - std::move(low_priority_task_runner)) {} + std::move(low_priority_task_runner), + isolate) {} IsolateHolder::IsolateHolder( scoped_refptr task_runner, @@ -92,7 +94,8 @@ IsolateHolder::IsolateHolder( IsolateType isolate_type, std::unique_ptr params, IsolateCreationMode isolate_creation_mode, - scoped_refptr low_priority_task_runner) + scoped_refptr low_priority_task_runner, + v8::Isolate* isolate) : access_mode_(access_mode), isolate_type_(isolate_type) { CHECK(Initialized()) << "You need to invoke gin::IsolateHolder::Initialize first"; @@ -103,7 +106,7 @@ IsolateHolder::IsolateHolder( v8::ArrayBuffer::Allocator* allocator = params->array_buffer_allocator; DCHECK(allocator); - isolate_ = v8::Isolate::Allocate(); + isolate_ = isolate ? isolate : v8::Isolate::Allocate(); isolate_data_ = std::make_unique( isolate_, allocator, access_mode_, task_runner, std::move(low_priority_task_runner)); diff --git a/gin/public/isolate_holder.h b/gin/public/isolate_holder.h index a5db8841773618814ac90f740201d4d7e9057b3c..1368ab8bfbf9e69437b394a8376bf7c956ca13ce 100644 --- a/gin/public/isolate_holder.h +++ b/gin/public/isolate_holder.h @@ -85,7 +85,8 @@ class GIN_EXPORT IsolateHolder { v8::CreateHistogramCallback create_histogram_callback = nullptr, v8::AddHistogramSampleCallback add_histogram_sample_callback = nullptr, scoped_refptr low_priority_task_runner = - nullptr); + nullptr, + v8::Isolate* isolate = nullptr); IsolateHolder( scoped_refptr task_runner, AccessMode access_mode, @@ -93,7 +94,8 @@ class GIN_EXPORT IsolateHolder { std::unique_ptr params, IsolateCreationMode isolate_creation_mode = IsolateCreationMode::kNormal, scoped_refptr low_priority_task_runner = - nullptr); + nullptr, + v8::Isolate* isolate = nullptr); IsolateHolder(const IsolateHolder&) = delete; IsolateHolder& operator=(const IsolateHolder&) = delete; ~IsolateHolder();