Commit 4073657e authored by binji's avatar binji Committed by Commit bot

Reland of d8 workers: make sure Shell::Quit is only called once (patchset #1...

Reland of d8 workers: make sure Shell::Quit is only called once (patchset #1 id:1 of https://codereview.chromium.org/1235083004/)

Reason for revert:
Looks like the failure is unrelated to my change (still fails after the revert). See http://build.chromium.org/p/client.v8.fyi/builders/V8-Blink%20Win/builds/856/steps/webkit_unit_tests/logs/stdio

Original issue's description:
> Revert of d8 workers: make sure Shell::Quit is only called once (patchset #5 id:80001 of https://codereview.chromium.org/1230403003/)
>
> Reason for revert:
> Breaks webkit_unit_tests. See http://build.chromium.org/p/client.v8.fyi/builders/V8-Blink%20Win/builds/853/steps/webkit_unit_tests/logs/stdio
>
> Original issue's description:
> > d8 workers: make sure Shell::Quit is only called once
> >
> > When running with isolates, Quit can be called simultaneously by two threads.
> > If this happens, then both threads try to clean up the Workers, which could
> > crash.
> >
> > BUG=v8:4279
> > R=jarin@chromium.org
> > R=machenbach@chromium.org
> > LOG=n
> >
> > Committed: https://crrev.com/76184292b392d107609f21662a949b58bb1e258c
> > Cr-Commit-Position: refs/heads/master@{#29654}
>
> TBR=jarin@chromium.org,machenbach@chromium.org
> NOPRESUBMIT=true
> NOTREECHECKS=true
> NOTRY=true
> BUG=v8:4279
>
> Committed: https://crrev.com/6b2c6eb75678747afca59b4a78ace597e218145d
> Cr-Commit-Position: refs/heads/master@{#29656}

TBR=jarin@chromium.org,machenbach@chromium.org,adamk@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=v8:4279

Review URL: https://codereview.chromium.org/1224203004

Cr-Commit-Position: refs/heads/master@{#29663}
parent 5c036cd7
...@@ -216,6 +216,7 @@ Persistent<Context> Shell::evaluation_context_; ...@@ -216,6 +216,7 @@ Persistent<Context> Shell::evaluation_context_;
ArrayBuffer::Allocator* Shell::array_buffer_allocator; ArrayBuffer::Allocator* Shell::array_buffer_allocator;
ShellOptions Shell::options; ShellOptions Shell::options;
const char* Shell::kPrompt = "d8> "; const char* Shell::kPrompt = "d8> ";
base::OnceType Shell::quit_once_ = V8_ONCE_INIT;
#ifndef V8_SHARED #ifndef V8_SHARED
bool CounterMap::Match(void* key1, void* key2) { bool CounterMap::Match(void* key1, void* key2) {
...@@ -809,16 +810,22 @@ void Shell::WorkerTerminate(const v8::FunctionCallbackInfo<v8::Value>& args) { ...@@ -809,16 +810,22 @@ void Shell::WorkerTerminate(const v8::FunctionCallbackInfo<v8::Value>& args) {
#endif // !V8_SHARED #endif // !V8_SHARED
void Shell::Quit(const v8::FunctionCallbackInfo<v8::Value>& args) { void Shell::QuitOnce(v8::FunctionCallbackInfo<v8::Value>* args) {
int exit_code = args[0]->Int32Value(); int exit_code = (*args)[0]->Int32Value();
#ifndef V8_SHARED #ifndef V8_SHARED
CleanupWorkers(); CleanupWorkers();
#endif // !V8_SHARED #endif // !V8_SHARED
OnExit(args.GetIsolate()); OnExit(args->GetIsolate());
exit(exit_code); exit(exit_code);
} }
void Shell::Quit(const v8::FunctionCallbackInfo<v8::Value>& args) {
base::CallOnce(&quit_once_, &QuitOnce,
const_cast<v8::FunctionCallbackInfo<v8::Value>*>(&args));
}
void Shell::Version(const v8::FunctionCallbackInfo<v8::Value>& args) { void Shell::Version(const v8::FunctionCallbackInfo<v8::Value>& args) {
args.GetReturnValue().Set( args.GetReturnValue().Set(
String::NewFromUtf8(args.GetIsolate(), V8::GetVersion())); String::NewFromUtf8(args.GetIsolate(), V8::GetVersion()));
......
...@@ -15,6 +15,9 @@ ...@@ -15,6 +15,9 @@
#include "src/base/compiler-specific.h" #include "src/base/compiler-specific.h"
#endif // !V8_SHARED #endif // !V8_SHARED
#include "src/base/once.h"
namespace v8 { namespace v8 {
...@@ -410,6 +413,7 @@ class Shell : public i::AllStatic { ...@@ -410,6 +413,7 @@ class Shell : public i::AllStatic {
static void Print(const v8::FunctionCallbackInfo<v8::Value>& args); static void Print(const v8::FunctionCallbackInfo<v8::Value>& args);
static void Write(const v8::FunctionCallbackInfo<v8::Value>& args); static void Write(const v8::FunctionCallbackInfo<v8::Value>& args);
static void QuitOnce(v8::FunctionCallbackInfo<v8::Value>* args);
static void Quit(const v8::FunctionCallbackInfo<v8::Value>& args); static void Quit(const v8::FunctionCallbackInfo<v8::Value>& args);
static void Version(const v8::FunctionCallbackInfo<v8::Value>& args); static void Version(const v8::FunctionCallbackInfo<v8::Value>& args);
static void Read(const v8::FunctionCallbackInfo<v8::Value>& args); static void Read(const v8::FunctionCallbackInfo<v8::Value>& args);
...@@ -467,6 +471,7 @@ class Shell : public i::AllStatic { ...@@ -467,6 +471,7 @@ class Shell : public i::AllStatic {
private: private:
static Persistent<Context> evaluation_context_; static Persistent<Context> evaluation_context_;
static base::OnceType quit_once_;
#ifndef V8_SHARED #ifndef V8_SHARED
static Persistent<Context> utility_context_; static Persistent<Context> utility_context_;
static CounterMap* counter_map_; static CounterMap* counter_map_;
......
...@@ -248,9 +248,6 @@ ...@@ -248,9 +248,6 @@
# BUG(chromium:508074). Remove this once the issue is fixed. # BUG(chromium:508074). Remove this once the issue is fixed.
'harmony/arrow-rest-params': [PASS, NO_VARIANTS], 'harmony/arrow-rest-params': [PASS, NO_VARIANTS],
'harmony/rest-params': [PASS, ['no_snap == True', NO_VARIANTS]], 'harmony/rest-params': [PASS, ['no_snap == True', NO_VARIANTS]],
# BUG(v8:4279).
'regress/regress-4279': [PASS, ['isolates', SKIP]],
}], # ALWAYS }], # ALWAYS
['novfp3 == True', { ['novfp3 == True', {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment