| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium 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 #include "base/tracked_objects.h" | 5 #include "base/tracked_objects.h" |
| 6 | 6 |
| 7 #include <limits.h> | 7 #include <limits.h> |
| 8 #include <stdlib.h> | 8 #include <stdlib.h> |
| 9 | 9 |
| 10 #include "base/atomicops.h" | 10 #include "base/atomicops.h" |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 47 | 47 |
| 48 // Control whether an alternate time source (Now() function) is supported by | 48 // Control whether an alternate time source (Now() function) is supported by |
| 49 // the ThreadData class. This compile time flag should be set to true if we | 49 // the ThreadData class. This compile time flag should be set to true if we |
| 50 // want other modules (such as a memory allocator, or a thread-specific CPU time | 50 // want other modules (such as a memory allocator, or a thread-specific CPU time |
| 51 // clock) to be able to provide a thread-specific Now() function. Without this | 51 // clock) to be able to provide a thread-specific Now() function. Without this |
| 52 // compile-time flag, the code will only support the wall-clock time. This flag | 52 // compile-time flag, the code will only support the wall-clock time. This flag |
| 53 // can be flipped to efficiently disable this path (if there is a performance | 53 // can be flipped to efficiently disable this path (if there is a performance |
| 54 // problem with its presence). | 54 // problem with its presence). |
| 55 static const bool kAllowAlternateTimeSourceHandling = true; | 55 static const bool kAllowAlternateTimeSourceHandling = true; |
| 56 | 56 |
| 57 // Possible states of the profiler timing enabledness. |
| 58 enum { |
| 59 UNDEFINED_TIMING, |
| 60 ENABLED_TIMING, |
| 61 DISABLED_TIMING, |
| 62 }; |
| 63 |
| 64 // State of the profiler timing enabledness. |
| 65 base::subtle::Atomic32 g_profiler_timing_enabled = UNDEFINED_TIMING; |
| 66 |
| 67 // Returns whether profiler timing is enabled. The default is true, but this may |
| 68 // be overridden by a command-line flag. Some platforms may programmatically set |
| 69 // this command-line flag to the "off" value if it's not specified. |
| 70 // This in turn can be overridden by explicitly calling |
| 71 // ThreadData::EnableProfilerTiming, say, based on a field trial. |
| 57 inline bool IsProfilerTimingEnabled() { | 72 inline bool IsProfilerTimingEnabled() { |
| 58 enum { | 73 // Reading |g_profiler_timing_enabled| is done without barrier because |
| 59 UNDEFINED_TIMING, | 74 // multiple initialization is not an issue while the barrier can be relatively |
| 60 ENABLED_TIMING, | 75 // costly given that this method is sometimes called in a tight loop. |
| 61 DISABLED_TIMING, | |
| 62 }; | |
| 63 static base::subtle::Atomic32 timing_enabled = UNDEFINED_TIMING; | |
| 64 // Reading |timing_enabled| is done without barrier because multiple | |
| 65 // initialization is not an issue while the barrier can be relatively costly | |
| 66 // given that this method is sometimes called in a tight loop. | |
| 67 base::subtle::Atomic32 current_timing_enabled = | 76 base::subtle::Atomic32 current_timing_enabled = |
| 68 base::subtle::NoBarrier_Load(&timing_enabled); | 77 base::subtle::NoBarrier_Load(&g_profiler_timing_enabled); |
| 69 if (current_timing_enabled == UNDEFINED_TIMING) { | 78 if (current_timing_enabled == UNDEFINED_TIMING) { |
| 70 if (!CommandLine::InitializedForCurrentProcess()) | 79 if (!CommandLine::InitializedForCurrentProcess()) |
| 71 return true; | 80 return true; |
| 72 current_timing_enabled = | 81 current_timing_enabled = |
| 73 (CommandLine::ForCurrentProcess()->GetSwitchValueASCII( | 82 (CommandLine::ForCurrentProcess()->GetSwitchValueASCII( |
| 74 switches::kProfilerTiming) == | 83 switches::kProfilerTiming) == |
| 75 switches::kProfilerTimingDisabledValue) | 84 switches::kProfilerTimingDisabledValue) |
| 76 ? DISABLED_TIMING | 85 ? DISABLED_TIMING |
| 77 : ENABLED_TIMING; | 86 : ENABLED_TIMING; |
| 78 base::subtle::NoBarrier_Store(&timing_enabled, current_timing_enabled); | 87 base::subtle::NoBarrier_Store(&g_profiler_timing_enabled, |
| 88 current_timing_enabled); |
| 79 } | 89 } |
| 80 return current_timing_enabled == ENABLED_TIMING; | 90 return current_timing_enabled == ENABLED_TIMING; |
| 81 } | 91 } |
| 82 | 92 |
| 83 } // namespace | 93 } // namespace |
| 84 | 94 |
| 85 //------------------------------------------------------------------------------ | 95 //------------------------------------------------------------------------------ |
| 86 // DeathData tallies durations when a death takes place. | 96 // DeathData tallies durations when a death takes place. |
| 87 | 97 |
| 88 DeathData::DeathData() { | 98 DeathData::DeathData() { |
| (...skipping 679 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 768 } | 778 } |
| 769 | 779 |
| 770 // static | 780 // static |
| 771 void ThreadData::SetAlternateTimeSource(NowFunction* now_function) { | 781 void ThreadData::SetAlternateTimeSource(NowFunction* now_function) { |
| 772 DCHECK(now_function); | 782 DCHECK(now_function); |
| 773 if (kAllowAlternateTimeSourceHandling) | 783 if (kAllowAlternateTimeSourceHandling) |
| 774 now_function_ = now_function; | 784 now_function_ = now_function; |
| 775 } | 785 } |
| 776 | 786 |
| 777 // static | 787 // static |
| 788 void ThreadData::EnableProfilerTiming() { |
| 789 base::subtle::NoBarrier_Store(&g_profiler_timing_enabled, ENABLED_TIMING); |
| 790 } |
| 791 |
| 792 // static |
| 778 TrackedTime ThreadData::Now() { | 793 TrackedTime ThreadData::Now() { |
| 779 if (kAllowAlternateTimeSourceHandling && now_function_) | 794 if (kAllowAlternateTimeSourceHandling && now_function_) |
| 780 return TrackedTime::FromMilliseconds((*now_function_)()); | 795 return TrackedTime::FromMilliseconds((*now_function_)()); |
| 781 if (kTrackAllTaskObjects && IsProfilerTimingEnabled() && TrackingStatus()) | 796 if (kTrackAllTaskObjects && IsProfilerTimingEnabled() && TrackingStatus()) |
| 782 return TrackedTime::Now(); | 797 return TrackedTime::Now(); |
| 783 return TrackedTime(); // Super fast when disabled, or not compiled. | 798 return TrackedTime(); // Super fast when disabled, or not compiled. |
| 784 } | 799 } |
| 785 | 800 |
| 786 // static | 801 // static |
| 787 void ThreadData::EnsureCleanupWasCalled(int major_threads_shutdown_count) { | 802 void ThreadData::EnsureCleanupWasCalled(int major_threads_shutdown_count) { |
| (...skipping 197 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 985 : process_id(base::GetCurrentProcId()) { | 1000 : process_id(base::GetCurrentProcId()) { |
| 986 #else | 1001 #else |
| 987 : process_id(0) { | 1002 : process_id(0) { |
| 988 #endif | 1003 #endif |
| 989 } | 1004 } |
| 990 | 1005 |
| 991 ProcessDataSnapshot::~ProcessDataSnapshot() { | 1006 ProcessDataSnapshot::~ProcessDataSnapshot() { |
| 992 } | 1007 } |
| 993 | 1008 |
| 994 } // namespace tracked_objects | 1009 } // namespace tracked_objects |
| OLD | NEW |