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 #ifndef CHROME_BROWSER_METRICS_PERF_PROVIDER_CHROMEOS_H_ | 5 #ifndef CHROME_BROWSER_METRICS_PERF_PROVIDER_CHROMEOS_H_ |
6 #define CHROME_BROWSER_METRICS_PERF_PROVIDER_CHROMEOS_H_ | 6 #define CHROME_BROWSER_METRICS_PERF_PROVIDER_CHROMEOS_H_ |
7 | 7 |
8 #include <string> | 8 #include <string> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
(...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
78 void ScheduleCollection(); | 78 void ScheduleCollection(); |
79 | 79 |
80 // Collects perf data for a given |trigger_event|. Calls perf via the ChromeOS | 80 // Collects perf data for a given |trigger_event|. Calls perf via the ChromeOS |
81 // debug daemon's dbus interface. | 81 // debug daemon's dbus interface. |
82 void CollectIfNecessary(scoped_ptr<SampledProfile> sampled_profile); | 82 void CollectIfNecessary(scoped_ptr<SampledProfile> sampled_profile); |
83 | 83 |
84 // Collects perf data on a repeating basis by calling CollectIfNecessary() and | 84 // Collects perf data on a repeating basis by calling CollectIfNecessary() and |
85 // reschedules it to be collected again. | 85 // reschedules it to be collected again. |
86 void DoPeriodicCollection(); | 86 void DoPeriodicCollection(); |
87 | 87 |
| 88 // Collects perf data after a resume. |sleep_duration| is the duration the |
| 89 // system was suspended before resuming. |time_after_resume_ms| is how long |
| 90 // ago the system resumed. |
| 91 void CollectPerfDataAfterResume(const base::TimeDelta& sleep_duration, |
| 92 const base::TimeDelta& time_after_resume); |
| 93 |
| 94 // Collects perf data after a session restore. |time_after_restore| is how |
| 95 // long ago the session restore started. |
| 96 void CollectPerfDataAfterSessionRestore( |
| 97 const base::TimeDelta& time_after_restore); |
| 98 |
88 // Parses a perf data protobuf from the |data| passed in only if the | 99 // Parses a perf data protobuf from the |data| passed in only if the |
89 // |incognito_observer| indicates that no incognito window had been opened | 100 // |incognito_observer| indicates that no incognito window had been opened |
90 // during the profile collection period. | 101 // during the profile collection period. |
91 // |trigger_event| is the cause of the perf data collection. | 102 // |trigger_event| is the cause of the perf data collection. |
92 void ParseProtoIfValid( | 103 void ParseProtoIfValid( |
93 scoped_ptr<WindowedIncognitoObserver> incognito_observer, | 104 scoped_ptr<WindowedIncognitoObserver> incognito_observer, |
94 scoped_ptr<SampledProfile> sampled_profile, | 105 scoped_ptr<SampledProfile> sampled_profile, |
95 const std::vector<uint8>& data); | 106 const std::vector<uint8>& data); |
96 | 107 |
97 // Vector of SampledProfile protobufs containing perf profiles. | 108 // Vector of SampledProfile protobufs containing perf profiles. |
98 std::vector<SampledProfile> cached_perf_data_; | 109 std::vector<SampledProfile> cached_perf_data_; |
99 | 110 |
100 // For scheduling collection of perf data. | 111 // Timers for scheduling collection of perf data. |
101 base::OneShotTimer<PerfProvider> timer_; | 112 |
| 113 // Timer for interval-based collection. |
| 114 base::OneShotTimer<PerfProvider> interval_timer_; |
| 115 // Timer for collection on resume from suspend. |
| 116 base::OneShotTimer<PerfProvider> resume_timer_; |
| 117 // Timer for collection on restore session. |
| 118 base::OneShotTimer<PerfProvider> restore_session_timer_; |
102 | 119 |
103 // For detecting when changes to the login state. | 120 // For detecting when changes to the login state. |
104 LoginObserver login_observer_; | 121 LoginObserver login_observer_; |
105 | 122 |
106 // Record of the last login time. | 123 // Record of the last login time. |
107 base::TimeTicks login_time_; | 124 base::TimeTicks login_time_; |
108 | 125 |
109 // Record of the start of the upcoming profiling interval. | 126 // Record of the start of the upcoming profiling interval. |
110 base::TimeTicks next_profiling_interval_start_; | 127 base::TimeTicks next_profiling_interval_start_; |
111 | 128 |
112 // Used to register objects of this class as observers to be notified of | 129 // Used to register objects of this class as observers to be notified of |
113 // session restore events. | 130 // session restore events. |
114 content::NotificationRegistrar session_restore_registrar_; | 131 content::NotificationRegistrar session_restore_registrar_; |
115 | 132 |
116 // Tracks the last time a session restore was collected. | 133 // Tracks the last time a session restore was collected. |
117 base::TimeTicks last_session_restore_collection_time_; | 134 base::TimeTicks last_session_restore_collection_time_; |
118 | 135 |
119 // To pass around the "this" pointer across threads safely. | 136 // To pass around the "this" pointer across threads safely. |
120 base::WeakPtrFactory<PerfProvider> weak_factory_; | 137 base::WeakPtrFactory<PerfProvider> weak_factory_; |
121 | 138 |
122 DISALLOW_COPY_AND_ASSIGN(PerfProvider); | 139 DISALLOW_COPY_AND_ASSIGN(PerfProvider); |
123 }; | 140 }; |
124 | 141 |
125 } // namespace metrics | 142 } // namespace metrics |
126 | 143 |
127 #endif // CHROME_BROWSER_METRICS_PERF_PROVIDER_CHROMEOS_H_ | 144 #endif // CHROME_BROWSER_METRICS_PERF_PROVIDER_CHROMEOS_H_ |
OLD | NEW |