1 // Copyright (C) 2018 The Android Open Source Project
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 // http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
14
15 #include <benchmark/benchmark.h>
16
17 #include <optional>
18
19 #include "perfetto/base/flat_set.h"
20 #include "perfetto/ext/base/utils.h"
21 #include "perfetto/protozero/root_message.h"
22 #include "perfetto/protozero/scattered_stream_null_delegate.h"
23 #include "perfetto/protozero/scattered_stream_writer.h"
24 #include "src/traced/probes/ftrace/cpu_reader.h"
25 #include "src/traced/probes/ftrace/ftrace_config_muxer.h"
26 #include "src/traced/probes/ftrace/ftrace_print_filter.h"
27 #include "src/traced/probes/ftrace/proto_translation_table.h"
28 #include "src/traced/probes/ftrace/test/cpu_reader_support.h"
29 #include "src/tracing/core/null_trace_writer.h"
30
31 #include "protos/perfetto/trace/ftrace/ftrace_event_bundle.pbzero.h"
32 #include "protos/perfetto/trace/ftrace/ftrace_stats.pbzero.h"
33
34 namespace perfetto {
35 namespace {
36
37 using ::perfetto::protos::pbzero::FtraceEventBundle;
38 using ::protozero::ScatteredStreamWriter;
39 using ::protozero::ScatteredStreamWriterNullDelegate;
40
41 // A page full of "sched/sched_switch" events.
42 ExamplePage g_full_page_sched_switch{
43 "synthetic",
44 R"(
45 00000000: 31f2 7622 1a00 0000 b40f 0000 0000 0000 1.v"............
46 00000010: 1e00 0000 0000 0000 1000 0000 2f00 0103 ............/...
47 00000020: 140d 0000 4a69 7420 7468 7265 6164 2070 ....Jit thread p
48 00000030: 6f6f 6c00 140d 0000 8100 0000 0008 0000 ool.............
49 00000040: 0000 0000 4576 656e 7454 6872 6561 6400 ....EventThread.
50 00000050: 6572 0000 7002 0000 6100 0000 f057 0e00 er..p...a....W..
51 00000060: 2f00 0103 7002 0000 4576 656e 7454 6872 /...p...EventThr
52 00000070: 6561 6400 6572 0000 7002 0000 6100 0000 ead.er..p...a...
53 00000080: 0100 0000 0000 0000 4a69 7420 7468 7265 ........Jit thre
54 00000090: 6164 2070 6f6f 6c00 140d 0000 8100 0000 ad pool.........
55 000000a0: 50c2 0910 2f00 0103 140d 0000 4a69 7420 P.../.......Jit
56 000000b0: 7468 7265 6164 2070 6f6f 6c00 140d 0000 thread pool.....
57 000000c0: 8100 0000 0100 0000 0000 0000 7377 6170 ............swap
58 000000d0: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
59 000000e0: 7800 0000 901a c80e 2f00 0103 0000 0000 x......./.......
60 000000f0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
61 00000100: 0000 0000 7800 0000 0000 0000 0000 0000 ....x...........
62 00000110: 4469 7370 5379 6e63 0069 6e67 6572 0000 DispSync.inger..
63 00000120: 6f02 0000 6100 0000 1064 1e00 2f00 0103 o...a....d../...
64 00000130: 6f02 0000 4469 7370 5379 6e63 0069 6e67 o...DispSync.ing
65 00000140: 6572 0000 6f02 0000 6100 0000 0100 0000 er..o...a.......
66 00000150: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
67 00000160: 0000 0000 0000 0000 7800 0000 9074 8600 ........x....t..
68 00000170: 2f00 0103 0000 0000 7377 6170 7065 722f /.......swapper/
69 00000180: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
70 00000190: 0000 0000 0000 0000 4576 656e 7454 6872 ........EventThr
71 000001a0: 6561 6400 6572 0000 7002 0000 6100 0000 ead.er..p...a...
72 000001b0: d071 0b00 2f00 0103 7002 0000 4576 656e .q../...p...Even
73 000001c0: 7454 6872 6561 6400 6572 0000 7002 0000 tThread.er..p...
74 000001d0: 6100 0000 0100 0000 0000 0000 7377 6170 a...........swap
75 000001e0: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
76 000001f0: 7800 0000 10cd 4504 2f00 0103 0000 0000 x.....E./.......
77 00000200: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
78 00000210: 0000 0000 7800 0000 0000 0000 0000 0000 ....x...........
79 00000220: 7375 676f 763a 3000 0000 0000 0000 0000 sugov:0.........
80 00000230: 3802 0000 3100 0000 30d6 1300 2f00 0103 8...1...0.../...
81 00000240: 3802 0000 7375 676f 763a 3000 0000 0000 8...sugov:0.....
82 00000250: 0000 0000 3802 0000 3100 0000 0100 0000 ....8...1.......
83 00000260: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
84 00000270: 0000 0000 0000 0000 7800 0000 3049 a202 ........x...0I..
85 00000280: 2f00 0103 0000 0000 7377 6170 7065 722f /.......swapper/
86 00000290: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
87 000002a0: 0000 0000 0000 0000 4469 7370 5379 6e63 ........DispSync
88 000002b0: 0069 6e67 6572 0000 6f02 0000 6100 0000 .inger..o...a...
89 000002c0: d07a 1000 2f00 0103 6f02 0000 4469 7370 .z../...o...Disp
90 000002d0: 5379 6e63 0069 6e67 6572 0000 6f02 0000 Sync.inger..o...
91 000002e0: 6100 0000 0100 0000 0000 0000 7377 6170 a...........swap
92 000002f0: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
93 00000300: 7800 0000 d085 1100 2f00 0103 0000 0000 x......./.......
94 00000310: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
95 00000320: 0000 0000 7800 0000 0000 0000 0000 0000 ....x...........
96 00000330: 7375 7266 6163 6566 6c69 6e67 6572 0000 surfaceflinger..
97 00000340: 4b02 0000 6200 0000 907a f000 2f00 0103 K...b....z../...
98 00000350: 4b02 0000 7375 7266 6163 6566 6c69 6e67 K...surfacefling
99 00000360: 6572 0000 4b02 0000 6200 0000 0100 0000 er..K...b.......
100 00000370: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
101 00000380: 0000 0000 0000 0000 7800 0000 305a 6400 ........x...0Zd.
102 00000390: 2f00 0103 0000 0000 7377 6170 7065 722f /.......swapper/
103 000003a0: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
104 000003b0: 0000 0000 0000 0000 6d64 7373 5f66 6230 ........mdss_fb0
105 000003c0: 0000 0000 0000 0000 5714 0000 5300 0000 ........W...S...
106 000003d0: 10b1 9e03 2f00 0103 5714 0000 6d64 7373 ..../...W...mdss
107 000003e0: 5f66 6230 0000 0000 0000 0000 5714 0000 _fb0........W...
108 000003f0: 5300 0000 0200 0000 0000 0000 6b73 6f66 S...........ksof
109 00000400: 7469 7271 642f 3000 0000 0000 0300 0000 tirqd/0.........
110 00000410: 7800 0000 90bb 9900 2f00 0103 0300 0000 x......./.......
111 00000420: 6b73 6f66 7469 7271 642f 3000 0000 0000 ksoftirqd/0.....
112 00000430: 0300 0000 7800 0000 0100 0000 0000 0000 ....x...........
113 00000440: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
114 00000450: 0000 0000 7800 0000 701e 5305 2f00 0103 ....x...p.S./...
115 00000460: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
116 00000470: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
117 00000480: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16:
118 00000490: 3600 0000 6401 0000 7800 0000 90a1 2900 6...d...x.....).
119 000004a0: 2f00 0103 6401 0000 6b77 6f72 6b65 722f /...d...kworker/
120 000004b0: 7531 363a 3600 0000 6401 0000 7800 0000 u16:6...d...x...
121 000004c0: 0200 0000 0000 0000 7377 6170 7065 722f ........swapper/
122 000004d0: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
123 000004e0: b0e5 4f04 2f00 0103 0000 0000 7377 6170 ..O./.......swap
124 000004f0: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
125 00000500: 7800 0000 0000 0000 0000 0000 4269 6e64 x...........Bind
126 00000510: 6572 3a32 3136 385f 3135 0000 e614 0000 er:2168_15......
127 00000520: 7800 0000 b0bd 7c00 2f00 0103 e614 0000 x.....|./.......
128 00000530: 4269 6e64 6572 3a32 3136 385f 3135 0000 Binder:2168_15..
129 00000540: e614 0000 7800 0000 0100 0000 0000 0000 ....x...........
130 00000550: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
131 00000560: 0000 0000 7800 0000 d0bd 7e01 2f00 0103 ....x.....~./...
132 00000570: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
133 00000580: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
134 00000590: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16:
135 000005a0: 3900 0000 e204 0000 7800 0000 7016 0800 9.......x...p...
136 000005b0: 2f00 0103 e204 0000 6b77 6f72 6b65 722f /.......kworker/
137 000005c0: 7531 363a 3900 0000 e204 0000 7800 0000 u16:9.......x...
138 000005d0: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/
139 000005e0: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
140 000005f0: 1004 5200 2f00 0103 0000 0000 7377 6170 ..R./.......swap
141 00000600: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
142 00000610: 7800 0000 0000 0000 0000 0000 6b77 6f72 x...........kwor
143 00000620: 6b65 722f 7531 363a 3900 0000 e204 0000 ker/u16:9.......
144 00000630: 7800 0000 d0db 0700 2f00 0103 e204 0000 x......./.......
145 00000640: 6b77 6f72 6b65 722f 7531 363a 3900 0000 kworker/u16:9...
146 00000650: e204 0000 7800 0000 0100 0000 0000 0000 ....x...........
147 00000660: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
148 00000670: 0000 0000 7800 0000 b0a2 8c00 2f00 0103 ....x......./...
149 00000680: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
150 00000690: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
151 000006a0: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16:
152 000006b0: 3900 0000 e204 0000 7800 0000 d02b 0400 9.......x....+..
153 000006c0: 2f00 0103 e204 0000 6b77 6f72 6b65 722f /.......kworker/
154 000006d0: 7531 363a 3900 0000 e204 0000 7800 0000 u16:9.......x...
155 000006e0: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/
156 000006f0: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
157 00000700: d064 ef05 2f00 0103 0000 0000 7377 6170 .d../.......swap
158 00000710: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
159 00000720: 7800 0000 0000 0000 0000 0000 4469 7370 x...........Disp
160 00000730: 5379 6e63 0069 6e67 6572 0000 6f02 0000 Sync.inger..o...
161 00000740: 6100 0000 f07d 1b00 2f00 0103 6f02 0000 a....}../...o...
162 00000750: 4469 7370 5379 6e63 0069 6e67 6572 0000 DispSync.inger..
163 00000760: 6f02 0000 6100 0000 0100 0000 0000 0000 o...a...........
164 00000770: 6b73 6f66 7469 7271 642f 3000 0000 0000 ksoftirqd/0.....
165 00000780: 0300 0000 7800 0000 304c 2000 2f00 0103 ....x...0L ./...
166 00000790: 0300 0000 6b73 6f66 7469 7271 642f 3000 ....ksoftirqd/0.
167 000007a0: 0000 0000 0300 0000 7800 0000 0100 0000 ........x.......
168 000007b0: 0000 0000 6465 7832 6f61 7400 3935 5f33 ....dex2oat.95_3
169 000007c0: 0000 0000 341f 0000 8200 0000 700b 0700 ....4.......p...
170 000007d0: 2f00 0103 341f 0000 6465 7832 6f61 7400 /...4...dex2oat.
171 000007e0: 3935 5f33 0000 0000 341f 0000 8200 0000 95_3....4.......
172 000007f0: 0000 0000 0000 0000 7375 676f 763a 3000 ........sugov:0.
173 00000800: 0000 0000 0000 0000 3802 0000 3100 0000 ........8...1...
174 00000810: 50b0 0600 2f00 0103 3802 0000 7375 676f P.../...8...sugo
175 00000820: 763a 3000 0000 0000 0000 0000 3802 0000 v:0.........8...
176 00000830: 3100 0000 0008 0000 0000 0000 6d69 6772 1...........migr
177 00000840: 6174 696f 6e2f 3000 0000 0000 0d00 0000 ation/0.........
178 00000850: 0000 0000 d09c 0600 2f00 0103 0d00 0000 ......../.......
179 00000860: 6d69 6772 6174 696f 6e2f 3000 0000 0000 migration/0.....
180 00000870: 0d00 0000 0000 0000 0100 0000 0000 0000 ................
181 00000880: 7375 676f 763a 3000 0000 0000 0000 0000 sugov:0.........
182 00000890: 3802 0000 3100 0000 7061 1900 2f00 0103 8...1...pa../...
183 000008a0: 3802 0000 7375 676f 763a 3000 0000 0000 8...sugov:0.....
184 000008b0: 0000 0000 3802 0000 3100 0000 0100 0000 ....8...1.......
185 000008c0: 0000 0000 6465 7832 6f61 7400 3935 5f33 ....dex2oat.95_3
186 000008d0: 0000 0000 341f 0000 8200 0000 f03c 5600 ....4........<V.
187 000008e0: 2f00 0103 341f 0000 6465 7832 6f61 7400 /...4...dex2oat.
188 000008f0: 3935 5f33 0000 0000 341f 0000 8200 0000 95_3....4.......
189 00000900: 0200 0000 0000 0000 7377 6170 7065 722f ........swapper/
190 00000910: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
191 00000920: 5013 c400 2f00 0103 0000 0000 7377 6170 P.../.......swap
192 00000930: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
193 00000940: 7800 0000 0000 0000 0000 0000 616e 6472 x...........andr
194 00000950: 6f69 642e 6861 7264 7761 7200 d20a 0000 oid.hardwar.....
195 00000960: 7800 0000 30c9 1300 2f00 0103 d20a 0000 x...0.../.......
196 00000970: 616e 6472 6f69 642e 6861 7264 7761 7200 android.hardwar.
197 00000980: d20a 0000 7800 0000 0100 0000 0000 0000 ....x...........
198 00000990: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
199 000009a0: 0000 0000 7800 0000 7097 c000 2f00 0103 ....x...p.../...
200 000009b0: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
201 000009c0: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
202 000009d0: 0000 0000 616e 6472 6f69 642e 6861 7264 ....android.hard
203 000009e0: 7761 7200 d20a 0000 7800 0000 305c 0c00 war.....x...0\..
204 000009f0: 2f00 0103 d20a 0000 616e 6472 6f69 642e /.......android.
205 00000a00: 6861 7264 7761 7200 d20a 0000 7800 0000 hardwar.....x...
206 00000a10: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/
207 00000a20: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
208 00000a30: d0aa 1401 2f00 0103 0000 0000 7377 6170 ..../.......swap
209 00000a40: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
210 00000a50: 7800 0000 0000 0000 0000 0000 616e 6472 x...........andr
211 00000a60: 6f69 642e 6861 7264 7761 7200 d20a 0000 oid.hardwar.....
212 00000a70: 7800 0000 903b 0c00 2f00 0103 d20a 0000 x....;../.......
213 00000a80: 616e 6472 6f69 642e 6861 7264 7761 7200 android.hardwar.
214 00000a90: d20a 0000 7800 0000 0100 0000 0000 0000 ....x...........
215 00000aa0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
216 00000ab0: 0000 0000 7800 0000 f024 5401 2f00 0103 ....x....$T./...
217 00000ac0: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
218 00000ad0: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
219 00000ae0: 0000 0000 616e 6472 6f69 642e 6861 7264 ....android.hard
220 00000af0: 7761 7200 d20a 0000 7800 0000 f0f3 0b00 war.....x.......
221 00000b00: 2f00 0103 d20a 0000 616e 6472 6f69 642e /.......android.
222 00000b10: 6861 7264 7761 7200 d20a 0000 7800 0000 hardwar.....x...
223 00000b20: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/
224 00000b30: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
225 00000b40: d0b5 bf02 2f00 0103 0000 0000 7377 6170 ..../.......swap
226 00000b50: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
227 00000b60: 7800 0000 0000 0000 0000 0000 4469 7370 x...........Disp
228 00000b70: 5379 6e63 0069 6e67 6572 0000 6f02 0000 Sync.inger..o...
229 00000b80: 6100 0000 90cd 1400 2f00 0103 6f02 0000 a......./...o...
230 00000b90: 4469 7370 5379 6e63 0069 6e67 6572 0000 DispSync.inger..
231 00000ba0: 6f02 0000 6100 0000 0100 0000 0000 0000 o...a...........
232 00000bb0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
233 00000bc0: 0000 0000 7800 0000 50a6 1100 2f00 0103 ....x...P.../...
234 00000bd0: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
235 00000be0: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
236 00000bf0: 0000 0000 7375 7266 6163 6566 6c69 6e67 ....surfacefling
237 00000c00: 6572 0000 4b02 0000 6200 0000 b04c 4200 er..K...b....LB.
238 00000c10: 2f00 0103 4b02 0000 7375 7266 6163 6566 /...K...surfacef
239 00000c20: 6c69 6e67 6572 0000 4b02 0000 6200 0000 linger..K...b...
240 00000c30: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/
241 00000c40: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
242 00000c50: b025 060a 2f00 0103 0000 0000 7377 6170 .%../.......swap
243 00000c60: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
244 00000c70: 7800 0000 0000 0000 0000 0000 6b77 6f72 x...........kwor
245 00000c80: 6b65 722f 7531 363a 3600 0000 6401 0000 ker/u16:6...d...
246 00000c90: 7800 0000 d0b6 0600 2f00 0103 6401 0000 x......./...d...
247 00000ca0: 6b77 6f72 6b65 722f 7531 363a 3600 0000 kworker/u16:6...
248 00000cb0: 6401 0000 7800 0000 0100 0000 0000 0000 d...x...........
249 00000cc0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
250 00000cd0: 0000 0000 7800 0000 f0a0 5800 2f00 0103 ....x.....X./...
251 00000ce0: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
252 00000cf0: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
253 00000d00: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16:
254 00000d10: 3600 0000 6401 0000 7800 0000 f07a 1300 6...d...x....z..
255 00000d20: 2f00 0103 6401 0000 6b77 6f72 6b65 722f /...d...kworker/
256 00000d30: 7531 363a 3600 0000 6401 0000 7800 0000 u16:6...d...x...
257 00000d40: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/
258 00000d50: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
259 00000d60: b080 b101 2f00 0103 0000 0000 7377 6170 ..../.......swap
260 00000d70: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
261 00000d80: 7800 0000 0000 0000 0000 0000 6b77 6f72 x...........kwor
262 00000d90: 6b65 722f 7531 363a 3600 0000 6401 0000 ker/u16:6...d...
263 00000da0: 7800 0000 103c 1200 2f00 0103 6401 0000 x....<../...d...
264 00000db0: 6b77 6f72 6b65 722f 7531 363a 3600 0000 kworker/u16:6...
265 00000dc0: 6401 0000 7800 0000 0100 0000 0000 0000 d...x...........
266 00000dd0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
267 00000de0: 0000 0000 7800 0000 50ea 3800 2f00 0103 ....x...P.8./...
268 00000df0: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
269 00000e00: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
270 00000e10: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16:
271 00000e20: 3600 0000 6401 0000 7800 0000 5032 0400 6...d...x...P2..
272 00000e30: 2f00 0103 6401 0000 6b77 6f72 6b65 722f /...d...kworker/
273 00000e40: 7531 363a 3600 0000 6401 0000 7800 0000 u16:6...d...x...
274 00000e50: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/
275 00000e60: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
276 00000e70: 70f5 9000 2f00 0103 0000 0000 7377 6170 p.../.......swap
277 00000e80: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
278 00000e90: 7800 0000 0000 0000 0000 0000 6b77 6f72 x...........kwor
279 00000ea0: 6b65 722f 7531 363a 3600 0000 6401 0000 ker/u16:6...d...
280 00000eb0: 7800 0000 10d7 0300 2f00 0103 6401 0000 x......./...d...
281 00000ec0: 6b77 6f72 6b65 722f 7531 363a 3600 0000 kworker/u16:6...
282 00000ed0: 6401 0000 7800 0000 0100 0000 0000 0000 d...x...........
283 00000ee0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
284 00000ef0: 0000 0000 7800 0000 907c 0900 2f00 0103 ....x....|../...
285 00000f00: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
286 00000f10: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
287 00000f20: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16:
288 00000f30: 3600 0000 6401 0000 7800 0000 7082 0300 6...d...x...p...
289 00000f40: 2f00 0103 6401 0000 6b77 6f72 6b65 722f /...d...kworker/
290 00000f50: 7531 363a 3600 0000 6401 0000 7800 0000 u16:6...d...x...
291 00000f60: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/
292 00000f70: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
293 00000f80: f0ec 2100 2f00 0103 0000 0000 7377 6170 ..!./.......swap
294 00000f90: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
295 00000fa0: 7800 0000 0000 0000 0000 0000 6b77 6f72 x...........kwor
296 00000fb0: 6b65 722f 7531 363a 3600 0000 6401 0000 ker/u16:6...d...
297 00000fc0: 7800 0000 0000 0000 0000 0000 0000 0000 x...............
298 00000fd0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
299 00000fe0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
300 00000ff0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
301 )",
302 };
303
304 // A page full of "ftrace/print" events.
305 ExamplePage g_full_page_print{
306 "synthetic",
307 R"(
308 00000000: df34 b6e2 e2a9 0000 e00f 0000 0000 0000 .4..............
309 00000010: 0700 0000 0500 0000 4f56 0700 84fc 9a9f ........OV......
310 00000020: ffff ffff 3333 3333 0a00 0000 f348 0700 ....3333.....H..
311 00000030: 47d0 0900 0500 0000 4f56 0700 84fc 9a9f G.......OV......
312 00000040: ffff ffff 3434 3434 0a00 722f 7531 3435 ....4444..r/u145
313 00000050: 07ab 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
314 00000060: ffff ffff 3535 3535 0a00 0700 6b77 6f72 ....5555....kwor
315 00000070: c7b0 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
316 00000080: ffff ffff 3636 3636 0a00 0100 4001 0103 ....6666....@...
317 00000090: a7b8 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
318 000000a0: ffff ffff 3737 3737 0a00 0000 0100 0000 ....7777........
319 000000b0: 47ac 0900 0500 0000 4f56 0700 84fc 9a9f G.......OV......
320 000000c0: ffff ffff 3838 3838 0a00 0000 f348 0700 ....8888.....H..
321 000000d0: 47d9 0900 0500 0000 4f56 0700 84fc 9a9f G.......OV......
322 000000e0: ffff ffff 3939 3939 0a00 722f 7531 3435 ....9999..r/u145
323 000000f0: c7b9 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
324 00000100: ffff ffff 4141 4141 0a00 0700 6b77 6f72 ....AAAA....kwor
325 00000110: c7b6 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
326 00000120: ffff ffff 4242 4242 0a00 0100 4001 0103 ....BBBB....@...
327 00000130: c7a6 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
328 00000140: ffff ffff 4343 4343 0a00 0000 0100 0000 ....CCCC........
329 00000150: c7ab 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
330 00000160: ffff ffff 4444 4444 0a00 0000 f348 0700 ....DDDD.....H..
331 00000170: 27b3 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
332 00000180: ffff ffff 4545 4545 0a00 722f 7531 3435 ....EEEE..r/u145
333 00000190: 27b0 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
334 000001a0: ffff ffff 4646 4646 0a00 0700 6b77 6f72 ....FFFF....kwor
335 000001b0: c778 0c00 0500 0000 4f56 0700 84fc 9a9f .x......OV......
336 000001c0: ffff ffff 3030 3030 0a00 0100 4001 0103 ....0000....@...
337 000001d0: 27b8 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
338 000001e0: ffff ffff 3131 3131 0a00 0000 0100 0000 ....1111........
339 000001f0: 27af 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
340 00000200: ffff ffff 3232 3232 0a00 0000 f348 0700 ....2222.....H..
341 00000210: 27a5 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
342 00000220: ffff ffff 3333 3333 0a00 722f 7531 3435 ....3333..r/u145
343 00000230: 07b7 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
344 00000240: ffff ffff 3434 3434 0a00 0700 6b77 6f72 ....4444....kwor
345 00000250: 47ac 0900 0500 0000 4f56 0700 84fc 9a9f G.......OV......
346 00000260: ffff ffff 3535 3535 0a00 0100 4001 0103 ....5555....@...
347 00000270: 27ad 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
348 00000280: ffff ffff 3636 3636 0a00 0000 0100 0000 ....6666........
349 00000290: e7b6 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
350 000002a0: ffff ffff 3737 3737 0a00 0000 f348 0700 ....7777.....H..
351 000002b0: 47b1 0900 0500 0000 4f56 0700 84fc 9a9f G.......OV......
352 000002c0: ffff ffff 3838 3838 0a00 722f 7531 3435 ....8888..r/u145
353 000002d0: a7a7 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
354 000002e0: ffff ffff 3939 3939 0a00 0700 6b77 6f72 ....9999....kwor
355 000002f0: 87a9 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
356 00000300: ffff ffff 4141 4141 0a00 0100 4001 0103 ....AAAA....@...
357 00000310: 27cb 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
358 00000320: ffff ffff 4242 4242 0a00 0000 0100 0000 ....BBBB........
359 00000330: 47c0 0900 0500 0000 4f56 0700 84fc 9a9f G.......OV......
360 00000340: ffff ffff 4343 4343 0a00 0000 f348 0700 ....CCCC.....H..
361 00000350: 67ae 0900 0500 0000 4f56 0700 84fc 9a9f g.......OV......
362 00000360: ffff ffff 4444 4444 0a00 722f 7531 3435 ....DDDD..r/u145
363 00000370: 47b0 0900 0500 0000 4f56 0700 84fc 9a9f G.......OV......
364 00000380: ffff ffff 4545 4545 0a00 0700 6b77 6f72 ....EEEE....kwor
365 00000390: 87a6 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
366 000003a0: ffff ffff 4646 4646 0a00 0100 4001 0103 ....FFFF....@...
367 000003b0: 07a2 0c00 0500 0000 4f56 0700 84fc 9a9f ........OV......
368 000003c0: ffff ffff 3030 3030 0a00 0000 0100 0000 ....0000........
369 000003d0: e71f 0a00 0500 0000 4f56 0700 84fc 9a9f ........OV......
370 000003e0: ffff ffff 3131 3131 0a00 0000 f348 0700 ....1111.....H..
371 000003f0: 67c6 0900 0500 0000 4f56 0700 84fc 9a9f g.......OV......
372 00000400: ffff ffff 3232 3232 0a00 722f 7531 3435 ....2222..r/u145
373 00000410: 67b2 0900 0500 0000 4f56 0700 84fc 9a9f g.......OV......
374 00000420: ffff ffff 3333 3333 0a00 0700 6b77 6f72 ....3333....kwor
375 00000430: 27af 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
376 00000440: ffff ffff 3434 3434 0a00 0100 4001 0103 ....4444....@...
377 00000450: 07d8 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
378 00000460: ffff ffff 3535 3535 0a00 0000 0100 0000 ....5555........
379 00000470: 87ba 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
380 00000480: ffff ffff 3636 3636 0a00 0000 f348 0700 ....6666.....H..
381 00000490: 27c3 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
382 000004a0: ffff ffff 3737 3737 0a00 722f 7531 3435 ....7777..r/u145
383 000004b0: 27bb 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
384 000004c0: ffff ffff 3838 3838 0a00 0700 6b77 6f72 ....8888....kwor
385 000004d0: c7a6 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
386 000004e0: ffff ffff 3939 3939 0a00 0100 4001 0103 ....9999....@...
387 000004f0: e7ac 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
388 00000500: ffff ffff 4141 4141 0a00 0000 0100 0000 ....AAAA........
389 00000510: e7a5 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
390 00000520: ffff ffff 4242 4242 0a00 0000 f348 0700 ....BBBB.....H..
391 00000530: c7ab 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
392 00000540: ffff ffff 4343 4343 0a00 722f 7531 3435 ....CCCC..r/u145
393 00000550: 07aa 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
394 00000560: ffff ffff 4444 4444 0a00 0700 6b77 6f72 ....DDDD....kwor
395 00000570: 27b1 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
396 00000580: ffff ffff 4545 4545 0a00 0100 4001 0103 ....EEEE....@...
397 00000590: e7ae 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
398 000005a0: ffff ffff 4646 4646 0a00 0000 0100 0000 ....FFFF........
399 000005b0: 876e 0c00 0500 0000 4f56 0700 84fc 9a9f .n......OV......
400 000005c0: ffff ffff 3030 3030 0a00 0000 f348 0700 ....0000.....H..
401 000005d0: 87b0 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
402 000005e0: ffff ffff 3131 3131 0a00 722f 7531 3435 ....1111..r/u145
403 000005f0: a7de 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
404 00000600: ffff ffff 3232 3232 0a00 0700 6b77 6f72 ....2222....kwor
405 00000610: c7bf 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
406 00000620: ffff ffff 3333 3333 0a00 0100 4001 0103 ....3333....@...
407 00000630: e7ad 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
408 00000640: ffff ffff 3434 3434 0a00 0000 2e00 0000 ....4444........
409 00000650: 67c2 0900 0500 0000 4f56 0700 84fc 9a9f g.......OV......
410 00000660: ffff ffff 3535 3535 0a00 0000 f348 0700 ....5555.....H..
411 00000670: 87ec 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
412 00000680: ffff ffff 3636 3636 0a00 722f 7531 3435 ....6666..r/u145
413 00000690: e7b9 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
414 000006a0: ffff ffff 3737 3737 0a00 0700 6b77 6f72 ....7777....kwor
415 000006b0: e7aa 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
416 000006c0: ffff ffff 3838 3838 0a00 0100 4001 0103 ....8888....@...
417 000006d0: 07a9 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
418 000006e0: ffff ffff 3939 3939 0a00 0000 0100 0000 ....9999........
419 000006f0: 87a6 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
420 00000700: ffff ffff 4141 4141 0a00 0000 f348 0700 ....AAAA.....H..
421 00000710: c7a6 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
422 00000720: ffff ffff 4242 4242 0a00 722f 7531 3435 ....BBBB..r/u145
423 00000730: 67d0 0900 0500 0000 4f56 0700 84fc 9a9f g.......OV......
424 00000740: ffff ffff 4343 4343 0a00 0700 6b77 6f72 ....CCCC....kwor
425 00000750: 27b6 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
426 00000760: ffff ffff 4444 4444 0a00 0100 4001 0103 ....DDDD....@...
427 00000770: e7ba 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
428 00000780: ffff ffff 4545 4545 0a00 0000 0100 0000 ....EEEE........
429 00000790: 07ce 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
430 000007a0: ffff ffff 4646 4646 0a00 0000 f348 0700 ....FFFF.....H..
431 000007b0: c768 0c00 0500 0000 4f56 0700 84fc 9a9f .h......OV......
432 000007c0: ffff ffff 3030 3030 0a00 722f 7531 3435 ....0000..r/u145
433 000007d0: 67de 0900 0500 0000 4f56 0700 84fc 9a9f g.......OV......
434 000007e0: ffff ffff 3131 3131 0a00 0700 6b77 6f72 ....1111....kwor
435 000007f0: 27b9 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
436 00000800: ffff ffff 3232 3232 0a00 0100 4001 0103 ....2222....@...
437 00000810: c7b2 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
438 00000820: ffff ffff 3333 3333 0a00 0000 0100 0000 ....3333........
439 00000830: 67b1 0900 0500 0000 4f56 0700 84fc 9a9f g.......OV......
440 00000840: ffff ffff 3434 3434 0a00 0000 f348 0700 ....4444.....H..
441 00000850: c7b2 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
442 00000860: ffff ffff 3535 3535 0a00 722f 7531 3435 ....5555..r/u145
443 00000870: c7c1 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
444 00000880: ffff ffff 3636 3636 0a00 0700 6b77 6f72 ....6666....kwor
445 00000890: 87ac 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
446 000008a0: ffff ffff 3737 3737 0a00 0100 4001 0103 ....7777....@...
447 000008b0: c7b2 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
448 000008c0: ffff ffff 3838 3838 0a00 0000 0100 0000 ....8888........
449 000008d0: 879e 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
450 000008e0: ffff ffff 3939 3939 0a00 0000 f348 0700 ....9999.....H..
451 000008f0: 67ae 0900 0500 0000 4f56 0700 84fc 9a9f g.......OV......
452 00000900: ffff ffff 4141 4141 0a00 722f 7531 3435 ....AAAA..r/u145
453 00000910: 07a6 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
454 00000920: ffff ffff 4242 4242 0a00 0700 6b77 6f72 ....BBBB....kwor
455 00000930: a7a2 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
456 00000940: ffff ffff 4343 4343 0a00 0100 4001 0103 ....CCCC....@...
457 00000950: 67a4 0900 0500 0000 4f56 0700 84fc 9a9f g.......OV......
458 00000960: ffff ffff 4444 4444 0a00 0000 0100 0000 ....DDDD........
459 00000970: 87a5 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
460 00000980: ffff ffff 4545 4545 0a00 0000 5417 0700 ....EEEE....T...
461 00000990: 47b1 0900 0500 0000 4f56 0700 84fc 9a9f G.......OV......
462 000009a0: ffff ffff 4646 4646 0a00 722f 7531 3435 ....FFFF..r/u145
463 000009b0: e75e 0c00 0500 0000 4f56 0700 84fc 9a9f .^......OV......
464 000009c0: ffff ffff 3030 3030 0a00 0700 6b77 6f72 ....0000....kwor
465 000009d0: a7bc 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
466 000009e0: ffff ffff 3131 3131 0a00 0100 4001 0103 ....1111....@...
467 000009f0: c7a8 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
468 00000a00: ffff ffff 3232 3232 0a00 0000 2e00 0000 ....2222........
469 00000a10: c7af 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
470 00000a20: ffff ffff 3333 3333 0a00 0000 5417 0700 ....3333....T...
471 00000a30: 67aa 0900 0500 0000 4f56 0700 84fc 9a9f g.......OV......
472 00000a40: ffff ffff 3434 3434 0a00 722f 7531 3435 ....4444..r/u145
473 00000a50: 07bd 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
474 00000a60: ffff ffff 3535 3535 0a00 0700 6b77 6f72 ....5555....kwor
475 00000a70: 67b2 0900 0500 0000 4f56 0700 84fc 9a9f g.......OV......
476 00000a80: ffff ffff 3636 3636 0a00 0100 4001 0103 ....6666....@...
477 00000a90: 27b2 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
478 00000aa0: ffff ffff 3737 3737 0a00 0000 2e00 0000 ....7777........
479 00000ab0: a731 0a00 0500 0000 4f56 0700 84fc 9a9f .1......OV......
480 00000ac0: ffff ffff 3838 3838 0a00 0000 5417 0700 ....8888....T...
481 00000ad0: e7bd 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
482 00000ae0: ffff ffff 3939 3939 0a00 722f 7531 3435 ....9999..r/u145
483 00000af0: c7ad 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
484 00000b00: ffff ffff 4141 4141 0a00 0700 6b77 6f72 ....AAAA....kwor
485 00000b10: 47af 0900 0500 0000 4f56 0700 84fc 9a9f G.......OV......
486 00000b20: ffff ffff 4242 4242 0a00 0100 4001 0103 ....BBBB....@...
487 00000b30: c7d2 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
488 00000b40: ffff ffff 4343 4343 0a00 0000 2e00 0000 ....CCCC........
489 00000b50: 67a6 0900 0500 0000 4f56 0700 84fc 9a9f g.......OV......
490 00000b60: ffff ffff 4444 4444 0a00 0000 5417 0700 ....DDDD....T...
491 00000b70: 47aa 0900 0500 0000 4f56 0700 84fc 9a9f G.......OV......
492 00000b80: ffff ffff 4545 4545 0a00 722f 7531 3435 ....EEEE..r/u145
493 00000b90: 07b6 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
494 00000ba0: ffff ffff 4646 4646 0a00 0700 6b77 6f72 ....FFFF....kwor
495 00000bb0: 876b 0c00 0500 0000 4f56 0700 84fc 9a9f .k......OV......
496 00000bc0: ffff ffff 3030 3030 0a00 0100 4001 0103 ....0000....@...
497 00000bd0: 47bc 0900 0500 0000 4f56 0700 84fc 9a9f G.......OV......
498 00000be0: ffff ffff 3131 3131 0a00 0000 2e00 0000 ....1111........
499 00000bf0: a7b1 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
500 00000c00: ffff ffff 3232 3232 0a00 0000 5417 0700 ....2222....T...
501 00000c10: a7bb 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
502 00000c20: ffff ffff 3333 3333 0a00 722f 7531 3435 ....3333..r/u145
503 00000c30: 47b4 0900 0500 0000 4f56 0700 84fc 9a9f G.......OV......
504 00000c40: ffff ffff 3434 3434 0a00 0700 6b77 6f72 ....4444....kwor
505 00000c50: 0710 0a00 0500 0000 4f56 0700 84fc 9a9f ........OV......
506 00000c60: ffff ffff 3535 3535 0a00 0100 4001 0103 ....5555....@...
507 00000c70: 27cb 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
508 00000c80: ffff ffff 3636 3636 0a00 0000 2e00 0000 ....6666........
509 00000c90: c7a8 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
510 00000ca0: ffff ffff 3737 3737 0a00 0000 5417 0700 ....7777....T...
511 00000cb0: 47c6 0900 0500 0000 4f56 0700 84fc 9a9f G.......OV......
512 00000cc0: ffff ffff 3838 3838 0a00 722f 7531 3435 ....8888..r/u145
513 00000cd0: 07c1 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
514 00000ce0: ffff ffff 3939 3939 0a00 0700 6b77 6f72 ....9999....kwor
515 00000cf0: 47b3 0900 0500 0000 4f56 0700 84fc 9a9f G.......OV......
516 00000d00: ffff ffff 4141 4141 0a00 0300 4001 0103 ....AAAA....@...
517 00000d10: a7ad 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
518 00000d20: ffff ffff 4242 4242 0a00 0000 2e00 0000 ....BBBB........
519 00000d30: 87b3 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
520 00000d40: ffff ffff 4343 4343 0a00 0000 5417 0700 ....CCCC....T...
521 00000d50: 07b8 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
522 00000d60: ffff ffff 4444 4444 0a00 722f 7531 3435 ....DDDD..r/u145
523 00000d70: 07b6 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
524 00000d80: ffff ffff 4545 4545 0a00 0700 6b77 6f72 ....EEEE....kwor
525 00000d90: 27b4 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
526 00000da0: ffff ffff 4646 4646 0a00 0100 4001 0103 ....FFFF....@...
527 00000db0: 2761 0c00 0500 0000 4f56 0700 84fc 9a9f 'a......OV......
528 00000dc0: ffff ffff 3030 3030 0a00 0000 2e00 0000 ....0000........
529 00000dd0: 87b6 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
530 00000de0: ffff ffff 3131 3131 0a00 0000 5417 0700 ....1111....T...
531 00000df0: 87ae 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
532 00000e00: ffff ffff 3232 3232 0a00 722f 7531 3435 ....2222..r/u145
533 00000e10: c7ac 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
534 00000e20: ffff ffff 3333 3333 0a00 0700 6b77 6f72 ....3333....kwor
535 00000e30: 27c0 0900 0500 0000 4f56 0700 84fc 9a9f '.......OV......
536 00000e40: ffff ffff 3434 3434 0a00 0100 4001 0103 ....4444....@...
537 00000e50: 07b2 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
538 00000e60: ffff ffff 3535 3535 0a00 0000 2e00 0000 ....5555........
539 00000e70: 67ae 0900 0500 0000 4f56 0700 84fc 9a9f g.......OV......
540 00000e80: ffff ffff 3636 3636 0a00 0000 5417 0700 ....6666....T...
541 00000e90: a7af 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
542 00000ea0: ffff ffff 3737 3737 0a00 722f 7531 3435 ....7777..r/u145
543 00000eb0: e7aa 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
544 00000ec0: ffff ffff 3838 3838 0a00 0700 6b77 6f72 ....8888....kwor
545 00000ed0: 07ae 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
546 00000ee0: ffff ffff 3939 3939 0a00 0100 4001 0103 ....9999....@...
547 00000ef0: 87af 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
548 00000f00: ffff ffff 4141 4141 0a00 0000 2e00 0000 ....AAAA........
549 00000f10: 07ae 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
550 00000f20: ffff ffff 4242 4242 0a00 0000 5417 0700 ....BBBB....T...
551 00000f30: 47a0 0900 0500 0000 4f56 0700 84fc 9a9f G.......OV......
552 00000f40: ffff ffff 4343 4343 0a00 722f 7531 3435 ....CCCC..r/u145
553 00000f50: e7d5 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
554 00000f60: ffff ffff 4444 4444 0a00 0700 6b77 6f72 ....DDDD....kwor
555 00000f70: 87bc 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
556 00000f80: ffff ffff 4545 4545 0a00 0100 4001 0103 ....EEEE....@...
557 00000f90: e7c3 0900 0500 0000 4f56 0700 84fc 9a9f ........OV......
558 00000fa0: ffff ffff 4646 4646 0a00 0000 2e00 0000 ....FFFF........
559 00000fb0: 475a 0c00 0500 0000 4f56 0700 84fc 9a9f GZ......OV......
560 00000fc0: ffff ffff 3030 3030 0a00 0000 5417 0700 ....0000....T...
561 00000fd0: 47bc 0900 0500 0000 4f56 0700 84fc 9a9f G.......OV......
562 00000fe0: ffff ffff 3131 3131 0a00 722f 7531 3435 ....1111..r/u145
563 00000ff0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
564 )",
565 };
566
567 // A page full of "ftrace/print" atrace "C|pid|0000" events
568 ExamplePage g_full_page_atrace_print{
569 "synthetic",
570 R"(
571 00000000: 5c07 2181 3e14 0800 e40f 00c0 ffff ffff \.!.>...........
572 00000010: 0800 0000 0500 0000 39ec 1700 042e 7b99 ........9.....{.
573 00000020: ffff ffff 437c 3131 317c 3333 3333 0a00 ....C|111|3333..
574 00000030: 0000 0000 8836 0c00 0500 0000 39ec 1700 .....6......9...
575 00000040: 042e 7b99 ffff ffff 437c 3131 317c 3434 ..{.....C|111|44
576 00000050: 3434 0a00 0000 0000 c84e 0c00 0500 0000 44.......N......
577 00000060: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
578 00000070: 317c 3535 3535 0a00 0000 0000 4847 0c00 1|5555......HG..
579 00000080: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
580 00000090: 437c 3131 317c 3636 3636 0a00 0000 0000 C|111|6666......
581 000000a0: 4835 0c00 0500 0000 39ec 1700 042e 7b99 H5......9.....{.
582 000000b0: ffff ffff 437c 3131 317c 3737 3737 0a00 ....C|111|7777..
583 000000c0: 0000 0000 8830 0c00 0500 0000 39ec 1700 .....0......9...
584 000000d0: 042e 7b99 ffff ffff 437c 3131 317c 3838 ..{.....C|111|88
585 000000e0: 3838 0a00 0000 0000 683d 0c00 0500 0000 88......h=......
586 000000f0: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
587 00000100: 317c 3939 3939 0a00 0000 0000 a84a 0e00 1|9999.......J..
588 00000110: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
589 00000120: 437c 3131 317c 4141 4141 0a00 0000 0000 C|111|AAAA......
590 00000130: c861 0c00 0500 0000 39ec 1700 042e 7b99 .a......9.....{.
591 00000140: ffff ffff 437c 3131 317c 4242 4242 0a00 ....C|111|BBBB..
592 00000150: 0000 0000 2837 0c00 0500 0000 39ec 1700 ....(7......9...
593 00000160: 042e 7b99 ffff ffff 437c 3131 317c 4343 ..{.....C|111|CC
594 00000170: 4343 0a00 0000 0000 283b 0c00 0500 0000 CC......(;......
595 00000180: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
596 00000190: 317c 4444 4444 0a00 0000 0000 2838 0c00 1|DDDD......(8..
597 000001a0: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
598 000001b0: 437c 3131 317c 4545 4545 0a00 0000 0000 C|111|EEEE......
599 000001c0: a830 0c00 0500 0000 39ec 1700 042e 7b99 .0......9.....{.
600 000001d0: ffff ffff 437c 3131 317c 4646 4646 0a00 ....C|111|FFFF..
601 000001e0: 0000 0000 08f7 1200 0500 0000 39ec 1700 ............9...
602 000001f0: 042e 7b99 ffff ffff 437c 3131 317c 3030 ..{.....C|111|00
603 00000200: 3030 0a00 0000 0000 e83f 0c00 0500 0000 00.......?......
604 00000210: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
605 00000220: 317c 3131 3131 0a00 0000 0000 6845 0c00 1|1111......hE..
606 00000230: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
607 00000240: 437c 3131 317c 3232 3232 0a00 0000 0000 C|111|2222......
608 00000250: 48c6 0c00 0500 0000 39ec 1700 042e 7b99 H.......9.....{.
609 00000260: ffff ffff 437c 3131 317c 3333 3333 0a00 ....C|111|3333..
610 00000270: 0000 0000 4843 0c00 0500 0000 39ec 1700 ....HC......9...
611 00000280: 042e 7b99 ffff ffff 437c 3131 317c 3434 ..{.....C|111|44
612 00000290: 3434 0a00 0000 0000 6899 0c00 0500 0000 44......h.......
613 000002a0: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
614 000002b0: 317c 3535 3535 0a00 0000 0000 2841 0c00 1|5555......(A..
615 000002c0: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
616 000002d0: 437c 3131 317c 3636 3636 0a00 0000 0000 C|111|6666......
617 000002e0: c83a 0c00 0500 0000 39ec 1700 042e 7b99 .:......9.....{.
618 000002f0: ffff ffff 437c 3131 317c 3737 3737 0a00 ....C|111|7777..
619 00000300: 0000 0000 c836 0c00 0500 0000 39ec 1700 .....6......9...
620 00000310: 042e 7b99 ffff ffff 437c 3131 317c 3838 ..{.....C|111|88
621 00000320: 3838 0a00 0000 0000 e82a 0c00 0500 0000 88.......*......
622 00000330: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
623 00000340: 317c 3939 3939 0a00 0000 0000 0834 0c00 1|9999.......4..
624 00000350: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
625 00000360: 437c 3131 317c 4141 4141 0a00 0000 0000 C|111|AAAA......
626 00000370: e883 0c00 0500 0000 39ec 1700 042e 7b99 ........9.....{.
627 00000380: ffff ffff 437c 3131 317c 4242 4242 0a00 ....C|111|BBBB..
628 00000390: 0000 0000 684f 0c00 0500 0000 39ec 1700 ....hO......9...
629 000003a0: 042e 7b99 ffff ffff 437c 3131 317c 4343 ..{.....C|111|CC
630 000003b0: 4343 0a00 0000 0000 c83a 0c00 0500 0000 CC.......:......
631 000003c0: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
632 000003d0: 317c 4444 4444 0a00 0000 0000 8836 0c00 1|DDDD.......6..
633 000003e0: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
634 000003f0: 437c 3131 317c 4545 4545 0a00 0000 0000 C|111|EEEE......
635 00000400: c826 0c00 0500 0000 39ec 1700 042e 7b99 .&......9.....{.
636 00000410: ffff ffff 437c 3131 317c 4646 4646 0a00 ....C|111|FFFF..
637 00000420: 0000 0000 68ee 1200 0500 0000 39ec 1700 ....h.......9...
638 00000430: 042e 7b99 ffff ffff 437c 3131 317c 3030 ..{.....C|111|00
639 00000440: 3030 0a00 0000 0000 4843 0c00 0500 0000 00......HC......
640 00000450: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
641 00000460: 317c 3131 3131 0a00 0000 0000 883f 0c00 1|1111.......?..
642 00000470: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
643 00000480: 437c 3131 317c 3232 3232 0a00 0000 0000 C|111|2222......
644 00000490: a824 0c00 0500 0000 39ec 1700 042e 7b99 .$......9.....{.
645 000004a0: ffff ffff 437c 3131 317c 3333 3333 0a00 ....C|111|3333..
646 000004b0: 0000 0000 e888 0d00 0500 0000 39ec 1700 ............9...
647 000004c0: 042e 7b99 ffff ffff 437c 3131 317c 3434 ..{.....C|111|44
648 000004d0: 3434 0a00 0000 0000 4853 0c00 0500 0000 44......HS......
649 000004e0: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
650 000004f0: 317c 3535 3535 0a00 0000 0000 683f 0c00 1|5555......h?..
651 00000500: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
652 00000510: 437c 3131 317c 3636 3636 0a00 0000 0000 C|111|6666......
653 00000520: 2839 0c00 0500 0000 39ec 1700 042e 7b99 (9......9.....{.
654 00000530: ffff ffff 437c 3131 317c 3737 3737 0a00 ....C|111|7777..
655 00000540: 0000 0000 4869 0c00 0500 0000 39ec 1700 ....Hi......9...
656 00000550: 042e 7b99 ffff ffff 437c 3131 317c 3838 ..{.....C|111|88
657 00000560: 3838 0a00 0000 0000 e861 0c00 0500 0000 88.......a......
658 00000570: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
659 00000580: 317c 3939 3939 0a00 0000 0000 4840 0c00 1|9999......H@..
660 00000590: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
661 000005a0: 437c 3131 317c 4141 4141 0a00 0000 0000 C|111|AAAA......
662 000005b0: a84c 0c00 0500 0000 39ec 1700 042e 7b99 .L......9.....{.
663 000005c0: ffff ffff 437c 3131 317c 4242 4242 0a00 ....C|111|BBBB..
664 000005d0: 0000 0000 2837 0c00 0500 0000 39ec 1700 ....(7......9...
665 000005e0: 042e 7b99 ffff ffff 437c 3131 317c 4343 ..{.....C|111|CC
666 000005f0: 4343 0a00 0000 0000 c831 0c00 0500 0000 CC.......1......
667 00000600: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
668 00000610: 317c 4444 4444 0a00 0000 0000 a823 0c00 1|DDDD.......#..
669 00000620: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
670 00000630: 437c 3131 317c 4545 4545 0a00 0000 0000 C|111|EEEE......
671 00000640: 8824 0c00 0500 0000 39ec 1700 042e 7b99 .$......9.....{.
672 00000650: ffff ffff 437c 3131 317c 4646 4646 0a00 ....C|111|FFFF..
673 00000660: 0000 0000 6867 1500 0500 0000 39ec 1700 ....hg......9...
674 00000670: 042e 7b99 ffff ffff 437c 3131 317c 3030 ..{.....C|111|00
675 00000680: 3030 0a00 0000 0000 284e 0c00 0500 0000 00......(N......
676 00000690: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
677 000006a0: 317c 3131 3131 0a00 0000 0000 8847 0c00 1|1111.......G..
678 000006b0: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
679 000006c0: 437c 3131 317c 3232 3232 0a00 0000 0000 C|111|2222......
680 000006d0: 6835 0c00 0500 0000 39ec 1700 042e 7b99 h5......9.....{.
681 000006e0: ffff ffff 437c 3131 317c 3333 3333 0a00 ....C|111|3333..
682 000006f0: 0000 0000 084e 0c00 0500 0000 39ec 1700 .....N......9...
683 00000700: 042e 7b99 ffff ffff 437c 3131 317c 3434 ..{.....C|111|44
684 00000710: 3434 0a00 0000 0000 c844 0c00 0500 0000 44.......D......
685 00000720: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
686 00000730: 317c 3535 3535 0a00 0000 0000 6825 0c00 1|5555......h%..
687 00000740: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
688 00000750: 437c 3131 317c 3636 3636 0a00 0000 0000 C|111|6666......
689 00000760: 282e 0c00 0500 0000 39ec 1700 042e 7b99 (.......9.....{.
690 00000770: ffff ffff 437c 3131 317c 3737 3737 0a00 ....C|111|7777..
691 00000780: 0000 0000 8832 0c00 0500 0000 39ec 1700 .....2......9...
692 00000790: 042e 7b99 ffff ffff 437c 3131 317c 3838 ..{.....C|111|88
693 000007a0: 3838 0a00 0000 0000 0831 0c00 0500 0000 88.......1......
694 000007b0: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
695 000007c0: 317c 3939 3939 0a00 0000 0000 e83b 0c00 1|9999.......;..
696 000007d0: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
697 000007e0: 437c 3131 317c 4141 4141 0a00 0000 0000 C|111|AAAA......
698 000007f0: e842 0c00 0500 0000 39ec 1700 042e 7b99 .B......9.....{.
699 00000800: ffff ffff 437c 3131 317c 4242 4242 0a00 ....C|111|BBBB..
700 00000810: 0000 0000 682d 0c00 0500 0000 39ec 1700 ....h-......9...
701 00000820: 042e 7b99 ffff ffff 437c 3131 317c 4343 ..{.....C|111|CC
702 00000830: 4343 0a00 0000 0000 4834 0c00 0500 0000 CC......H4......
703 00000840: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
704 00000850: 317c 4444 4444 0a00 0000 0000 887f 0c00 1|DDDD..........
705 00000860: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
706 00000870: 437c 3131 317c 4545 4545 0a00 0000 0000 C|111|EEEE......
707 00000880: 0848 0c00 0500 0000 39ec 1700 042e 7b99 .H......9.....{.
708 00000890: ffff ffff 437c 3131 317c 4646 4646 0a00 ....C|111|FFFF..
709 000008a0: 0000 0000 680e 1300 0500 0000 39ec 1700 ....h.......9...
710 000008b0: 042e 7b99 ffff ffff 437c 3131 317c 3030 ..{.....C|111|00
711 000008c0: 3030 0a00 0000 0000 e847 0c00 0500 0000 00.......G......
712 000008d0: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
713 000008e0: 317c 3131 3131 0a00 0000 0000 684f 0c00 1|1111......hO..
714 000008f0: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
715 00000900: 437c 3131 317c 3232 3232 0a00 0000 0000 C|111|2222......
716 00000910: 4844 0c00 0500 0000 39ec 1700 042e 7b99 HD......9.....{.
717 00000920: ffff ffff 437c 3131 317c 3333 3333 0a00 ....C|111|3333..
718 00000930: 0000 0000 e83e 0c00 0500 0000 39ec 1700 .....>......9...
719 00000940: 042e 7b99 ffff ffff 437c 3131 317c 3434 ..{.....C|111|44
720 00000950: 3434 0a00 0000 0000 882c 0c00 0500 0000 44.......,......
721 00000960: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
722 00000970: 317c 3535 3535 0a00 0000 0000 4825 0c00 1|5555......H%..
723 00000980: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
724 00000990: 437c 3131 317c 3636 3636 0a00 0000 0000 C|111|6666......
725 000009a0: 0827 0c00 0500 0000 39ec 1700 042e 7b99 .'......9.....{.
726 000009b0: ffff ffff 437c 3131 317c 3737 3737 0a00 ....C|111|7777..
727 000009c0: 0000 0000 882f 0c00 0500 0000 39ec 1700 ...../......9...
728 000009d0: 042e 7b99 ffff ffff 437c 3131 317c 3838 ..{.....C|111|88
729 000009e0: 3838 0a00 0000 0000 e835 0c00 0500 0000 88.......5......
730 000009f0: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
731 00000a00: 317c 3939 3939 0a00 0000 0000 48e1 0c00 1|9999......H...
732 00000a10: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
733 00000a20: 437c 3131 317c 4141 4141 0a00 0000 0000 C|111|AAAA......
734 00000a30: e85a 0c00 0500 0000 39ec 1700 042e 7b99 .Z......9.....{.
735 00000a40: ffff ffff 437c 3131 317c 4242 4242 0a00 ....C|111|BBBB..
736 00000a50: 0000 0000 2830 0c00 0500 0000 39ec 1700 ....(0......9...
737 00000a60: 042e 7b99 ffff ffff 437c 3131 317c 4343 ..{.....C|111|CC
738 00000a70: 4343 0a00 0000 0000 c833 0c00 0500 0000 CC.......3......
739 00000a80: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
740 00000a90: 317c 4444 4444 0a00 0000 0000 c838 0c00 1|DDDD.......8..
741 00000aa0: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
742 00000ab0: 437c 3131 317c 4545 4545 0a00 0000 0000 C|111|EEEE......
743 00000ac0: c82a 0c00 0500 0000 39ec 1700 042e 7b99 .*......9.....{.
744 00000ad0: ffff ffff 437c 3131 317c 4646 4646 0a00 ....C|111|FFFF..
745 00000ae0: 0000 0000 08e8 1200 0500 0000 39ec 1700 ............9...
746 00000af0: 042e 7b99 ffff ffff 437c 3131 317c 3030 ..{.....C|111|00
747 00000b00: 3030 0a00 0000 0000 283b 0c00 0500 0000 00......(;......
748 00000b10: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
749 00000b20: 317c 3131 3131 0a00 0000 0000 882d 0c00 1|1111.......-..
750 00000b30: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
751 00000b40: 437c 3131 317c 3232 3232 0a00 0000 0000 C|111|2222......
752 00000b50: 8842 0c00 0500 0000 39ec 1700 042e 7b99 .B......9.....{.
753 00000b60: ffff ffff 437c 3131 317c 3333 3333 0a00 ....C|111|3333..
754 00000b70: 0000 0000 e88e 0c00 0500 0000 39ec 1700 ............9...
755 00000b80: 042e 7b99 ffff ffff 437c 3131 317c 3434 ..{.....C|111|44
756 00000b90: 3434 0a00 0000 0000 c848 0c00 0500 0000 44.......H......
757 00000ba0: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
758 00000bb0: 317c 3535 3535 0a00 0000 0000 2840 0e00 1|5555......(@..
759 00000bc0: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
760 00000bd0: 437c 3131 317c 3636 3636 0a00 0000 0000 C|111|6666......
761 00000be0: a878 0c00 0500 0000 39ec 1700 042e 7b99 .x......9.....{.
762 00000bf0: ffff ffff 437c 3131 317c 3737 3737 0a00 ....C|111|7777..
763 00000c00: 0000 0000 8837 0c00 0500 0000 39ec 1700 .....7......9...
764 00000c10: 042e 7b99 ffff ffff 437c 3131 317c 3838 ..{.....C|111|88
765 00000c20: 3838 0a00 0000 0000 482e 0c00 0500 0000 88......H.......
766 00000c30: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
767 00000c40: 317c 3939 3939 0a00 0000 0000 6832 0c00 1|9999......h2..
768 00000c50: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
769 00000c60: 437c 3131 317c 4141 4141 0a00 0000 0000 C|111|AAAA......
770 00000c70: 483a 0c00 0500 0000 39ec 1700 042e 7b99 H:......9.....{.
771 00000c80: ffff ffff 437c 3131 317c 4242 4242 0a00 ....C|111|BBBB..
772 00000c90: 0000 0000 4830 0c00 0500 0000 39ec 1700 ....H0......9...
773 00000ca0: 042e 7b99 ffff ffff 437c 3131 317c 4343 ..{.....C|111|CC
774 00000cb0: 4343 0a00 0000 0000 282e 0c00 0500 0000 CC......(.......
775 00000cc0: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
776 00000cd0: 317c 4444 4444 0a00 0000 0000 c81f 1c00 1|DDDD..........
777 00000ce0: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
778 00000cf0: 437c 3131 317c 4545 4545 0a00 0000 0000 C|111|EEEE......
779 00000d00: 6833 0c00 0500 0000 39ec 1700 042e 7b99 h3......9.....{.
780 00000d10: ffff ffff 437c 3131 317c 4646 4646 0a00 ....C|111|FFFF..
781 00000d20: 0000 0000 28ee 1200 0500 0000 39ec 1700 ....(.......9...
782 00000d30: 042e 7b99 ffff ffff 437c 3131 317c 3030 ..{.....C|111|00
783 00000d40: 3030 0a00 0000 0000 083e 0c00 0500 0000 00.......>......
784 00000d50: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
785 00000d60: 317c 3131 3131 0a00 0000 0000 8848 0c00 1|1111.......H..
786 00000d70: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
787 00000d80: 437c 3131 317c 3232 3232 0a00 0000 0000 C|111|2222......
788 00000d90: 2832 0c00 0500 0000 39ec 1700 042e 7b99 (2......9.....{.
789 00000da0: ffff ffff 437c 3131 317c 3333 3333 0a00 ....C|111|3333..
790 00000db0: 0000 0000 e8b9 1400 0500 0000 39ec 1700 ............9...
791 00000dc0: 042e 7b99 ffff ffff 437c 3131 317c 3434 ..{.....C|111|44
792 00000dd0: 3434 0a00 0000 0000 28ff 0c00 0500 0000 44......(.......
793 00000de0: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
794 00000df0: 317c 3535 3535 0a00 0000 0000 08f3 0c00 1|5555..........
795 00000e00: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
796 00000e10: 437c 3131 317c 3636 3636 0a00 0000 0000 C|111|6666......
797 00000e20: 88f0 0c00 0500 0000 39ec 1700 042e 7b99 ........9.....{.
798 00000e30: ffff ffff 437c 3131 317c 3737 3737 0a00 ....C|111|7777..
799 00000e40: 0000 0000 88e8 1300 0500 0000 39ec 1700 ............9...
800 00000e50: 042e 7b99 ffff ffff 437c 3131 317c 3838 ..{.....C|111|88
801 00000e60: 3838 0a00 0000 0000 e8c0 1600 0500 0000 88..............
802 00000e70: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
803 00000e80: 317c 3939 3939 0a00 0000 0000 c878 0e00 1|9999.......x..
804 00000e90: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
805 00000ea0: 437c 3131 317c 4141 4141 0a00 0000 0000 C|111|AAAA......
806 00000eb0: 0889 0e00 0500 0000 39ec 1700 042e 7b99 ........9.....{.
807 00000ec0: ffff ffff 437c 3131 317c 4242 4242 0a00 ....C|111|BBBB..
808 00000ed0: 0000 0000 286f 0e00 0500 0000 39ec 1700 ....(o......9...
809 00000ee0: 042e 7b99 ffff ffff 437c 3131 317c 4343 ..{.....C|111|CC
810 00000ef0: 4343 0a00 0000 0000 4874 0e00 0500 0000 CC......Ht......
811 00000f00: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
812 00000f10: 317c 4444 4444 0a00 0000 0000 8869 0e00 1|DDDD.......i..
813 00000f20: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
814 00000f30: 437c 3131 317c 4545 4545 0a00 0000 0000 C|111|EEEE......
815 00000f40: 8870 0e00 0500 0000 39ec 1700 042e 7b99 .p......9.....{.
816 00000f50: ffff ffff 437c 3131 317c 4646 4646 0a00 ....C|111|FFFF..
817 00000f60: 0000 0000 6892 1600 0500 0000 39ec 1700 ....h.......9...
818 00000f70: 042e 7b99 ffff ffff 437c 3131 317c 3030 ..{.....C|111|00
819 00000f80: 3030 0a00 0000 0000 e82e 0f00 0500 0000 00..............
820 00000f90: 39ec 1700 042e 7b99 ffff ffff 437c 3131 9.....{.....C|11
821 00000fa0: 317c 3131 3131 0a00 0000 0000 08ab 0e00 1|1111..........
822 00000fb0: 0500 0000 39ec 1700 042e 7b99 ffff ffff ....9.....{.....
823 00000fc0: 437c 3131 317c 3232 3232 0a00 0000 0000 C|111|2222......
824 00000fd0: 2885 0e00 0500 0000 39ec 1700 042e 7b99 (.......9.....{.
825 00000fe0: ffff ffff 437c 3131 317c 3333 3333 0a00 ....C|111|3333..
826 00000ff0: 0000 0000 5301 0000 0000 0000 0000 0000 ....S...........
827 )",
828 };
829
830 // Low level benchmark for the CpuReader::ParsePageHeader and
831 // CpuReader::ParsePagePayload functions.
DoParse(const ExamplePage & test_case,const std::vector<GroupAndName> & enabled_events,std::optional<FtraceConfig::PrintFilter> print_filter,benchmark::State & state)832 void DoParse(const ExamplePage& test_case,
833 const std::vector<GroupAndName>& enabled_events,
834 std::optional<FtraceConfig::PrintFilter> print_filter,
835 benchmark::State& state) {
836 NullTraceWriter writer;
837 FtraceMetadata metadata{};
838 auto compact_sched_buf = std::make_unique<CompactSchedBuffer>();
839 CpuReader::Bundler bundler(
840 &writer, &metadata, /*symbolizer=*/nullptr, /*cpu=*/0,
841 /*ftrace_clock_snapshot=*/nullptr,
842 protos::pbzero::FTRACE_CLOCK_UNSPECIFIED, compact_sched_buf.get(),
843 /*compact_sched_enabled=*/false, /*last_read_event_ts=*/0);
844
845 ProtoTranslationTable* table = GetTable(test_case.name);
846 auto page = PageFromXxd(test_case.data);
847
848 FtraceDataSourceConfig ds_config{EventFilter{},
849 EventFilter{},
850 DisabledCompactSchedConfigForTesting(),
851 std::nullopt,
852 {},
853 {},
854 {},
855 false /*symbolize_ksyms*/,
856 false /*preserve_ftrace_buffer*/,
857 {}};
858 if (print_filter.has_value()) {
859 ds_config.print_filter =
860 FtracePrintFilterConfig::Create(print_filter.value(), table);
861 PERFETTO_CHECK(ds_config.print_filter.has_value());
862 }
863 for (const GroupAndName& enabled_event : enabled_events) {
864 ds_config.event_filter.AddEnabledEvent(
865 table->EventToFtraceId(enabled_event));
866 }
867
868 while (state.KeepRunning()) {
869 std::unique_ptr<CompactSchedBuffer> compact_buffer(
870 new CompactSchedBuffer());
871 const uint8_t* parse_pos = page.get();
872 std::optional<CpuReader::PageHeader> page_header =
873 CpuReader::ParsePageHeader(&parse_pos, table->page_header_size_len());
874
875 if (!page_header.has_value())
876 return;
877
878 uint64_t last_read_event_ts = 0;
879 CpuReader::ParsePagePayload(parse_pos, &page_header.value(), table,
880 &ds_config, &bundler, &metadata,
881 &last_read_event_ts);
882
883 metadata.Clear();
884 bundler.FinalizeAndRunSymbolizer();
885 }
886 }
887
888 void BM_ParsePageFullOfSchedSwitch(benchmark::State& state) {
889 DoParse(g_full_page_sched_switch, {GroupAndName("sched", "sched_switch")},
890 std::nullopt, state);
891 }
892 BENCHMARK(BM_ParsePageFullOfSchedSwitch);
893
894 void BM_ParsePageFullOfPrint(benchmark::State& state) {
895 DoParse(g_full_page_print, {GroupAndName("ftrace", "print")}, std::nullopt,
896 state);
897 }
898 BENCHMARK(BM_ParsePageFullOfPrint);
899
900 void BM_ParsePageFullOfPrintWithFilterRules(benchmark::State& state) {
901 FtraceConfig::PrintFilter filter_conf;
902 for (int i = 0; i < state.range(0); i++) {
903 auto* rule = filter_conf.add_rules();
904 rule->set_prefix("X"); // This rule will not match
905 rule->set_allow(false);
906 }
907 DoParse(g_full_page_print, {GroupAndName("ftrace", "print")}, filter_conf,
908 state);
909 }
910 BENCHMARK(BM_ParsePageFullOfPrintWithFilterRules)->DenseRange(0, 16, 1);
911
912 void BM_ParsePageFullOfAtracePrint(benchmark::State& state) {
913 DoParse(g_full_page_atrace_print, {GroupAndName("ftrace", "print")},
914 std::nullopt, state);
915 }
916 BENCHMARK(BM_ParsePageFullOfAtracePrint);
917
918 void BM_ParsePageFullOfAtracePrintWithFilterRules(benchmark::State& state) {
919 FtraceConfig::PrintFilter filter_conf;
920 for (int i = 0; i < state.range(0); i++) {
921 auto* rule = filter_conf.add_rules();
922 auto* atrace = rule->mutable_atrace_msg();
923 atrace->set_type("C");
924 atrace->set_prefix("X"); // This rule will not match
925 rule->set_allow(false);
926 }
927 DoParse(g_full_page_print, {GroupAndName("ftrace", "print")}, filter_conf,
928 state);
929 }
930 BENCHMARK(BM_ParsePageFullOfAtracePrintWithFilterRules)->DenseRange(0, 16, 1);
931
932 // Higher level benchmark for the CpuReader::ProcessPagesForDataSource function.
933 void DoProcessPages(const ExamplePage& test_case,
934 const size_t page_repetition,
935 const std::vector<GroupAndName>& enabled_events,
936 std::optional<FtraceConfig::PrintFilter> print_filter,
937 benchmark::State& state) {
938 perfetto::NullTraceWriter writer;
939
940 ProtoTranslationTable* table = GetTable(test_case.name);
941
942 auto repeated_pages =
943 std::make_unique<uint8_t[]>(base::GetSysPageSize() * page_repetition);
944 {
945 auto page = PageFromXxd(test_case.data);
946 for (size_t i = 0; i < page_repetition; i++) {
947 memcpy(&repeated_pages[i * base::GetSysPageSize()], &page[0],
948 base::GetSysPageSize());
949 }
950 }
951
952 FtraceDataSourceConfig ds_config{EventFilter{},
953 EventFilter{},
954 DisabledCompactSchedConfigForTesting(),
955 std::nullopt,
956 {},
957 {},
958 {},
959 false /*symbolize_ksyms*/,
960 false /*preserve_ftrace_buffer*/,
961 {}};
962 if (print_filter.has_value()) {
963 ds_config.print_filter =
964 FtracePrintFilterConfig::Create(print_filter.value(), table);
965 PERFETTO_CHECK(ds_config.print_filter.has_value());
966 }
967 for (const GroupAndName& enabled_event : enabled_events) {
968 ds_config.event_filter.AddEnabledEvent(
969 table->EventToFtraceId(enabled_event));
970 }
971
972 FtraceMetadata metadata{};
973 auto compact_sched_buf = std::make_unique<CompactSchedBuffer>();
974 uint64_t last_read_event_ts = 0;
975 base::FlatSet<protos::pbzero::FtraceParseStatus> parse_errors;
976 while (state.KeepRunning()) {
977 CpuReader::ProcessPagesForDataSource(
978 &writer, &metadata, /*cpu=*/0, &ds_config, &parse_errors,
979 &last_read_event_ts, repeated_pages.get(), page_repetition,
980 compact_sched_buf.get(), table,
981 /*symbolizer=*/nullptr, /*ftrace_clock_snapshot=*/nullptr,
982 protos::pbzero::FTRACE_CLOCK_UNSPECIFIED);
983
984 metadata.Clear();
985 }
986 }
987
988 void BM_ProcessPagesFullOfSchedSwitch(benchmark::State& state) {
989 DoProcessPages(g_full_page_sched_switch, static_cast<size_t>(state.range(0)),
990 {GroupAndName("sched", "sched_switch")}, std::nullopt, state);
991 }
992 BENCHMARK(BM_ProcessPagesFullOfSchedSwitch)->Range(1, 64);
993
994 void BM_ProcessPagesFullOfPrint(benchmark::State& state) {
995 DoProcessPages(g_full_page_print, static_cast<size_t>(state.range(0)),
996 {GroupAndName("ftrace", "print")}, std::nullopt, state);
997 }
998 BENCHMARK(BM_ProcessPagesFullOfPrint)->Range(1, 64);
999
1000 } // namespace
1001 } // namespace perfetto
1002