Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2015, 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/thread.h" | 5 #include "vm/thread.h" |
| 6 | 6 |
| 7 #include "vm/dart_api_state.h" | 7 #include "vm/dart_api_state.h" |
| 8 #include "vm/growable_array.h" | 8 #include "vm/growable_array.h" |
| 9 #include "vm/isolate.h" | 9 #include "vm/isolate.h" |
| 10 #include "vm/lockers.h" | 10 #include "vm/lockers.h" |
| (...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 55 #if defined(DEBUG) | 55 #if defined(DEBUG) |
| 56 top_handle_scope_(NULL), | 56 top_handle_scope_(NULL), |
| 57 no_handle_scope_depth_(0), | 57 no_handle_scope_depth_(0), |
| 58 no_safepoint_scope_depth_(0), | 58 no_safepoint_scope_depth_(0), |
| 59 #endif | 59 #endif |
| 60 reusable_handles_(), | 60 reusable_handles_(), |
| 61 cha_(NULL), | 61 cha_(NULL), |
| 62 deopt_id_(0), | 62 deopt_id_(0), |
| 63 vm_tag_(0), | 63 vm_tag_(0), |
| 64 pending_functions_(GrowableObjectArray::null()), | 64 pending_functions_(GrowableObjectArray::null()), |
| 65 sticky_error_(Error::null()), | |
| 65 REUSABLE_HANDLE_LIST(REUSABLE_HANDLE_INITIALIZERS) | 66 REUSABLE_HANDLE_LIST(REUSABLE_HANDLE_INITIALIZERS) |
| 66 REUSABLE_HANDLE_LIST(REUSABLE_HANDLE_SCOPE_INIT) | 67 REUSABLE_HANDLE_LIST(REUSABLE_HANDLE_SCOPE_INIT) |
| 67 safepoint_state_(0), | 68 safepoint_state_(0), |
| 68 execution_state_(kThreadInVM), | 69 execution_state_(kThreadInVM), |
| 69 next_(NULL) { | 70 next_(NULL) { |
| 70 #define DEFAULT_INIT(type_name, member_name, init_expr, default_init_value) \ | 71 #define DEFAULT_INIT(type_name, member_name, init_expr, default_init_value) \ |
| 71 member_name = default_init_value; | 72 member_name = default_init_value; |
| 72 CACHED_CONSTANTS_LIST(DEFAULT_INIT) | 73 CACHED_CONSTANTS_LIST(DEFAULT_INIT) |
| 73 #undef DEFAULT_INIT | 74 #undef DEFAULT_INIT |
| 74 | 75 |
| (...skipping 93 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 168 | 169 |
| 169 | 170 |
| 170 RawGrowableObjectArray* Thread::pending_functions() { | 171 RawGrowableObjectArray* Thread::pending_functions() { |
| 171 if (pending_functions_ == GrowableObjectArray::null()) { | 172 if (pending_functions_ == GrowableObjectArray::null()) { |
| 172 pending_functions_ = GrowableObjectArray::New(Heap::kOld); | 173 pending_functions_ = GrowableObjectArray::New(Heap::kOld); |
| 173 } | 174 } |
| 174 return pending_functions_; | 175 return pending_functions_; |
| 175 } | 176 } |
| 176 | 177 |
| 177 | 178 |
| 179 void Thread::clear_pending_functions() { | |
| 180 pending_functions_ = GrowableObjectArray::null(); | |
| 181 } | |
| 182 | |
| 183 | |
| 184 RawError* Thread::sticky_error() const { | |
| 185 return sticky_error_; | |
| 186 } | |
| 187 | |
| 188 | |
| 189 void Thread::set_sticky_error(const Error& value) { | |
| 190 // TODO(asiva): Move sticky_error_ into thread specific area. | |
| 191 // ASSERT(Thread::Current()->IsMutatorThread()); | |
|
siva
2016/02/05 22:46:36
This TODO and ASSERT can be removed now.
srdjan
2016/02/05 23:34:33
Done.
| |
| 192 ASSERT(!value.IsNull()); | |
| 193 sticky_error_ = value.raw(); | |
| 194 } | |
| 195 | |
| 196 | |
| 197 void Thread::clear_sticky_error() { | |
| 198 sticky_error_ = Error::null(); | |
| 199 } | |
| 200 | |
| 201 | |
| 178 bool Thread::EnterIsolate(Isolate* isolate) { | 202 bool Thread::EnterIsolate(Isolate* isolate) { |
| 179 const bool kIsMutatorThread = true; | 203 const bool kIsMutatorThread = true; |
| 180 Thread* thread = isolate->ScheduleThread(kIsMutatorThread); | 204 Thread* thread = isolate->ScheduleThread(kIsMutatorThread); |
| 181 if (thread != NULL) { | 205 if (thread != NULL) { |
| 182 ASSERT(thread->store_buffer_block_ == NULL); | 206 ASSERT(thread->store_buffer_block_ == NULL); |
| 183 thread->StoreBufferAcquire(); | 207 thread->StoreBufferAcquire(); |
| 184 return true; | 208 return true; |
| 185 } | 209 } |
| 186 return false; | 210 return false; |
| 187 } | 211 } |
| (...skipping 143 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 331 | 355 |
| 332 // Visit objects in thread specific handles area. | 356 // Visit objects in thread specific handles area. |
| 333 reusable_handles_.VisitObjectPointers(visitor); | 357 reusable_handles_.VisitObjectPointers(visitor); |
| 334 | 358 |
| 335 // Visit the pending functions. | 359 // Visit the pending functions. |
| 336 if (pending_functions_ != GrowableObjectArray::null()) { | 360 if (pending_functions_ != GrowableObjectArray::null()) { |
| 337 visitor->VisitPointer( | 361 visitor->VisitPointer( |
| 338 reinterpret_cast<RawObject**>(&pending_functions_)); | 362 reinterpret_cast<RawObject**>(&pending_functions_)); |
| 339 } | 363 } |
| 340 | 364 |
| 365 if (sticky_error_ != Error::null()) { | |
| 366 visitor->VisitPointer( | |
| 367 reinterpret_cast<RawObject**>(&sticky_error_)); | |
| 368 } | |
|
siva
2016/02/05 22:46:36
Why do we have these checks for NULL the visitor s
srdjan
2016/02/05 23:34:33
Do not remember why that was done. Removed both ch
| |
| 369 | |
| 341 // Visit the api local scope as it has all the api local handles. | 370 // Visit the api local scope as it has all the api local handles. |
| 342 ApiLocalScope* scope = api_top_scope_; | 371 ApiLocalScope* scope = api_top_scope_; |
| 343 while (scope != NULL) { | 372 while (scope != NULL) { |
| 344 scope->local_handles()->VisitObjectPointers(visitor); | 373 scope->local_handles()->VisitObjectPointers(visitor); |
| 345 scope = scope->previous(); | 374 scope = scope->previous(); |
| 346 } | 375 } |
| 347 } | 376 } |
| 348 | 377 |
| 349 | 378 |
| 350 bool Thread::CanLoadFromThread(const Object& object) { | 379 bool Thread::CanLoadFromThread(const Object& object) { |
| (...skipping 123 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 474 | 503 |
| 475 DisableThreadInterruptsScope::~DisableThreadInterruptsScope() { | 504 DisableThreadInterruptsScope::~DisableThreadInterruptsScope() { |
| 476 if (thread() != NULL) { | 505 if (thread() != NULL) { |
| 477 OSThread* os_thread = thread()->os_thread(); | 506 OSThread* os_thread = thread()->os_thread(); |
| 478 ASSERT(os_thread != NULL); | 507 ASSERT(os_thread != NULL); |
| 479 os_thread->EnableThreadInterrupts(); | 508 os_thread->EnableThreadInterrupts(); |
| 480 } | 509 } |
| 481 } | 510 } |
| 482 | 511 |
| 483 } // namespace dart | 512 } // namespace dart |
| OLD | NEW |