OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 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 "ui/events/latency_info.h" | 5 #include "ui/events/latency_info.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include <algorithm> | 9 #include <algorithm> |
10 #include <string> | 10 #include <string> |
11 #include <utility> | 11 #include <utility> |
12 | 12 |
13 #include "base/json/json_writer.h" | 13 #include "base/json/json_writer.h" |
14 #include "base/lazy_instance.h" | 14 #include "base/lazy_instance.h" |
15 #include "base/macros.h" | 15 #include "base/macros.h" |
16 #include "base/strings/stringprintf.h" | 16 #include "base/strings/stringprintf.h" |
17 #include "base/trace_event/trace_event.h" | 17 #include "base/trace_event/trace_event.h" |
18 | 18 |
19 namespace { | 19 namespace { |
20 | 20 |
21 const size_t kMaxLatencyInfoNumber = 100; | 21 const size_t kMaxLatencyInfoNumber = 100; |
22 | 22 |
23 const char* GetComponentName(ui::LatencyComponentType type) { | |
24 #define CASE_TYPE(t) case ui::t: return #t | |
25 switch (type) { | |
26 CASE_TYPE(INPUT_EVENT_LATENCY_BEGIN_RWH_COMPONENT); | |
27 CASE_TYPE(LATENCY_BEGIN_SCROLL_LISTENER_UPDATE_MAIN_COMPONENT); | |
28 CASE_TYPE(INPUT_EVENT_LATENCY_SCROLL_UPDATE_ORIGINAL_COMPONENT); | |
29 CASE_TYPE(INPUT_EVENT_LATENCY_FIRST_SCROLL_UPDATE_ORIGINAL_COMPONENT); | |
30 CASE_TYPE(INPUT_EVENT_LATENCY_ORIGINAL_COMPONENT); | |
31 CASE_TYPE(INPUT_EVENT_LATENCY_UI_COMPONENT); | |
32 CASE_TYPE(INPUT_EVENT_LATENCY_RENDERING_SCHEDULED_MAIN_COMPONENT); | |
33 CASE_TYPE(INPUT_EVENT_LATENCY_RENDERING_SCHEDULED_IMPL_COMPONENT); | |
34 CASE_TYPE(INPUT_EVENT_LATENCY_FORWARD_SCROLL_UPDATE_TO_MAIN_COMPONENT); | |
35 CASE_TYPE(INPUT_EVENT_LATENCY_ACK_RWH_COMPONENT); | |
36 CASE_TYPE(WINDOW_SNAPSHOT_FRAME_NUMBER_COMPONENT); | |
37 CASE_TYPE(TAB_SHOW_COMPONENT); | |
38 CASE_TYPE(INPUT_EVENT_LATENCY_RENDERER_MAIN_COMPONENT); | |
39 CASE_TYPE(INPUT_EVENT_LATENCY_RENDERER_SWAP_COMPONENT); | |
40 CASE_TYPE(INPUT_EVENT_BROWSER_RECEIVED_RENDERER_SWAP_COMPONENT); | |
41 CASE_TYPE(INPUT_EVENT_GPU_SWAP_BUFFER_COMPONENT); | |
42 CASE_TYPE(INPUT_EVENT_LATENCY_GENERATE_SCROLL_UPDATE_FROM_MOUSE_WHEEL); | |
43 CASE_TYPE(INPUT_EVENT_LATENCY_TERMINATED_NO_SWAP_COMPONENT); | |
44 CASE_TYPE(INPUT_EVENT_LATENCY_TERMINATED_FRAME_SWAP_COMPONENT); | |
45 CASE_TYPE(INPUT_EVENT_LATENCY_TERMINATED_COMMIT_FAILED_COMPONENT); | |
46 CASE_TYPE(INPUT_EVENT_LATENCY_TERMINATED_COMMIT_NO_UPDATE_COMPONENT); | |
47 CASE_TYPE(INPUT_EVENT_LATENCY_TERMINATED_SWAP_FAILED_COMPONENT); | |
48 default: | |
49 DLOG(WARNING) << "Unhandled LatencyComponentType.\n"; | |
50 break; | |
51 } | |
52 #undef CASE_TYPE | |
53 return "unknown"; | |
54 } | |
55 | 23 |
56 bool IsTerminalComponent(ui::LatencyComponentType type) { | 24 bool IsTerminalComponent(ui::LatencyComponentType type) { |
57 switch (type) { | 25 switch (type) { |
58 case ui::INPUT_EVENT_LATENCY_TERMINATED_NO_SWAP_COMPONENT: | 26 case ui::INPUT_EVENT_LATENCY_TERMINATED_NO_SWAP_COMPONENT: |
59 case ui::INPUT_EVENT_LATENCY_TERMINATED_FRAME_SWAP_COMPONENT: | 27 case ui::INPUT_EVENT_LATENCY_TERMINATED_FRAME_SWAP_COMPONENT: |
60 case ui::INPUT_EVENT_LATENCY_TERMINATED_COMMIT_FAILED_COMPONENT: | 28 case ui::INPUT_EVENT_LATENCY_TERMINATED_COMMIT_FAILED_COMPONENT: |
61 case ui::INPUT_EVENT_LATENCY_TERMINATED_COMMIT_NO_UPDATE_COMPONENT: | 29 case ui::INPUT_EVENT_LATENCY_TERMINATED_COMMIT_NO_UPDATE_COMPONENT: |
62 case ui::INPUT_EVENT_LATENCY_TERMINATED_SWAP_FAILED_COMPONENT: | 30 case ui::INPUT_EVENT_LATENCY_TERMINATED_SWAP_FAILED_COMPONENT: |
63 return true; | 31 return true; |
64 default: | 32 default: |
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
123 const unsigned char* latency_info_enabled; | 91 const unsigned char* latency_info_enabled; |
124 }; | 92 }; |
125 | 93 |
126 static base::LazyInstance<LatencyInfoEnabledInitializer>::Leaky | 94 static base::LazyInstance<LatencyInfoEnabledInitializer>::Leaky |
127 g_latency_info_enabled = LAZY_INSTANCE_INITIALIZER; | 95 g_latency_info_enabled = LAZY_INSTANCE_INITIALIZER; |
128 | 96 |
129 } // namespace | 97 } // namespace |
130 | 98 |
131 namespace ui { | 99 namespace ui { |
132 | 100 |
| 101 const char* GetComponentName(ui::LatencyComponentType type) { |
| 102 #define CASE_TYPE(t) case ui::t: return #t |
| 103 switch (type) { |
| 104 CASE_TYPE(INPUT_EVENT_LATENCY_BEGIN_RWH_COMPONENT); |
| 105 CASE_TYPE(LATENCY_BEGIN_SCROLL_LISTENER_UPDATE_MAIN_COMPONENT); |
| 106 CASE_TYPE(INPUT_EVENT_LATENCY_SCROLL_UPDATE_ORIGINAL_COMPONENT); |
| 107 CASE_TYPE(INPUT_EVENT_LATENCY_FIRST_SCROLL_UPDATE_ORIGINAL_COMPONENT); |
| 108 CASE_TYPE(INPUT_EVENT_LATENCY_ORIGINAL_COMPONENT); |
| 109 CASE_TYPE(INPUT_EVENT_LATENCY_UI_COMPONENT); |
| 110 CASE_TYPE(INPUT_EVENT_LATENCY_RENDERING_SCHEDULED_MAIN_COMPONENT); |
| 111 CASE_TYPE(INPUT_EVENT_LATENCY_RENDERING_SCHEDULED_IMPL_COMPONENT); |
| 112 CASE_TYPE(INPUT_EVENT_LATENCY_FORWARD_SCROLL_UPDATE_TO_MAIN_COMPONENT); |
| 113 CASE_TYPE(INPUT_EVENT_LATENCY_ACK_RWH_COMPONENT); |
| 114 CASE_TYPE(WINDOW_SNAPSHOT_FRAME_NUMBER_COMPONENT); |
| 115 CASE_TYPE(TAB_SHOW_COMPONENT); |
| 116 CASE_TYPE(INPUT_EVENT_LATENCY_RENDERER_MAIN_COMPONENT); |
| 117 CASE_TYPE(INPUT_EVENT_LATENCY_RENDERER_SWAP_COMPONENT); |
| 118 CASE_TYPE(INPUT_EVENT_BROWSER_RECEIVED_RENDERER_SWAP_COMPONENT); |
| 119 CASE_TYPE(INPUT_EVENT_GPU_SWAP_BUFFER_COMPONENT); |
| 120 CASE_TYPE(INPUT_EVENT_LATENCY_GENERATE_SCROLL_UPDATE_FROM_MOUSE_WHEEL); |
| 121 CASE_TYPE(INPUT_EVENT_LATENCY_TERMINATED_NO_SWAP_COMPONENT); |
| 122 CASE_TYPE(INPUT_EVENT_LATENCY_TERMINATED_FRAME_SWAP_COMPONENT); |
| 123 CASE_TYPE(INPUT_EVENT_LATENCY_TERMINATED_COMMIT_FAILED_COMPONENT); |
| 124 CASE_TYPE(INPUT_EVENT_LATENCY_TERMINATED_COMMIT_NO_UPDATE_COMPONENT); |
| 125 CASE_TYPE(INPUT_EVENT_LATENCY_TERMINATED_SWAP_FAILED_COMPONENT); |
| 126 default: |
| 127 DLOG(WARNING) << "Unhandled LatencyComponentType.\n"; |
| 128 break; |
| 129 } |
| 130 #undef CASE_TYPE |
| 131 return "unknown"; |
| 132 } |
| 133 |
133 LatencyInfo::LatencyInfo() : LatencyInfo(SourceEventType::UNKNOWN) {} | 134 LatencyInfo::LatencyInfo() : LatencyInfo(SourceEventType::UNKNOWN) {} |
134 | 135 |
135 LatencyInfo::LatencyInfo(SourceEventType type) | 136 LatencyInfo::LatencyInfo(SourceEventType type) |
136 : input_coordinates_size_(0), | 137 : input_coordinates_size_(0), |
137 trace_id_(-1), | 138 trace_id_(-1), |
138 coalesced_(false), | 139 coalesced_(false), |
139 terminated_(false), | 140 terminated_(false), |
140 source_event_type_(type) {} | 141 source_event_type_(type) {} |
141 | 142 |
142 LatencyInfo::LatencyInfo(const LatencyInfo& other) = default; | 143 LatencyInfo::LatencyInfo(const LatencyInfo& other) = default; |
(...skipping 205 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
348 LatencyComponent* output) const { | 349 LatencyComponent* output) const { |
349 LatencyMap::const_iterator it = latency_components_.find( | 350 LatencyMap::const_iterator it = latency_components_.find( |
350 std::make_pair(type, id)); | 351 std::make_pair(type, id)); |
351 if (it == latency_components_.end()) | 352 if (it == latency_components_.end()) |
352 return false; | 353 return false; |
353 if (output) | 354 if (output) |
354 *output = it->second; | 355 *output = it->second; |
355 return true; | 356 return true; |
356 } | 357 } |
357 | 358 |
| 359 bool LatencyInfo::FindLatency(LatencyComponentType type, |
| 360 LatencyComponent* output) const { |
| 361 LatencyMap::const_iterator it = latency_components_.begin(); |
| 362 while (it != latency_components_.end()) { |
| 363 if (it->first.first == type) { |
| 364 if (output) |
| 365 *output = it->second; |
| 366 return true; |
| 367 } |
| 368 it++; |
| 369 } |
| 370 return false; |
| 371 } |
| 372 |
358 void LatencyInfo::RemoveLatency(LatencyComponentType type) { | 373 void LatencyInfo::RemoveLatency(LatencyComponentType type) { |
359 LatencyMap::iterator it = latency_components_.begin(); | 374 LatencyMap::iterator it = latency_components_.begin(); |
360 while (it != latency_components_.end()) { | 375 while (it != latency_components_.end()) { |
361 if (it->first.first == type) | 376 if (it->first.first == type) |
362 it = latency_components_.erase(it); | 377 it = latency_components_.erase(it); |
363 else | 378 else |
364 it++; | 379 it++; |
365 } | 380 } |
366 } | 381 } |
367 | 382 |
368 bool LatencyInfo::AddInputCoordinate(const gfx::PointF& input_coordinate) { | 383 bool LatencyInfo::AddInputCoordinate(const gfx::PointF& input_coordinate) { |
369 if (input_coordinates_size_ >= kMaxInputCoordinates) | 384 if (input_coordinates_size_ >= kMaxInputCoordinates) |
370 return false; | 385 return false; |
371 input_coordinates_[input_coordinates_size_++] = input_coordinate; | 386 input_coordinates_[input_coordinates_size_++] = input_coordinate; |
372 return true; | 387 return true; |
373 } | 388 } |
374 | 389 |
375 } // namespace ui | 390 } // namespace ui |
OLD | NEW |