| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 72 i::Isolate::Current()); | 72 i::Isolate::Current()); |
| 73 | 73 |
| 74 Isolate* isolate = Isolate::Current(); | 74 Isolate* isolate = Isolate::Current(); |
| 75 if (isolate->IsDead()) return false; | 75 if (isolate->IsDead()) return false; |
| 76 if (isolate->IsInitialized()) return true; | 76 if (isolate->IsInitialized()) return true; |
| 77 | 77 |
| 78 return isolate->Init(des); | 78 return isolate->Init(des); |
| 79 } | 79 } |
| 80 | 80 |
| 81 | 81 |
| 82 void V8::TearDown() { | 82 bool V8::TearDown() { |
| 83 Isolate* isolate = Isolate::Current(); | 83 Isolate* isolate = Isolate::UncheckedCurrent(); |
| 84 ASSERT(isolate->IsDefaultIsolate()); | 84 if (isolate != NULL) { |
| 85 if (!isolate->IsInitialized()) return; | 85 ASSERT(isolate->IsDefaultIsolate()); |
| 86 if (isolate->IsInitialized()) isolate->TearDown(); |
| 87 delete isolate; |
| 88 } |
| 86 | 89 |
| 87 // The isolate has to be torn down before clearing the LOperand | 90 // V8 was never initialized, nothing to do. |
| 91 if (Acquire_Load(&init_once) == ONCE_STATE_UNINITIALIZED) return true; |
| 92 |
| 93 // TODO(dcarney): Everything below this should be in some sort of mutex... |
| 94 Atomic32 living_isolates = Isolate::GetLivingIsolates(); |
| 95 |
| 96 // All isolates have to be torn down before clearing the LOperand |
| 88 // caches so that the optimizing compiler thread (if running) | 97 // caches so that the optimizing compiler thread (if running) |
| 89 // doesn't see an inconsistent view of the lithium instructions. | 98 // doesn't see an inconsistent view of the lithium instructions. |
| 90 isolate->TearDown(); | 99 if (living_isolates != 0) return false; |
| 91 delete isolate; | |
| 92 | 100 |
| 93 ElementsAccessor::TearDown(); | 101 ElementsAccessor::TearDown(); |
| 94 LOperand::TearDownCaches(); | 102 LOperand::TearDownCaches(); |
| 95 ExternalReference::TearDownMathExpData(); | 103 ExternalReference::TearDownMathExpData(); |
| 96 RegisteredExtension::UnregisterAll(); | 104 RegisteredExtension::UnregisterAll(); |
| 97 Isolate::GlobalTearDown(); | 105 Isolate::GlobalTearDown(); |
| 98 | 106 |
| 99 delete call_completed_callbacks_; | 107 delete call_completed_callbacks_; |
| 100 call_completed_callbacks_ = NULL; | 108 call_completed_callbacks_ = NULL; |
| 101 | 109 |
| 102 Sampler::TearDown(); | 110 Sampler::TearDown(); |
| 111 return true; |
| 103 } | 112 } |
| 104 | 113 |
| 105 | 114 |
| 106 void V8::SetReturnAddressLocationResolver( | 115 void V8::SetReturnAddressLocationResolver( |
| 107 ReturnAddressLocationResolver resolver) { | 116 ReturnAddressLocationResolver resolver) { |
| 108 StackFrame::SetReturnAddressLocationResolver(resolver); | 117 StackFrame::SetReturnAddressLocationResolver(resolver); |
| 109 } | 118 } |
| 110 | 119 |
| 111 | 120 |
| 112 // Used by JavaScript APIs | 121 // Used by JavaScript APIs |
| (...skipping 129 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 242 ExternalReference::SetUp(); | 251 ExternalReference::SetUp(); |
| 243 Bootstrapper::InitializeOncePerProcess(); | 252 Bootstrapper::InitializeOncePerProcess(); |
| 244 } | 253 } |
| 245 | 254 |
| 246 | 255 |
| 247 void V8::InitializeOncePerProcess() { | 256 void V8::InitializeOncePerProcess() { |
| 248 CallOnce(&init_once, &InitializeOncePerProcessImpl); | 257 CallOnce(&init_once, &InitializeOncePerProcessImpl); |
| 249 } | 258 } |
| 250 | 259 |
| 251 } } // namespace v8::internal | 260 } } // namespace v8::internal |
| OLD | NEW |