| 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/compiler_stats.h" | 7 #include "vm/compiler_stats.h" |
| 8 #include "vm/dart_api_state.h" | 8 #include "vm/dart_api_state.h" |
| 9 #include "vm/growable_array.h" | 9 #include "vm/growable_array.h" |
| 10 #include "vm/isolate.h" | 10 #include "vm/isolate.h" |
| (...skipping 20 matching lines...) Expand all Loading... |
| 31 DECLARE_FLAG(bool, trace_service_verbose); | 31 DECLARE_FLAG(bool, trace_service_verbose); |
| 32 | 32 |
| 33 | 33 |
| 34 Thread::~Thread() { | 34 Thread::~Thread() { |
| 35 // We should cleanly exit any isolate before destruction. | 35 // We should cleanly exit any isolate before destruction. |
| 36 ASSERT(isolate_ == NULL); | 36 ASSERT(isolate_ == NULL); |
| 37 if (compiler_stats_ != NULL) { | 37 if (compiler_stats_ != NULL) { |
| 38 delete compiler_stats_; | 38 delete compiler_stats_; |
| 39 compiler_stats_ = NULL; | 39 compiler_stats_ = NULL; |
| 40 } | 40 } |
| 41 // All zone allocated memory should be free by this point. |
| 42 ASSERT(current_thread_memory_ == 0); |
| 41 // There should be no top api scopes at this point. | 43 // There should be no top api scopes at this point. |
| 42 ASSERT(api_top_scope() == NULL); | 44 ASSERT(api_top_scope() == NULL); |
| 43 // Delete the resusable api scope if there is one. | 45 // Delete the resusable api scope if there is one. |
| 44 if (api_reusable_scope_) { | 46 if (api_reusable_scope_) { |
| 45 delete api_reusable_scope_; | 47 delete api_reusable_scope_; |
| 46 api_reusable_scope_ = NULL; | 48 api_reusable_scope_ = NULL; |
| 47 } | 49 } |
| 48 delete thread_lock_; | 50 delete thread_lock_; |
| 49 thread_lock_ = NULL; | 51 thread_lock_ = NULL; |
| 50 } | 52 } |
| (...skipping 16 matching lines...) Expand all Loading... |
| 67 isolate_(NULL), | 69 isolate_(NULL), |
| 68 heap_(NULL), | 70 heap_(NULL), |
| 69 top_exit_frame_info_(0), | 71 top_exit_frame_info_(0), |
| 70 store_buffer_block_(NULL), | 72 store_buffer_block_(NULL), |
| 71 vm_tag_(0), | 73 vm_tag_(0), |
| 72 task_kind_(kUnknownTask), | 74 task_kind_(kUnknownTask), |
| 73 dart_stream_(NULL), | 75 dart_stream_(NULL), |
| 74 os_thread_(NULL), | 76 os_thread_(NULL), |
| 75 thread_lock_(new Monitor()), | 77 thread_lock_(new Monitor()), |
| 76 zone_(NULL), | 78 zone_(NULL), |
| 79 current_thread_memory_(0), |
| 80 memory_high_watermark_(0), |
| 77 api_reusable_scope_(NULL), | 81 api_reusable_scope_(NULL), |
| 78 api_top_scope_(NULL), | 82 api_top_scope_(NULL), |
| 79 top_resource_(NULL), | 83 top_resource_(NULL), |
| 80 long_jump_base_(NULL), | 84 long_jump_base_(NULL), |
| 81 no_callback_scope_depth_(0), | 85 no_callback_scope_depth_(0), |
| 82 #if defined(DEBUG) | 86 #if defined(DEBUG) |
| 83 top_handle_scope_(NULL), | 87 top_handle_scope_(NULL), |
| 84 no_handle_scope_depth_(0), | 88 no_handle_scope_depth_(0), |
| 85 no_safepoint_scope_depth_(0), | 89 no_safepoint_scope_depth_(0), |
| 86 #endif | 90 #endif |
| (...skipping 119 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 206 | 210 |
| 207 | 211 |
| 208 #ifndef PRODUCT | 212 #ifndef PRODUCT |
| 209 // Collect information about each individual zone associated with this thread. | 213 // Collect information about each individual zone associated with this thread. |
| 210 void Thread::PrintJSON(JSONStream* stream) const { | 214 void Thread::PrintJSON(JSONStream* stream) const { |
| 211 JSONObject jsobj(stream); | 215 JSONObject jsobj(stream); |
| 212 jsobj.AddProperty("type", "_Thread"); | 216 jsobj.AddProperty("type", "_Thread"); |
| 213 jsobj.AddPropertyF("id", "threads/%" Pd "", | 217 jsobj.AddPropertyF("id", "threads/%" Pd "", |
| 214 OSThread::ThreadIdToIntPtr(os_thread()->trace_id())); | 218 OSThread::ThreadIdToIntPtr(os_thread()->trace_id())); |
| 215 jsobj.AddProperty("kind", TaskKindToCString(task_kind())); | 219 jsobj.AddProperty("kind", TaskKindToCString(task_kind())); |
| 220 jsobj.AddPropertyF("_memoryHighWatermark", "%u", memory_high_watermark_); |
| 216 Zone* zone = zone_; | 221 Zone* zone = zone_; |
| 217 { | 222 { |
| 218 JSONArray zone_info_array(&jsobj, "zones"); | 223 JSONArray zone_info_array(&jsobj, "zones"); |
| 219 zone = zone_; | 224 zone = zone_; |
| 220 while (zone != NULL) { | 225 while (zone != NULL) { |
| 221 zone_info_array.AddValue(zone); | 226 zone_info_array.AddValue(zone); |
| 222 zone = zone->previous(); | 227 zone = zone->previous(); |
| 223 } | 228 } |
| 224 } | 229 } |
| 225 } | 230 } |
| (...skipping 613 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 839 | 844 |
| 840 DisableThreadInterruptsScope::~DisableThreadInterruptsScope() { | 845 DisableThreadInterruptsScope::~DisableThreadInterruptsScope() { |
| 841 if (thread() != NULL) { | 846 if (thread() != NULL) { |
| 842 OSThread* os_thread = thread()->os_thread(); | 847 OSThread* os_thread = thread()->os_thread(); |
| 843 ASSERT(os_thread != NULL); | 848 ASSERT(os_thread != NULL); |
| 844 os_thread->EnableThreadInterrupts(); | 849 os_thread->EnableThreadInterrupts(); |
| 845 } | 850 } |
| 846 } | 851 } |
| 847 | 852 |
| 848 } // namespace dart | 853 } // namespace dart |
| OLD | NEW |