blob: 078b46ab8c620cbe78ca6495866e31cadb2785c9 [file] [log] [blame]
Hector Dearmanbc8368e2018-01-25 17:34:11 +00001// 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 "cpu_reader.h"
18
19#include "perfetto/protozero/scattered_stream_writer.h"
20
21#include "perfetto/trace/ftrace/ftrace_event_bundle.pbzero.h"
22#include "test/cpu_reader_support.h"
23#include "test/scattered_stream_null_delegate.h"
24
25namespace {
26
27const size_t kPageSize = 4096;
28
29perfetto::ExamplePage g_full_page_sched_switch{
30 "synthetic",
31 R"(
3200000000: 31f2 7622 1a00 0000 b40f 0000 0000 0000 1.v"............
3300000010: 1e00 0000 0000 0000 1000 0000 2f00 0103 ............/...
3400000020: 140d 0000 4a69 7420 7468 7265 6164 2070 ....Jit thread p
3500000030: 6f6f 6c00 140d 0000 8100 0000 0008 0000 ool.............
3600000040: 0000 0000 4576 656e 7454 6872 6561 6400 ....EventThread.
3700000050: 6572 0000 7002 0000 6100 0000 f057 0e00 er..p...a....W..
3800000060: 2f00 0103 7002 0000 4576 656e 7454 6872 /...p...EventThr
3900000070: 6561 6400 6572 0000 7002 0000 6100 0000 ead.er..p...a...
4000000080: 0100 0000 0000 0000 4a69 7420 7468 7265 ........Jit thre
4100000090: 6164 2070 6f6f 6c00 140d 0000 8100 0000 ad pool.........
42000000a0: 50c2 0910 2f00 0103 140d 0000 4a69 7420 P.../.......Jit
43000000b0: 7468 7265 6164 2070 6f6f 6c00 140d 0000 thread pool.....
44000000c0: 8100 0000 0100 0000 0000 0000 7377 6170 ............swap
45000000d0: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
46000000e0: 7800 0000 901a c80e 2f00 0103 0000 0000 x......./.......
47000000f0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
4800000100: 0000 0000 7800 0000 0000 0000 0000 0000 ....x...........
4900000110: 4469 7370 5379 6e63 0069 6e67 6572 0000 DispSync.inger..
5000000120: 6f02 0000 6100 0000 1064 1e00 2f00 0103 o...a....d../...
5100000130: 6f02 0000 4469 7370 5379 6e63 0069 6e67 o...DispSync.ing
5200000140: 6572 0000 6f02 0000 6100 0000 0100 0000 er..o...a.......
5300000150: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
5400000160: 0000 0000 0000 0000 7800 0000 9074 8600 ........x....t..
5500000170: 2f00 0103 0000 0000 7377 6170 7065 722f /.......swapper/
5600000180: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
5700000190: 0000 0000 0000 0000 4576 656e 7454 6872 ........EventThr
58000001a0: 6561 6400 6572 0000 7002 0000 6100 0000 ead.er..p...a...
59000001b0: d071 0b00 2f00 0103 7002 0000 4576 656e .q../...p...Even
60000001c0: 7454 6872 6561 6400 6572 0000 7002 0000 tThread.er..p...
61000001d0: 6100 0000 0100 0000 0000 0000 7377 6170 a...........swap
62000001e0: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
63000001f0: 7800 0000 10cd 4504 2f00 0103 0000 0000 x.....E./.......
6400000200: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
6500000210: 0000 0000 7800 0000 0000 0000 0000 0000 ....x...........
6600000220: 7375 676f 763a 3000 0000 0000 0000 0000 sugov:0.........
6700000230: 3802 0000 3100 0000 30d6 1300 2f00 0103 8...1...0.../...
6800000240: 3802 0000 7375 676f 763a 3000 0000 0000 8...sugov:0.....
6900000250: 0000 0000 3802 0000 3100 0000 0100 0000 ....8...1.......
7000000260: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
7100000270: 0000 0000 0000 0000 7800 0000 3049 a202 ........x...0I..
7200000280: 2f00 0103 0000 0000 7377 6170 7065 722f /.......swapper/
7300000290: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
74000002a0: 0000 0000 0000 0000 4469 7370 5379 6e63 ........DispSync
75000002b0: 0069 6e67 6572 0000 6f02 0000 6100 0000 .inger..o...a...
76000002c0: d07a 1000 2f00 0103 6f02 0000 4469 7370 .z../...o...Disp
77000002d0: 5379 6e63 0069 6e67 6572 0000 6f02 0000 Sync.inger..o...
78000002e0: 6100 0000 0100 0000 0000 0000 7377 6170 a...........swap
79000002f0: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
8000000300: 7800 0000 d085 1100 2f00 0103 0000 0000 x......./.......
8100000310: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
8200000320: 0000 0000 7800 0000 0000 0000 0000 0000 ....x...........
8300000330: 7375 7266 6163 6566 6c69 6e67 6572 0000 surfaceflinger..
8400000340: 4b02 0000 6200 0000 907a f000 2f00 0103 K...b....z../...
8500000350: 4b02 0000 7375 7266 6163 6566 6c69 6e67 K...surfacefling
8600000360: 6572 0000 4b02 0000 6200 0000 0100 0000 er..K...b.......
8700000370: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
8800000380: 0000 0000 0000 0000 7800 0000 305a 6400 ........x...0Zd.
8900000390: 2f00 0103 0000 0000 7377 6170 7065 722f /.......swapper/
90000003a0: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
91000003b0: 0000 0000 0000 0000 6d64 7373 5f66 6230 ........mdss_fb0
92000003c0: 0000 0000 0000 0000 5714 0000 5300 0000 ........W...S...
93000003d0: 10b1 9e03 2f00 0103 5714 0000 6d64 7373 ..../...W...mdss
94000003e0: 5f66 6230 0000 0000 0000 0000 5714 0000 _fb0........W...
95000003f0: 5300 0000 0200 0000 0000 0000 6b73 6f66 S...........ksof
9600000400: 7469 7271 642f 3000 0000 0000 0300 0000 tirqd/0.........
9700000410: 7800 0000 90bb 9900 2f00 0103 0300 0000 x......./.......
9800000420: 6b73 6f66 7469 7271 642f 3000 0000 0000 ksoftirqd/0.....
9900000430: 0300 0000 7800 0000 0100 0000 0000 0000 ....x...........
10000000440: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
10100000450: 0000 0000 7800 0000 701e 5305 2f00 0103 ....x...p.S./...
10200000460: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
10300000470: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
10400000480: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16:
10500000490: 3600 0000 6401 0000 7800 0000 90a1 2900 6...d...x.....).
106000004a0: 2f00 0103 6401 0000 6b77 6f72 6b65 722f /...d...kworker/
107000004b0: 7531 363a 3600 0000 6401 0000 7800 0000 u16:6...d...x...
108000004c0: 0200 0000 0000 0000 7377 6170 7065 722f ........swapper/
109000004d0: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
110000004e0: b0e5 4f04 2f00 0103 0000 0000 7377 6170 ..O./.......swap
111000004f0: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
11200000500: 7800 0000 0000 0000 0000 0000 4269 6e64 x...........Bind
11300000510: 6572 3a32 3136 385f 3135 0000 e614 0000 er:2168_15......
11400000520: 7800 0000 b0bd 7c00 2f00 0103 e614 0000 x.....|./.......
11500000530: 4269 6e64 6572 3a32 3136 385f 3135 0000 Binder:2168_15..
11600000540: e614 0000 7800 0000 0100 0000 0000 0000 ....x...........
11700000550: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
11800000560: 0000 0000 7800 0000 d0bd 7e01 2f00 0103 ....x.....~./...
11900000570: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
12000000580: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
12100000590: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16:
122000005a0: 3900 0000 e204 0000 7800 0000 7016 0800 9.......x...p...
123000005b0: 2f00 0103 e204 0000 6b77 6f72 6b65 722f /.......kworker/
124000005c0: 7531 363a 3900 0000 e204 0000 7800 0000 u16:9.......x...
125000005d0: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/
126000005e0: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
127000005f0: 1004 5200 2f00 0103 0000 0000 7377 6170 ..R./.......swap
12800000600: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
12900000610: 7800 0000 0000 0000 0000 0000 6b77 6f72 x...........kwor
13000000620: 6b65 722f 7531 363a 3900 0000 e204 0000 ker/u16:9.......
13100000630: 7800 0000 d0db 0700 2f00 0103 e204 0000 x......./.......
13200000640: 6b77 6f72 6b65 722f 7531 363a 3900 0000 kworker/u16:9...
13300000650: e204 0000 7800 0000 0100 0000 0000 0000 ....x...........
13400000660: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
13500000670: 0000 0000 7800 0000 b0a2 8c00 2f00 0103 ....x......./...
13600000680: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
13700000690: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
138000006a0: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16:
139000006b0: 3900 0000 e204 0000 7800 0000 d02b 0400 9.......x....+..
140000006c0: 2f00 0103 e204 0000 6b77 6f72 6b65 722f /.......kworker/
141000006d0: 7531 363a 3900 0000 e204 0000 7800 0000 u16:9.......x...
142000006e0: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/
143000006f0: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
14400000700: d064 ef05 2f00 0103 0000 0000 7377 6170 .d../.......swap
14500000710: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
14600000720: 7800 0000 0000 0000 0000 0000 4469 7370 x...........Disp
14700000730: 5379 6e63 0069 6e67 6572 0000 6f02 0000 Sync.inger..o...
14800000740: 6100 0000 f07d 1b00 2f00 0103 6f02 0000 a....}../...o...
14900000750: 4469 7370 5379 6e63 0069 6e67 6572 0000 DispSync.inger..
15000000760: 6f02 0000 6100 0000 0100 0000 0000 0000 o...a...........
15100000770: 6b73 6f66 7469 7271 642f 3000 0000 0000 ksoftirqd/0.....
15200000780: 0300 0000 7800 0000 304c 2000 2f00 0103 ....x...0L ./...
15300000790: 0300 0000 6b73 6f66 7469 7271 642f 3000 ....ksoftirqd/0.
154000007a0: 0000 0000 0300 0000 7800 0000 0100 0000 ........x.......
155000007b0: 0000 0000 6465 7832 6f61 7400 3935 5f33 ....dex2oat.95_3
156000007c0: 0000 0000 341f 0000 8200 0000 700b 0700 ....4.......p...
157000007d0: 2f00 0103 341f 0000 6465 7832 6f61 7400 /...4...dex2oat.
158000007e0: 3935 5f33 0000 0000 341f 0000 8200 0000 95_3....4.......
159000007f0: 0000 0000 0000 0000 7375 676f 763a 3000 ........sugov:0.
16000000800: 0000 0000 0000 0000 3802 0000 3100 0000 ........8...1...
16100000810: 50b0 0600 2f00 0103 3802 0000 7375 676f P.../...8...sugo
16200000820: 763a 3000 0000 0000 0000 0000 3802 0000 v:0.........8...
16300000830: 3100 0000 0008 0000 0000 0000 6d69 6772 1...........migr
16400000840: 6174 696f 6e2f 3000 0000 0000 0d00 0000 ation/0.........
16500000850: 0000 0000 d09c 0600 2f00 0103 0d00 0000 ......../.......
16600000860: 6d69 6772 6174 696f 6e2f 3000 0000 0000 migration/0.....
16700000870: 0d00 0000 0000 0000 0100 0000 0000 0000 ................
16800000880: 7375 676f 763a 3000 0000 0000 0000 0000 sugov:0.........
16900000890: 3802 0000 3100 0000 7061 1900 2f00 0103 8...1...pa../...
170000008a0: 3802 0000 7375 676f 763a 3000 0000 0000 8...sugov:0.....
171000008b0: 0000 0000 3802 0000 3100 0000 0100 0000 ....8...1.......
172000008c0: 0000 0000 6465 7832 6f61 7400 3935 5f33 ....dex2oat.95_3
173000008d0: 0000 0000 341f 0000 8200 0000 f03c 5600 ....4........<V.
174000008e0: 2f00 0103 341f 0000 6465 7832 6f61 7400 /...4...dex2oat.
175000008f0: 3935 5f33 0000 0000 341f 0000 8200 0000 95_3....4.......
17600000900: 0200 0000 0000 0000 7377 6170 7065 722f ........swapper/
17700000910: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
17800000920: 5013 c400 2f00 0103 0000 0000 7377 6170 P.../.......swap
17900000930: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
18000000940: 7800 0000 0000 0000 0000 0000 616e 6472 x...........andr
18100000950: 6f69 642e 6861 7264 7761 7200 d20a 0000 oid.hardwar.....
18200000960: 7800 0000 30c9 1300 2f00 0103 d20a 0000 x...0.../.......
18300000970: 616e 6472 6f69 642e 6861 7264 7761 7200 android.hardwar.
18400000980: d20a 0000 7800 0000 0100 0000 0000 0000 ....x...........
18500000990: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
186000009a0: 0000 0000 7800 0000 7097 c000 2f00 0103 ....x...p.../...
187000009b0: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
188000009c0: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
189000009d0: 0000 0000 616e 6472 6f69 642e 6861 7264 ....android.hard
190000009e0: 7761 7200 d20a 0000 7800 0000 305c 0c00 war.....x...0\..
191000009f0: 2f00 0103 d20a 0000 616e 6472 6f69 642e /.......android.
19200000a00: 6861 7264 7761 7200 d20a 0000 7800 0000 hardwar.....x...
19300000a10: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/
19400000a20: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
19500000a30: d0aa 1401 2f00 0103 0000 0000 7377 6170 ..../.......swap
19600000a40: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
19700000a50: 7800 0000 0000 0000 0000 0000 616e 6472 x...........andr
19800000a60: 6f69 642e 6861 7264 7761 7200 d20a 0000 oid.hardwar.....
19900000a70: 7800 0000 903b 0c00 2f00 0103 d20a 0000 x....;../.......
20000000a80: 616e 6472 6f69 642e 6861 7264 7761 7200 android.hardwar.
20100000a90: d20a 0000 7800 0000 0100 0000 0000 0000 ....x...........
20200000aa0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
20300000ab0: 0000 0000 7800 0000 f024 5401 2f00 0103 ....x....$T./...
20400000ac0: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
20500000ad0: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
20600000ae0: 0000 0000 616e 6472 6f69 642e 6861 7264 ....android.hard
20700000af0: 7761 7200 d20a 0000 7800 0000 f0f3 0b00 war.....x.......
20800000b00: 2f00 0103 d20a 0000 616e 6472 6f69 642e /.......android.
20900000b10: 6861 7264 7761 7200 d20a 0000 7800 0000 hardwar.....x...
21000000b20: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/
21100000b30: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
21200000b40: d0b5 bf02 2f00 0103 0000 0000 7377 6170 ..../.......swap
21300000b50: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
21400000b60: 7800 0000 0000 0000 0000 0000 4469 7370 x...........Disp
21500000b70: 5379 6e63 0069 6e67 6572 0000 6f02 0000 Sync.inger..o...
21600000b80: 6100 0000 90cd 1400 2f00 0103 6f02 0000 a......./...o...
21700000b90: 4469 7370 5379 6e63 0069 6e67 6572 0000 DispSync.inger..
21800000ba0: 6f02 0000 6100 0000 0100 0000 0000 0000 o...a...........
21900000bb0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
22000000bc0: 0000 0000 7800 0000 50a6 1100 2f00 0103 ....x...P.../...
22100000bd0: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
22200000be0: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
22300000bf0: 0000 0000 7375 7266 6163 6566 6c69 6e67 ....surfacefling
22400000c00: 6572 0000 4b02 0000 6200 0000 b04c 4200 er..K...b....LB.
22500000c10: 2f00 0103 4b02 0000 7375 7266 6163 6566 /...K...surfacef
22600000c20: 6c69 6e67 6572 0000 4b02 0000 6200 0000 linger..K...b...
22700000c30: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/
22800000c40: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
22900000c50: b025 060a 2f00 0103 0000 0000 7377 6170 .%../.......swap
23000000c60: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
23100000c70: 7800 0000 0000 0000 0000 0000 6b77 6f72 x...........kwor
23200000c80: 6b65 722f 7531 363a 3600 0000 6401 0000 ker/u16:6...d...
23300000c90: 7800 0000 d0b6 0600 2f00 0103 6401 0000 x......./...d...
23400000ca0: 6b77 6f72 6b65 722f 7531 363a 3600 0000 kworker/u16:6...
23500000cb0: 6401 0000 7800 0000 0100 0000 0000 0000 d...x...........
23600000cc0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
23700000cd0: 0000 0000 7800 0000 f0a0 5800 2f00 0103 ....x.....X./...
23800000ce0: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
23900000cf0: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
24000000d00: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16:
24100000d10: 3600 0000 6401 0000 7800 0000 f07a 1300 6...d...x....z..
24200000d20: 2f00 0103 6401 0000 6b77 6f72 6b65 722f /...d...kworker/
24300000d30: 7531 363a 3600 0000 6401 0000 7800 0000 u16:6...d...x...
24400000d40: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/
24500000d50: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
24600000d60: b080 b101 2f00 0103 0000 0000 7377 6170 ..../.......swap
24700000d70: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
24800000d80: 7800 0000 0000 0000 0000 0000 6b77 6f72 x...........kwor
24900000d90: 6b65 722f 7531 363a 3600 0000 6401 0000 ker/u16:6...d...
25000000da0: 7800 0000 103c 1200 2f00 0103 6401 0000 x....<../...d...
25100000db0: 6b77 6f72 6b65 722f 7531 363a 3600 0000 kworker/u16:6...
25200000dc0: 6401 0000 7800 0000 0100 0000 0000 0000 d...x...........
25300000dd0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
25400000de0: 0000 0000 7800 0000 50ea 3800 2f00 0103 ....x...P.8./...
25500000df0: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
25600000e00: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
25700000e10: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16:
25800000e20: 3600 0000 6401 0000 7800 0000 5032 0400 6...d...x...P2..
25900000e30: 2f00 0103 6401 0000 6b77 6f72 6b65 722f /...d...kworker/
26000000e40: 7531 363a 3600 0000 6401 0000 7800 0000 u16:6...d...x...
26100000e50: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/
26200000e60: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
26300000e70: 70f5 9000 2f00 0103 0000 0000 7377 6170 p.../.......swap
26400000e80: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
26500000e90: 7800 0000 0000 0000 0000 0000 6b77 6f72 x...........kwor
26600000ea0: 6b65 722f 7531 363a 3600 0000 6401 0000 ker/u16:6...d...
26700000eb0: 7800 0000 10d7 0300 2f00 0103 6401 0000 x......./...d...
26800000ec0: 6b77 6f72 6b65 722f 7531 363a 3600 0000 kworker/u16:6...
26900000ed0: 6401 0000 7800 0000 0100 0000 0000 0000 d...x...........
27000000ee0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0.......
27100000ef0: 0000 0000 7800 0000 907c 0900 2f00 0103 ....x....|../...
27200000f00: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0...
27300000f10: 0000 0000 0000 0000 7800 0000 0000 0000 ........x.......
27400000f20: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16:
27500000f30: 3600 0000 6401 0000 7800 0000 7082 0300 6...d...x...p...
27600000f40: 2f00 0103 6401 0000 6b77 6f72 6b65 722f /...d...kworker/
27700000f50: 7531 363a 3600 0000 6401 0000 7800 0000 u16:6...d...x...
27800000f60: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/
27900000f70: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x...
28000000f80: f0ec 2100 2f00 0103 0000 0000 7377 6170 ..!./.......swap
28100000f90: 7065 722f 3000 0000 0000 0000 0000 0000 per/0...........
28200000fa0: 7800 0000 0000 0000 0000 0000 6b77 6f72 x...........kwor
28300000fb0: 6b65 722f 7531 363a 3600 0000 6401 0000 ker/u16:6...d...
28400000fc0: 7800 0000 0000 0000 0000 0000 0000 0000 x...............
28500000fd0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
28600000fe0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
28700000ff0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
288 )",
289};
290
291} // namespace
292
293using perfetto::ExamplePage;
294using perfetto::EventFilter;
295using perfetto::ProtoTranslationTable;
296using perfetto::ScatteredStreamNullDelegate;
297using perfetto::GetTable;
298using perfetto::PageFromXxd;
299using perfetto::protos::pbzero::FtraceEventBundle;
300using perfetto::CpuReader;
301
302static void BM_ParsePageFullOfSchedSwitch(benchmark::State& state) {
303 const ExamplePage* test_case = &g_full_page_sched_switch;
304
305 ScatteredStreamNullDelegate delegate(kPageSize);
306 protozero::ScatteredStreamWriter stream(&delegate);
307 FtraceEventBundle writer;
308
309 ProtoTranslationTable* table = GetTable(test_case->name);
310 auto page = PageFromXxd(test_case->data);
311
312 EventFilter filter(*table, std::set<std::string>({"sched_switch"}));
313
314 while (state.KeepRunning()) {
315 writer.Reset(&stream);
316 CpuReader::ParsePage(42 /* cpu number */, page.get(), &filter, &writer,
317 table);
318 }
319}
320BENCHMARK(BM_ParsePageFullOfSchedSwitch);