| OLD | NEW |
| 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
| 4 | 4 |
| 5 #include "vm/dart.h" | 5 #include "vm/dart.h" |
| 6 | 6 |
| 7 #include "vm/code_observers.h" | 7 #include "vm/code_observers.h" |
| 8 #include "vm/cpu.h" | 8 #include "vm/cpu.h" |
| 9 #include "vm/dart_api_state.h" | 9 #include "vm/dart_api_state.h" |
| 10 #include "vm/dart_entry.h" | 10 #include "vm/dart_entry.h" |
| (...skipping 128 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 139 } | 139 } |
| 140 #endif | 140 #endif |
| 141 Object::FinalizeVMIsolate(vm_isolate_); | 141 Object::FinalizeVMIsolate(vm_isolate_); |
| 142 } | 142 } |
| 143 // There is a planned and known asymmetry here: We enter one scope for the VM | 143 // There is a planned and known asymmetry here: We enter one scope for the VM |
| 144 // isolate so that we can allocate the "persistent" scoped handles for the | 144 // isolate so that we can allocate the "persistent" scoped handles for the |
| 145 // predefined API values (such as Dart_True, Dart_False and Dart_Null). | 145 // predefined API values (such as Dart_True, Dart_False and Dart_Null). |
| 146 Dart_EnterScope(); | 146 Dart_EnterScope(); |
| 147 Api::InitHandles(); | 147 Api::InitHandles(); |
| 148 | 148 |
| 149 Isolate::SetCurrent(NULL); // Unregister the VM isolate from this thread. | 149 Thread::ExitIsolate(); // Unregister the VM isolate from this thread. |
| 150 Isolate::SetCreateCallback(create); | 150 Isolate::SetCreateCallback(create); |
| 151 Isolate::SetInterruptCallback(interrupt); | 151 Isolate::SetInterruptCallback(interrupt); |
| 152 Isolate::SetUnhandledExceptionCallback(unhandled); | 152 Isolate::SetUnhandledExceptionCallback(unhandled); |
| 153 Isolate::SetShutdownCallback(shutdown); | 153 Isolate::SetShutdownCallback(shutdown); |
| 154 | 154 |
| 155 ServiceIsolate::Run(); | 155 ServiceIsolate::Run(); |
| 156 | 156 |
| 157 return NULL; | 157 return NULL; |
| 158 } | 158 } |
| 159 | 159 |
| 160 | 160 |
| 161 const char* Dart::Cleanup() { | 161 const char* Dart::Cleanup() { |
| 162 // Shutdown the service isolate before shutting down the thread pool. | 162 // Shutdown the service isolate before shutting down the thread pool. |
| 163 ServiceIsolate::Shutdown(); | 163 ServiceIsolate::Shutdown(); |
| 164 #if 0 | 164 #if 0 |
| 165 // Ideally we should shutdown the VM isolate here, but the thread pool | 165 // Ideally we should shutdown the VM isolate here, but the thread pool |
| 166 // shutdown does not seem to ensure that all the threads have stopped | 166 // shutdown does not seem to ensure that all the threads have stopped |
| 167 // execution before it terminates, this results in racing isolates. | 167 // execution before it terminates, this results in racing isolates. |
| 168 if (vm_isolate_ == NULL) { | 168 if (vm_isolate_ == NULL) { |
| 169 return "VM already terminated."; | 169 return "VM already terminated."; |
| 170 } | 170 } |
| 171 | 171 |
| 172 ASSERT(Isolate::Current() == NULL); | 172 ASSERT(Isolate::Current() == NULL); |
| 173 | 173 |
| 174 delete thread_pool_; | 174 delete thread_pool_; |
| 175 thread_pool_ = NULL; | 175 thread_pool_ = NULL; |
| 176 | 176 |
| 177 // Set the VM isolate as current isolate. | 177 // Set the VM isolate as current isolate. |
| 178 Isolate::SetCurrent(vm_isolate_); | 178 Thread::EnterIsolate(vm_isolate_); |
| 179 | 179 |
| 180 // There is a planned and known asymmetry here: We exit one scope for the VM | 180 // There is a planned and known asymmetry here: We exit one scope for the VM |
| 181 // isolate to account for the scope that was entered in Dart_InitOnce. | 181 // isolate to account for the scope that was entered in Dart_InitOnce. |
| 182 Dart_ExitScope(); | 182 Dart_ExitScope(); |
| 183 | 183 |
| 184 ShutdownIsolate(); | 184 ShutdownIsolate(); |
| 185 vm_isolate_ = NULL; | 185 vm_isolate_ = NULL; |
| 186 | 186 |
| 187 TargetCPUFeatures::Cleanup(); | 187 TargetCPUFeatures::Cleanup(); |
| 188 #endif | 188 #endif |
| (...skipping 124 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 313 return predefined_handles_->handles_.AllocateScopedHandle(); | 313 return predefined_handles_->handles_.AllocateScopedHandle(); |
| 314 } | 314 } |
| 315 | 315 |
| 316 | 316 |
| 317 bool Dart::IsReadOnlyHandle(uword address) { | 317 bool Dart::IsReadOnlyHandle(uword address) { |
| 318 ASSERT(predefined_handles_ != NULL); | 318 ASSERT(predefined_handles_ != NULL); |
| 319 return predefined_handles_->handles_.IsValidScopedHandle(address); | 319 return predefined_handles_->handles_.IsValidScopedHandle(address); |
| 320 } | 320 } |
| 321 | 321 |
| 322 } // namespace dart | 322 } // namespace dart |
| OLD | NEW |