OLD | NEW |
---|---|
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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 "chrome/browser/metrics/chrome_browser_main_extra_parts_metrics.h" | 5 #include "chrome/browser/metrics/chrome_browser_main_extra_parts_metrics.h" |
6 | 6 |
7 #include <string> | 7 #include <string> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
11 #include "base/cpu.h" | 11 #include "base/cpu.h" |
12 #include "base/metrics/histogram.h" | 12 #include "base/metrics/histogram.h" |
13 #include "base/metrics/sparse_histogram.h" | 13 #include "base/metrics/sparse_histogram.h" |
14 #include "base/sys_info.h" | 14 #include "base/sys_info.h" |
15 #include "base/threading/sequenced_worker_pool.h" | 15 #include "base/threading/sequenced_worker_pool.h" |
16 #include "base/time/time.h" | 16 #include "base/time/time.h" |
17 #include "chrome/browser/about_flags.h" | 17 #include "chrome/browser/about_flags.h" |
18 #include "chrome/browser/browser_process.h" | 18 #include "chrome/browser/browser_process.h" |
19 #include "chrome/browser/chrome_browser_main.h" | 19 #include "chrome/browser/chrome_browser_main.h" |
20 #include "chrome/browser/mac/bluetooth_utility.h" | 20 #include "chrome/browser/mac/bluetooth_utility.h" |
21 #include "chrome/browser/pref_service_flags_storage.h" | 21 #include "chrome/browser/pref_service_flags_storage.h" |
22 #include "chrome/browser/shell_integration.h" | 22 #include "chrome/browser/shell_integration.h" |
23 #include "content/public/browser/browser_thread.h" | 23 #include "content/public/browser/browser_thread.h" |
24 #include "ui/base/touch/touch_device.h" | 24 #include "ui/base/touch/touch_device.h" |
25 #include "ui/base/ui_base_switches.h" | 25 #include "ui/base/ui_base_switches.h" |
26 #include "ui/events/devices/device_data_manager.h" | |
26 #include "ui/events/event_switches.h" | 27 #include "ui/events/event_switches.h" |
27 #include "ui/gfx/screen.h" | 28 #include "ui/gfx/screen.h" |
28 | 29 |
29 #if defined(OS_ANDROID) && defined(__arm__) | 30 #if defined(OS_ANDROID) && defined(__arm__) |
30 #include <cpu-features.h> | 31 #include <cpu-features.h> |
31 #endif // defined(OS_ANDROID) && defined(__arm__) | 32 #endif // defined(OS_ANDROID) && defined(__arm__) |
32 | 33 |
33 #if defined(OS_LINUX) && !defined(OS_CHROMEOS) | 34 #if defined(OS_LINUX) && !defined(OS_CHROMEOS) |
34 #include <gnu/libc-version.h> | 35 #include <gnu/libc-version.h> |
35 | 36 |
(...skipping 193 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
229 state = UMA_TOUCH_EVENTS_ENABLED; | 230 state = UMA_TOUCH_EVENTS_ENABLED; |
230 } else if (touch_enabled_switch == switches::kTouchEventsAuto) { | 231 } else if (touch_enabled_switch == switches::kTouchEventsAuto) { |
231 state = ui::IsTouchDevicePresent() ? | 232 state = ui::IsTouchDevicePresent() ? |
232 UMA_TOUCH_EVENTS_AUTO_ENABLED : UMA_TOUCH_EVENTS_AUTO_DISABLED; | 233 UMA_TOUCH_EVENTS_AUTO_ENABLED : UMA_TOUCH_EVENTS_AUTO_DISABLED; |
233 } else if (touch_enabled_switch == switches::kTouchEventsDisabled) { | 234 } else if (touch_enabled_switch == switches::kTouchEventsDisabled) { |
234 state = UMA_TOUCH_EVENTS_DISABLED; | 235 state = UMA_TOUCH_EVENTS_DISABLED; |
235 } else { | 236 } else { |
236 NOTREACHED(); | 237 NOTREACHED(); |
237 return; | 238 return; |
238 } | 239 } |
239 | |
240 UMA_HISTOGRAM_ENUMERATION("Touchscreen.TouchEventsEnabled", state, | 240 UMA_HISTOGRAM_ENUMERATION("Touchscreen.TouchEventsEnabled", state, |
241 UMA_TOUCH_EVENTS_STATE_COUNT); | 241 UMA_TOUCH_EVENTS_STATE_COUNT); |
242 } | 242 } |
243 | 243 |
244 } // namespace | 244 } // namespace |
245 | 245 |
246 ChromeBrowserMainExtraPartsMetrics::ChromeBrowserMainExtraPartsMetrics() | 246 ChromeBrowserMainExtraPartsMetrics::ChromeBrowserMainExtraPartsMetrics() |
247 : display_count_(0), is_screen_observer_(false) { | 247 : display_count_(0), is_screen_observer_(false) { |
248 } | 248 } |
249 | 249 |
250 ChromeBrowserMainExtraPartsMetrics::~ChromeBrowserMainExtraPartsMetrics() { | 250 ChromeBrowserMainExtraPartsMetrics::~ChromeBrowserMainExtraPartsMetrics() { |
251 if (is_screen_observer_) | 251 if (is_screen_observer_) |
252 gfx::Screen::GetNativeScreen()->RemoveObserver(this); | 252 gfx::Screen::GetNativeScreen()->RemoveObserver(this); |
253 #if defined(USE_OZONE) || defined(USE_X11) | |
254 ui::DeviceDataManager::GetInstance()->RemoveObserver(this); | |
255 #endif // defined(USE_OZONE) || defined(USE_X11) | |
253 } | 256 } |
254 | 257 |
255 void ChromeBrowserMainExtraPartsMetrics::PreProfileInit() { | 258 void ChromeBrowserMainExtraPartsMetrics::PreProfileInit() { |
256 RecordMicroArchitectureStats(); | 259 RecordMicroArchitectureStats(); |
257 } | 260 } |
258 | 261 |
259 void ChromeBrowserMainExtraPartsMetrics::PreBrowserStart() { | 262 void ChromeBrowserMainExtraPartsMetrics::PreBrowserStart() { |
260 about_flags::PrefServiceFlagsStorage flags_storage_( | 263 about_flags::PrefServiceFlagsStorage flags_storage_( |
261 g_browser_process->local_state()); | 264 g_browser_process->local_state()); |
262 about_flags::RecordUMAStatistics(&flags_storage_); | 265 about_flags::RecordUMAStatistics(&flags_storage_); |
263 } | 266 } |
264 | 267 |
265 void ChromeBrowserMainExtraPartsMetrics::PostBrowserStart() { | 268 void ChromeBrowserMainExtraPartsMetrics::PostBrowserStart() { |
266 RecordLinuxGlibcVersion(); | 269 RecordLinuxGlibcVersion(); |
267 #if defined(USE_X11) && !defined(OS_CHROMEOS) | 270 #if defined(USE_X11) && !defined(OS_CHROMEOS) |
268 UMA_HISTOGRAM_ENUMERATION("Linux.WindowManager", | 271 UMA_HISTOGRAM_ENUMERATION("Linux.WindowManager", |
269 GetLinuxWindowManager(), | 272 GetLinuxWindowManager(), |
270 UMA_LINUX_WINDOW_MANAGER_COUNT); | 273 UMA_LINUX_WINDOW_MANAGER_COUNT); |
271 #endif | 274 #endif |
275 | |
276 #if defined(USE_OZONE) || defined(USE_X11) | |
Rick Byers
2015/06/16 14:45:47
Rather than use an #if, couldn't we encapsulate th
bruthig
2015/06/16 15:52:45
Agreed I'm not happy about the 'potential' race co
spang
2015/06/16 15:55:40
A race free way to do it is
if (ui::DeviceDataM
| |
277 // The touch event state for X11 and Ozone based event sub-systems are based | |
278 // on device scans that happen asynchronously so we attach an observer to | |
279 // wait until these scans complete. | |
280 ui::DeviceDataManager::GetInstance()->AddObserver(this); | |
281 #else | |
272 RecordTouchEventState(); | 282 RecordTouchEventState(); |
283 #endif // defined(USE_OZONE) || defined(USE_X11) | |
273 | 284 |
274 #if defined(OS_MACOSX) && !defined(OS_IOS) | 285 #if defined(OS_MACOSX) && !defined(OS_IOS) |
275 RecordMacMetrics(); | 286 RecordMacMetrics(); |
276 #endif // defined(OS_MACOSX) && !defined(OS_IOS) | 287 #endif // defined(OS_MACOSX) && !defined(OS_IOS) |
277 | 288 |
278 const int kStartupMetricsGatheringDelaySeconds = 45; | 289 const int kStartupMetricsGatheringDelaySeconds = 45; |
279 content::BrowserThread::GetBlockingPool()->PostDelayedTask( | 290 content::BrowserThread::GetBlockingPool()->PostDelayedTask( |
280 FROM_HERE, | 291 FROM_HERE, |
281 base::Bind(&RecordStartupMetricsOnBlockingPool), | 292 base::Bind(&RecordStartupMetricsOnBlockingPool), |
282 base::TimeDelta::FromSeconds(kStartupMetricsGatheringDelaySeconds)); | 293 base::TimeDelta::FromSeconds(kStartupMetricsGatheringDelaySeconds)); |
(...skipping 21 matching lines...) Expand all Loading... | |
304 | 315 |
305 void ChromeBrowserMainExtraPartsMetrics::OnDisplayMetricsChanged( | 316 void ChromeBrowserMainExtraPartsMetrics::OnDisplayMetricsChanged( |
306 const gfx::Display& display, | 317 const gfx::Display& display, |
307 uint32_t changed_metrics) { | 318 uint32_t changed_metrics) { |
308 } | 319 } |
309 | 320 |
310 void ChromeBrowserMainExtraPartsMetrics::ProfilerFinishedCollectingMetrics() { | 321 void ChromeBrowserMainExtraPartsMetrics::ProfilerFinishedCollectingMetrics() { |
311 first_web_contents_profiler_.reset(); | 322 first_web_contents_profiler_.reset(); |
312 } | 323 } |
313 | 324 |
325 void ChromeBrowserMainExtraPartsMetrics::OnDeviceListsComplete() { | |
326 ui::DeviceDataManager::GetInstance()->RemoveObserver(this); | |
327 RecordTouchEventState(); | |
328 } | |
329 | |
314 void ChromeBrowserMainExtraPartsMetrics::EmitDisplaysChangedMetric() { | 330 void ChromeBrowserMainExtraPartsMetrics::EmitDisplaysChangedMetric() { |
315 int display_count = gfx::Screen::GetNativeScreen()->GetNumDisplays(); | 331 int display_count = gfx::Screen::GetNativeScreen()->GetNumDisplays(); |
316 if (display_count != display_count_) { | 332 if (display_count != display_count_) { |
317 display_count_ = display_count; | 333 display_count_ = display_count; |
318 UMA_HISTOGRAM_COUNTS_100("Hardware.Display.Count.OnChange", display_count_); | 334 UMA_HISTOGRAM_COUNTS_100("Hardware.Display.Count.OnChange", display_count_); |
319 } | 335 } |
320 } | 336 } |
321 | 337 |
322 namespace chrome { | 338 namespace chrome { |
323 | 339 |
324 void AddMetricsExtraParts(ChromeBrowserMainParts* main_parts) { | 340 void AddMetricsExtraParts(ChromeBrowserMainParts* main_parts) { |
325 main_parts->AddParts(new ChromeBrowserMainExtraPartsMetrics()); | 341 main_parts->AddParts(new ChromeBrowserMainExtraPartsMetrics()); |
326 } | 342 } |
327 | 343 |
328 } // namespace chrome | 344 } // namespace chrome |
OLD | NEW |