Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(11)

Side by Side Diff: ui/events/latency_info.h

Issue 921473003: Break down end-to-end scroll update latency UMA metrics (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: address comments Created 5 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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 #ifndef UI_EVENTS_LATENCY_INFO_H_ 5 #ifndef UI_EVENTS_LATENCY_INFO_H_
6 #define UI_EVENTS_LATENCY_INFO_H_ 6 #define UI_EVENTS_LATENCY_INFO_H_
7 7
8 #include <utility> 8 #include <utility>
9 #include <vector> 9 #include <vector>
10 10
(...skipping 17 matching lines...) Expand all
28 // The original timestamp of the touch event which converts to scroll update. 28 // The original timestamp of the touch event which converts to scroll update.
29 INPUT_EVENT_LATENCY_SCROLL_UPDATE_ORIGINAL_COMPONENT, 29 INPUT_EVENT_LATENCY_SCROLL_UPDATE_ORIGINAL_COMPONENT,
30 // The original timestamp of the touch event which converts to the *first* 30 // The original timestamp of the touch event which converts to the *first*
31 // scroll update in a scroll gesture sequence. 31 // scroll update in a scroll gesture sequence.
32 INPUT_EVENT_LATENCY_FIRST_SCROLL_UPDATE_ORIGINAL_COMPONENT, 32 INPUT_EVENT_LATENCY_FIRST_SCROLL_UPDATE_ORIGINAL_COMPONENT,
33 // Original timestamp for input event (e.g. timestamp from kernel). 33 // Original timestamp for input event (e.g. timestamp from kernel).
34 INPUT_EVENT_LATENCY_ORIGINAL_COMPONENT, 34 INPUT_EVENT_LATENCY_ORIGINAL_COMPONENT,
35 // Timestamp when the UI event is created. 35 // Timestamp when the UI event is created.
36 INPUT_EVENT_LATENCY_UI_COMPONENT, 36 INPUT_EVENT_LATENCY_UI_COMPONENT,
37 // This is special component indicating there is rendering scheduled for 37 // This is special component indicating there is rendering scheduled for
38 // the event associated with this LatencyInfo. 38 // the event associated with this LatencyInfo on main thread.
39 INPUT_EVENT_LATENCY_RENDERING_SCHEDULED_COMPONENT, 39 INPUT_EVENT_LATENCY_RENDERING_SCHEDULED_MAIN_COMPONENT,
40 // This is special component indicating there is rendering scheduled for
41 // the event associated with this LatencyInfo on impl thread.
42 INPUT_EVENT_LATENCY_RENDERING_SCHEDULED_IMPL_COMPONENT,
40 // Timestamp when a scroll update is forwarded to the main thread. 43 // Timestamp when a scroll update is forwarded to the main thread.
41 INPUT_EVENT_LATENCY_FORWARD_SCROLL_UPDATE_TO_MAIN_COMPONENT, 44 INPUT_EVENT_LATENCY_FORWARD_SCROLL_UPDATE_TO_MAIN_COMPONENT,
42 // Timestamp when the event's ack is received by the RWH. 45 // Timestamp when the event's ack is received by the RWH.
43 INPUT_EVENT_LATENCY_ACK_RWH_COMPONENT, 46 INPUT_EVENT_LATENCY_ACK_RWH_COMPONENT,
44 // Frame number when a window snapshot was requested. The snapshot 47 // Frame number when a window snapshot was requested. The snapshot
45 // is taken when the rendering results actually reach the screen. 48 // is taken when the rendering results actually reach the screen.
46 WINDOW_SNAPSHOT_FRAME_NUMBER_COMPONENT, 49 WINDOW_SNAPSHOT_FRAME_NUMBER_COMPONENT,
47 // Frame number for a snapshot requested via 50 // Frame number for a snapshot requested via
48 // gpuBenchmarking.beginWindowSnapshotPNG 51 // gpuBenchmarking.beginWindowSnapshotPNG
49 // TODO(vkuzkokov): remove when patch adding this hits Stable 52 // TODO(vkuzkokov): remove when patch adding this hits Stable
50 WINDOW_OLD_SNAPSHOT_FRAME_NUMBER_COMPONENT, 53 WINDOW_OLD_SNAPSHOT_FRAME_NUMBER_COMPONENT,
51 // Timestamp when a tab is requested to be shown. 54 // Timestamp when a tab is requested to be shown.
52 TAB_SHOW_COMPONENT, 55 TAB_SHOW_COMPONENT,
56 // Timestamp when the frame is swapped in renderer.
57 INPUT_EVENT_LATENCY_RENDERER_SWAP_COMPONENT,
53 // Timestamp of when the browser process receives a buffer swap notification 58 // Timestamp of when the browser process receives a buffer swap notification
54 // from the renderer. 59 // from the renderer.
55 INPUT_EVENT_BROWSER_RECEIVED_RENDERER_SWAP_COMPONENT, 60 INPUT_EVENT_BROWSER_RECEIVED_RENDERER_SWAP_COMPONENT,
56 // Timestamp of when the gpu service began swap buffers, unlike 61 // Timestamp of when the gpu service began swap buffers, unlike
57 // INPUT_EVENT_LATENCY_TERMINATED_FRAME_SWAP_COMPONENT which measures after. 62 // INPUT_EVENT_LATENCY_TERMINATED_FRAME_SWAP_COMPONENT which measures after.
58 INPUT_EVENT_GPU_SWAP_BUFFER_COMPONENT, 63 INPUT_EVENT_GPU_SWAP_BUFFER_COMPONENT,
59 // ---------------------------TERMINAL COMPONENT----------------------------- 64 // ---------------------------TERMINAL COMPONENT-----------------------------
60 // TERMINAL COMPONENT is when we show the latency end in chrome://tracing. 65 // TERMINAL COMPONENT is when we show the latency end in chrome://tracing.
61 // Timestamp when the mouse event is acked from renderer and it does not 66 // Timestamp when the mouse event is acked from renderer and it does not
62 // cause any rendering scheduled. 67 // cause any rendering scheduled.
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
99 104
100 struct EVENTS_BASE_EXPORT InputCoordinate { 105 struct EVENTS_BASE_EXPORT InputCoordinate {
101 InputCoordinate(); 106 InputCoordinate();
102 InputCoordinate(float x, float y); 107 InputCoordinate(float x, float y);
103 108
104 float x; 109 float x;
105 float y; 110 float y;
106 }; 111 };
107 112
108 // Empirically determined constant based on a typical scroll sequence. 113 // Empirically determined constant based on a typical scroll sequence.
109 enum { kTypicalMaxComponentsPerLatencyInfo = 9 }; 114 enum { kTypicalMaxComponentsPerLatencyInfo = 10 };
110 115
111 enum { kMaxInputCoordinates = 2 }; 116 enum { kMaxInputCoordinates = 2 };
112 117
113 // Map a Latency Component (with a component-specific int64 id) to a 118 // Map a Latency Component (with a component-specific int64 id) to a
114 // component info. 119 // component info.
115 typedef base::SmallMap< 120 typedef base::SmallMap<
116 std::map<std::pair<LatencyComponentType, int64>, LatencyComponent>, 121 std::map<std::pair<LatencyComponentType, int64>, LatencyComponent>,
117 kTypicalMaxComponentsPerLatencyInfo> LatencyMap; 122 kTypicalMaxComponentsPerLatencyInfo> LatencyMap;
118 123
119 LatencyInfo(); 124 LatencyInfo();
(...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after
172 177
173 // The unique id for matching the ASYNC_BEGIN/END trace event. 178 // The unique id for matching the ASYNC_BEGIN/END trace event.
174 int64 trace_id; 179 int64 trace_id;
175 // Whether a terminal component has been added. 180 // Whether a terminal component has been added.
176 bool terminated; 181 bool terminated;
177 }; 182 };
178 183
179 } // namespace ui 184 } // namespace ui
180 185
181 #endif // UI_EVENTS_LATENCY_INFO_H_ 186 #endif // UI_EVENTS_LATENCY_INFO_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698