| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef V8_COUNTERS_H_ | 5 #ifndef V8_COUNTERS_H_ |
| 6 #define V8_COUNTERS_H_ | 6 #define V8_COUNTERS_H_ |
| 7 | 7 |
| 8 #include "include/v8.h" | 8 #include "include/v8.h" |
| 9 #include "src/allocation.h" | 9 #include "src/allocation.h" |
| 10 #include "src/base/atomic-utils.h" | 10 #include "src/base/atomic-utils.h" |
| (...skipping 835 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 846 RuntimeCallTimer* current_timer() { return current_timer_.Value(); } | 846 RuntimeCallTimer* current_timer() { return current_timer_.Value(); } |
| 847 bool InUse() { return in_use_; } | 847 bool InUse() { return in_use_; } |
| 848 | 848 |
| 849 private: | 849 private: |
| 850 // Counter to track recursive time events. | 850 // Counter to track recursive time events. |
| 851 base::AtomicValue<RuntimeCallTimer*> current_timer_; | 851 base::AtomicValue<RuntimeCallTimer*> current_timer_; |
| 852 // Used to track nested tracing scopes. | 852 // Used to track nested tracing scopes. |
| 853 bool in_use_; | 853 bool in_use_; |
| 854 }; | 854 }; |
| 855 | 855 |
| 856 #define TRACE_RUNTIME_CALL_STATS(isolate, counter_name) \ | 856 #define TRACE_RUNTIME_CALL_STATS(isolate, counter_name) \ |
| 857 do { \ | 857 do { \ |
| 858 if (V8_UNLIKELY(TRACE_EVENT_RUNTIME_CALL_STATS_TRACING_ENABLED() || \ | 858 if (V8_UNLIKELY(FLAG_runtime_stats)) { \ |
| 859 FLAG_runtime_call_stats)) { \ | 859 RuntimeCallStats::CorrectCurrentCounterId( \ |
| 860 RuntimeCallStats::CorrectCurrentCounterId( \ | 860 isolate->counters()->runtime_call_stats(), \ |
| 861 isolate->counters()->runtime_call_stats(), \ | 861 &RuntimeCallStats::counter_name); \ |
| 862 &RuntimeCallStats::counter_name); \ | 862 } \ |
| 863 } \ | |
| 864 } while (false) | 863 } while (false) |
| 865 | 864 |
| 866 #define TRACE_HANDLER_STATS(isolate, counter_name) \ | 865 #define TRACE_HANDLER_STATS(isolate, counter_name) \ |
| 867 TRACE_RUNTIME_CALL_STATS(isolate, Handler_##counter_name) | 866 TRACE_RUNTIME_CALL_STATS(isolate, Handler_##counter_name) |
| 868 | 867 |
| 869 #define HISTOGRAM_RANGE_LIST(HR) \ | 868 #define HISTOGRAM_RANGE_LIST(HR) \ |
| 870 /* Generic range histograms */ \ | 869 /* Generic range histograms */ \ |
| 871 HR(detached_context_age_in_gc, V8.DetachedContextAgeInGC, 0, 20, 21) \ | 870 HR(detached_context_age_in_gc, V8.DetachedContextAgeInGC, 0, 20, 21) \ |
| 872 HR(gc_idle_time_allotted_in_ms, V8.GCIdleTimeAllottedInMS, 0, 10000, 101) \ | 871 HR(gc_idle_time_allotted_in_ms, V8.GCIdleTimeAllottedInMS, 0, 10000, 101) \ |
| 873 HR(gc_idle_time_limit_overshot, V8.GCIdleTimeLimit.Overshot, 0, 10000, 101) \ | 872 HR(gc_idle_time_limit_overshot, V8.GCIdleTimeLimit.Overshot, 0, 10000, 101) \ |
| (...skipping 430 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1304 } | 1303 } |
| 1305 | 1304 |
| 1306 Isolate* isolate_ = nullptr; | 1305 Isolate* isolate_ = nullptr; |
| 1307 RuntimeCallTimer timer_; | 1306 RuntimeCallTimer timer_; |
| 1308 }; | 1307 }; |
| 1309 | 1308 |
| 1310 } // namespace internal | 1309 } // namespace internal |
| 1311 } // namespace v8 | 1310 } // namespace v8 |
| 1312 | 1311 |
| 1313 #endif // V8_COUNTERS_H_ | 1312 #endif // V8_COUNTERS_H_ |
| OLD | NEW |