Fix multiple V8::Dispose calls since r16563.

R=svenpanne@chromium.org
BUG=v8:2744
TEST=cctest/test-api/InitializeAndDisposeMultiple

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

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@16565 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 43780dbd
...@@ -1383,6 +1383,7 @@ class Isolate { ...@@ -1383,6 +1383,7 @@ class Isolate {
friend class v8::Isolate; friend class v8::Isolate;
friend class v8::Locker; friend class v8::Locker;
friend class v8::Unlocker; friend class v8::Unlocker;
friend class V8;
DISALLOW_COPY_AND_ASSIGN(Isolate); DISALLOW_COPY_AND_ASSIGN(Isolate);
}; };
......
...@@ -63,8 +63,8 @@ bool V8::Initialize(Deserializer* des) { ...@@ -63,8 +63,8 @@ bool V8::Initialize(Deserializer* des) {
// The current thread may not yet had entered an isolate to run. // The current thread may not yet had entered an isolate to run.
// Note the Isolate::Current() may be non-null because for various // Note the Isolate::Current() may be non-null because for various
// initialization purposes an initializing thread may be assigned an isolate // initialization purposes an initializing thread may be assigned an
// but not actually enter it. // isolate but not actually enter it.
if (i::Isolate::CurrentPerIsolateThreadData() == NULL) { if (i::Isolate::CurrentPerIsolateThreadData() == NULL) {
i::Isolate::EnterDefaultIsolate(); i::Isolate::EnterDefaultIsolate();
} }
...@@ -84,6 +84,15 @@ bool V8::Initialize(Deserializer* des) { ...@@ -84,6 +84,15 @@ bool V8::Initialize(Deserializer* des) {
void V8::TearDown() { void V8::TearDown() {
// The current thread may not yet had entered an isolate to run or may
// have already disposed the entered isolated before.
// Note the Isolate::Current() may be non-null because for various
// initialization purposes an initializing thread may be assigned an
// isolate but not actually enter it.
if (i::Isolate::CurrentPerIsolateThreadData() == NULL) {
return;
}
Isolate* isolate = Isolate::Current(); Isolate* isolate = Isolate::Current();
ASSERT(isolate->IsDefaultIsolate()); ASSERT(isolate->IsDefaultIsolate());
if (!isolate->IsInitialized()) return; if (!isolate->IsInitialized()) return;
...@@ -91,6 +100,7 @@ void V8::TearDown() { ...@@ -91,6 +100,7 @@ void V8::TearDown() {
// The isolate has to be torn down before clearing the LOperand // The isolate has to be torn down before clearing the LOperand
// caches so that the optimizing compiler thread (if running) // caches so that the optimizing compiler thread (if running)
// doesn't see an inconsistent view of the lithium instructions. // doesn't see an inconsistent view of the lithium instructions.
Isolate::SetIsolateThreadLocals(isolate, NULL);
isolate->TearDown(); isolate->TearDown();
delete isolate; delete isolate;
......
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