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 "src/traced/probes/ftrace/cpu_reader.h" 18 #include "src/traced/probes/ftrace/proto_translation_table.h" 19 20 #include "perfetto/base/utils.h" 21 #include "perfetto/protozero/scattered_stream_null_delegate.h" 22 #include "perfetto/protozero/scattered_stream_writer.h" 23 24 #include "perfetto/trace/ftrace/ftrace_event_bundle.pbzero.h" 25 #include "test/cpu_reader_support.h" 26 27 namespace { 28 29 perfetto::ExamplePage g_full_page_sched_switch{ 30 "synthetic", 31 R"( 32 00000000: 31f2 7622 1a00 0000 b40f 0000 0000 0000 1.v"............ 33 00000010: 1e00 0000 0000 0000 1000 0000 2f00 0103 ............/... 34 00000020: 140d 0000 4a69 7420 7468 7265 6164 2070 ....Jit thread p 35 00000030: 6f6f 6c00 140d 0000 8100 0000 0008 0000 ool............. 36 00000040: 0000 0000 4576 656e 7454 6872 6561 6400 ....EventThread. 37 00000050: 6572 0000 7002 0000 6100 0000 f057 0e00 er..p...a....W.. 38 00000060: 2f00 0103 7002 0000 4576 656e 7454 6872 /...p...EventThr 39 00000070: 6561 6400 6572 0000 7002 0000 6100 0000 ead.er..p...a... 40 00000080: 0100 0000 0000 0000 4a69 7420 7468 7265 ........Jit thre 41 00000090: 6164 2070 6f6f 6c00 140d 0000 8100 0000 ad pool......... 42 000000a0: 50c2 0910 2f00 0103 140d 0000 4a69 7420 P.../.......Jit 43 000000b0: 7468 7265 6164 2070 6f6f 6c00 140d 0000 thread pool..... 44 000000c0: 8100 0000 0100 0000 0000 0000 7377 6170 ............swap 45 000000d0: 7065 722f 3000 0000 0000 0000 0000 0000 per/0........... 46 000000e0: 7800 0000 901a c80e 2f00 0103 0000 0000 x......./....... 47 000000f0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0....... 48 00000100: 0000 0000 7800 0000 0000 0000 0000 0000 ....x........... 49 00000110: 4469 7370 5379 6e63 0069 6e67 6572 0000 DispSync.inger.. 50 00000120: 6f02 0000 6100 0000 1064 1e00 2f00 0103 o...a....d../... 51 00000130: 6f02 0000 4469 7370 5379 6e63 0069 6e67 o...DispSync.ing 52 00000140: 6572 0000 6f02 0000 6100 0000 0100 0000 er..o...a....... 53 00000150: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0... 54 00000160: 0000 0000 0000 0000 7800 0000 9074 8600 ........x....t.. 55 00000170: 2f00 0103 0000 0000 7377 6170 7065 722f /.......swapper/ 56 00000180: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x... 57 00000190: 0000 0000 0000 0000 4576 656e 7454 6872 ........EventThr 58 000001a0: 6561 6400 6572 0000 7002 0000 6100 0000 ead.er..p...a... 59 000001b0: d071 0b00 2f00 0103 7002 0000 4576 656e .q../...p...Even 60 000001c0: 7454 6872 6561 6400 6572 0000 7002 0000 tThread.er..p... 61 000001d0: 6100 0000 0100 0000 0000 0000 7377 6170 a...........swap 62 000001e0: 7065 722f 3000 0000 0000 0000 0000 0000 per/0........... 63 000001f0: 7800 0000 10cd 4504 2f00 0103 0000 0000 x.....E./....... 64 00000200: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0....... 65 00000210: 0000 0000 7800 0000 0000 0000 0000 0000 ....x........... 66 00000220: 7375 676f 763a 3000 0000 0000 0000 0000 sugov:0......... 67 00000230: 3802 0000 3100 0000 30d6 1300 2f00 0103 8...1...0.../... 68 00000240: 3802 0000 7375 676f 763a 3000 0000 0000 8...sugov:0..... 69 00000250: 0000 0000 3802 0000 3100 0000 0100 0000 ....8...1....... 70 00000260: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0... 71 00000270: 0000 0000 0000 0000 7800 0000 3049 a202 ........x...0I.. 72 00000280: 2f00 0103 0000 0000 7377 6170 7065 722f /.......swapper/ 73 00000290: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x... 74 000002a0: 0000 0000 0000 0000 4469 7370 5379 6e63 ........DispSync 75 000002b0: 0069 6e67 6572 0000 6f02 0000 6100 0000 .inger..o...a... 76 000002c0: d07a 1000 2f00 0103 6f02 0000 4469 7370 .z../...o...Disp 77 000002d0: 5379 6e63 0069 6e67 6572 0000 6f02 0000 Sync.inger..o... 78 000002e0: 6100 0000 0100 0000 0000 0000 7377 6170 a...........swap 79 000002f0: 7065 722f 3000 0000 0000 0000 0000 0000 per/0........... 80 00000300: 7800 0000 d085 1100 2f00 0103 0000 0000 x......./....... 81 00000310: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0....... 82 00000320: 0000 0000 7800 0000 0000 0000 0000 0000 ....x........... 83 00000330: 7375 7266 6163 6566 6c69 6e67 6572 0000 surfaceflinger.. 84 00000340: 4b02 0000 6200 0000 907a f000 2f00 0103 K...b....z../... 85 00000350: 4b02 0000 7375 7266 6163 6566 6c69 6e67 K...surfacefling 86 00000360: 6572 0000 4b02 0000 6200 0000 0100 0000 er..K...b....... 87 00000370: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0... 88 00000380: 0000 0000 0000 0000 7800 0000 305a 6400 ........x...0Zd. 89 00000390: 2f00 0103 0000 0000 7377 6170 7065 722f /.......swapper/ 90 000003a0: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x... 91 000003b0: 0000 0000 0000 0000 6d64 7373 5f66 6230 ........mdss_fb0 92 000003c0: 0000 0000 0000 0000 5714 0000 5300 0000 ........W...S... 93 000003d0: 10b1 9e03 2f00 0103 5714 0000 6d64 7373 ..../...W...mdss 94 000003e0: 5f66 6230 0000 0000 0000 0000 5714 0000 _fb0........W... 95 000003f0: 5300 0000 0200 0000 0000 0000 6b73 6f66 S...........ksof 96 00000400: 7469 7271 642f 3000 0000 0000 0300 0000 tirqd/0......... 97 00000410: 7800 0000 90bb 9900 2f00 0103 0300 0000 x......./....... 98 00000420: 6b73 6f66 7469 7271 642f 3000 0000 0000 ksoftirqd/0..... 99 00000430: 0300 0000 7800 0000 0100 0000 0000 0000 ....x........... 100 00000440: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0....... 101 00000450: 0000 0000 7800 0000 701e 5305 2f00 0103 ....x...p.S./... 102 00000460: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0... 103 00000470: 0000 0000 0000 0000 7800 0000 0000 0000 ........x....... 104 00000480: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16: 105 00000490: 3600 0000 6401 0000 7800 0000 90a1 2900 6...d...x.....). 106 000004a0: 2f00 0103 6401 0000 6b77 6f72 6b65 722f /...d...kworker/ 107 000004b0: 7531 363a 3600 0000 6401 0000 7800 0000 u16:6...d...x... 108 000004c0: 0200 0000 0000 0000 7377 6170 7065 722f ........swapper/ 109 000004d0: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x... 110 000004e0: b0e5 4f04 2f00 0103 0000 0000 7377 6170 ..O./.......swap 111 000004f0: 7065 722f 3000 0000 0000 0000 0000 0000 per/0........... 112 00000500: 7800 0000 0000 0000 0000 0000 4269 6e64 x...........Bind 113 00000510: 6572 3a32 3136 385f 3135 0000 e614 0000 er:2168_15...... 114 00000520: 7800 0000 b0bd 7c00 2f00 0103 e614 0000 x.....|./....... 115 00000530: 4269 6e64 6572 3a32 3136 385f 3135 0000 Binder:2168_15.. 116 00000540: e614 0000 7800 0000 0100 0000 0000 0000 ....x........... 117 00000550: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0....... 118 00000560: 0000 0000 7800 0000 d0bd 7e01 2f00 0103 ....x.....~./... 119 00000570: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0... 120 00000580: 0000 0000 0000 0000 7800 0000 0000 0000 ........x....... 121 00000590: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16: 122 000005a0: 3900 0000 e204 0000 7800 0000 7016 0800 9.......x...p... 123 000005b0: 2f00 0103 e204 0000 6b77 6f72 6b65 722f /.......kworker/ 124 000005c0: 7531 363a 3900 0000 e204 0000 7800 0000 u16:9.......x... 125 000005d0: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/ 126 000005e0: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x... 127 000005f0: 1004 5200 2f00 0103 0000 0000 7377 6170 ..R./.......swap 128 00000600: 7065 722f 3000 0000 0000 0000 0000 0000 per/0........... 129 00000610: 7800 0000 0000 0000 0000 0000 6b77 6f72 x...........kwor 130 00000620: 6b65 722f 7531 363a 3900 0000 e204 0000 ker/u16:9....... 131 00000630: 7800 0000 d0db 0700 2f00 0103 e204 0000 x......./....... 132 00000640: 6b77 6f72 6b65 722f 7531 363a 3900 0000 kworker/u16:9... 133 00000650: e204 0000 7800 0000 0100 0000 0000 0000 ....x........... 134 00000660: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0....... 135 00000670: 0000 0000 7800 0000 b0a2 8c00 2f00 0103 ....x......./... 136 00000680: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0... 137 00000690: 0000 0000 0000 0000 7800 0000 0000 0000 ........x....... 138 000006a0: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16: 139 000006b0: 3900 0000 e204 0000 7800 0000 d02b 0400 9.......x....+.. 140 000006c0: 2f00 0103 e204 0000 6b77 6f72 6b65 722f /.......kworker/ 141 000006d0: 7531 363a 3900 0000 e204 0000 7800 0000 u16:9.......x... 142 000006e0: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/ 143 000006f0: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x... 144 00000700: d064 ef05 2f00 0103 0000 0000 7377 6170 .d../.......swap 145 00000710: 7065 722f 3000 0000 0000 0000 0000 0000 per/0........... 146 00000720: 7800 0000 0000 0000 0000 0000 4469 7370 x...........Disp 147 00000730: 5379 6e63 0069 6e67 6572 0000 6f02 0000 Sync.inger..o... 148 00000740: 6100 0000 f07d 1b00 2f00 0103 6f02 0000 a....}../...o... 149 00000750: 4469 7370 5379 6e63 0069 6e67 6572 0000 DispSync.inger.. 150 00000760: 6f02 0000 6100 0000 0100 0000 0000 0000 o...a........... 151 00000770: 6b73 6f66 7469 7271 642f 3000 0000 0000 ksoftirqd/0..... 152 00000780: 0300 0000 7800 0000 304c 2000 2f00 0103 ....x...0L ./... 153 00000790: 0300 0000 6b73 6f66 7469 7271 642f 3000 ....ksoftirqd/0. 154 000007a0: 0000 0000 0300 0000 7800 0000 0100 0000 ........x....... 155 000007b0: 0000 0000 6465 7832 6f61 7400 3935 5f33 ....dex2oat.95_3 156 000007c0: 0000 0000 341f 0000 8200 0000 700b 0700 ....4.......p... 157 000007d0: 2f00 0103 341f 0000 6465 7832 6f61 7400 /...4...dex2oat. 158 000007e0: 3935 5f33 0000 0000 341f 0000 8200 0000 95_3....4....... 159 000007f0: 0000 0000 0000 0000 7375 676f 763a 3000 ........sugov:0. 160 00000800: 0000 0000 0000 0000 3802 0000 3100 0000 ........8...1... 161 00000810: 50b0 0600 2f00 0103 3802 0000 7375 676f P.../...8...sugo 162 00000820: 763a 3000 0000 0000 0000 0000 3802 0000 v:0.........8... 163 00000830: 3100 0000 0008 0000 0000 0000 6d69 6772 1...........migr 164 00000840: 6174 696f 6e2f 3000 0000 0000 0d00 0000 ation/0......... 165 00000850: 0000 0000 d09c 0600 2f00 0103 0d00 0000 ......../....... 166 00000860: 6d69 6772 6174 696f 6e2f 3000 0000 0000 migration/0..... 167 00000870: 0d00 0000 0000 0000 0100 0000 0000 0000 ................ 168 00000880: 7375 676f 763a 3000 0000 0000 0000 0000 sugov:0......... 169 00000890: 3802 0000 3100 0000 7061 1900 2f00 0103 8...1...pa../... 170 000008a0: 3802 0000 7375 676f 763a 3000 0000 0000 8...sugov:0..... 171 000008b0: 0000 0000 3802 0000 3100 0000 0100 0000 ....8...1....... 172 000008c0: 0000 0000 6465 7832 6f61 7400 3935 5f33 ....dex2oat.95_3 173 000008d0: 0000 0000 341f 0000 8200 0000 f03c 5600 ....4........<V. 174 000008e0: 2f00 0103 341f 0000 6465 7832 6f61 7400 /...4...dex2oat. 175 000008f0: 3935 5f33 0000 0000 341f 0000 8200 0000 95_3....4....... 176 00000900: 0200 0000 0000 0000 7377 6170 7065 722f ........swapper/ 177 00000910: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x... 178 00000920: 5013 c400 2f00 0103 0000 0000 7377 6170 P.../.......swap 179 00000930: 7065 722f 3000 0000 0000 0000 0000 0000 per/0........... 180 00000940: 7800 0000 0000 0000 0000 0000 616e 6472 x...........andr 181 00000950: 6f69 642e 6861 7264 7761 7200 d20a 0000 oid.hardwar..... 182 00000960: 7800 0000 30c9 1300 2f00 0103 d20a 0000 x...0.../....... 183 00000970: 616e 6472 6f69 642e 6861 7264 7761 7200 android.hardwar. 184 00000980: d20a 0000 7800 0000 0100 0000 0000 0000 ....x........... 185 00000990: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0....... 186 000009a0: 0000 0000 7800 0000 7097 c000 2f00 0103 ....x...p.../... 187 000009b0: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0... 188 000009c0: 0000 0000 0000 0000 7800 0000 0000 0000 ........x....... 189 000009d0: 0000 0000 616e 6472 6f69 642e 6861 7264 ....android.hard 190 000009e0: 7761 7200 d20a 0000 7800 0000 305c 0c00 war.....x...0\.. 191 000009f0: 2f00 0103 d20a 0000 616e 6472 6f69 642e /.......android. 192 00000a00: 6861 7264 7761 7200 d20a 0000 7800 0000 hardwar.....x... 193 00000a10: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/ 194 00000a20: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x... 195 00000a30: d0aa 1401 2f00 0103 0000 0000 7377 6170 ..../.......swap 196 00000a40: 7065 722f 3000 0000 0000 0000 0000 0000 per/0........... 197 00000a50: 7800 0000 0000 0000 0000 0000 616e 6472 x...........andr 198 00000a60: 6f69 642e 6861 7264 7761 7200 d20a 0000 oid.hardwar..... 199 00000a70: 7800 0000 903b 0c00 2f00 0103 d20a 0000 x....;../....... 200 00000a80: 616e 6472 6f69 642e 6861 7264 7761 7200 android.hardwar. 201 00000a90: d20a 0000 7800 0000 0100 0000 0000 0000 ....x........... 202 00000aa0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0....... 203 00000ab0: 0000 0000 7800 0000 f024 5401 2f00 0103 ....x....$T./... 204 00000ac0: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0... 205 00000ad0: 0000 0000 0000 0000 7800 0000 0000 0000 ........x....... 206 00000ae0: 0000 0000 616e 6472 6f69 642e 6861 7264 ....android.hard 207 00000af0: 7761 7200 d20a 0000 7800 0000 f0f3 0b00 war.....x....... 208 00000b00: 2f00 0103 d20a 0000 616e 6472 6f69 642e /.......android. 209 00000b10: 6861 7264 7761 7200 d20a 0000 7800 0000 hardwar.....x... 210 00000b20: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/ 211 00000b30: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x... 212 00000b40: d0b5 bf02 2f00 0103 0000 0000 7377 6170 ..../.......swap 213 00000b50: 7065 722f 3000 0000 0000 0000 0000 0000 per/0........... 214 00000b60: 7800 0000 0000 0000 0000 0000 4469 7370 x...........Disp 215 00000b70: 5379 6e63 0069 6e67 6572 0000 6f02 0000 Sync.inger..o... 216 00000b80: 6100 0000 90cd 1400 2f00 0103 6f02 0000 a......./...o... 217 00000b90: 4469 7370 5379 6e63 0069 6e67 6572 0000 DispSync.inger.. 218 00000ba0: 6f02 0000 6100 0000 0100 0000 0000 0000 o...a........... 219 00000bb0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0....... 220 00000bc0: 0000 0000 7800 0000 50a6 1100 2f00 0103 ....x...P.../... 221 00000bd0: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0... 222 00000be0: 0000 0000 0000 0000 7800 0000 0000 0000 ........x....... 223 00000bf0: 0000 0000 7375 7266 6163 6566 6c69 6e67 ....surfacefling 224 00000c00: 6572 0000 4b02 0000 6200 0000 b04c 4200 er..K...b....LB. 225 00000c10: 2f00 0103 4b02 0000 7375 7266 6163 6566 /...K...surfacef 226 00000c20: 6c69 6e67 6572 0000 4b02 0000 6200 0000 linger..K...b... 227 00000c30: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/ 228 00000c40: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x... 229 00000c50: b025 060a 2f00 0103 0000 0000 7377 6170 .%../.......swap 230 00000c60: 7065 722f 3000 0000 0000 0000 0000 0000 per/0........... 231 00000c70: 7800 0000 0000 0000 0000 0000 6b77 6f72 x...........kwor 232 00000c80: 6b65 722f 7531 363a 3600 0000 6401 0000 ker/u16:6...d... 233 00000c90: 7800 0000 d0b6 0600 2f00 0103 6401 0000 x......./...d... 234 00000ca0: 6b77 6f72 6b65 722f 7531 363a 3600 0000 kworker/u16:6... 235 00000cb0: 6401 0000 7800 0000 0100 0000 0000 0000 d...x........... 236 00000cc0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0....... 237 00000cd0: 0000 0000 7800 0000 f0a0 5800 2f00 0103 ....x.....X./... 238 00000ce0: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0... 239 00000cf0: 0000 0000 0000 0000 7800 0000 0000 0000 ........x....... 240 00000d00: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16: 241 00000d10: 3600 0000 6401 0000 7800 0000 f07a 1300 6...d...x....z.. 242 00000d20: 2f00 0103 6401 0000 6b77 6f72 6b65 722f /...d...kworker/ 243 00000d30: 7531 363a 3600 0000 6401 0000 7800 0000 u16:6...d...x... 244 00000d40: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/ 245 00000d50: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x... 246 00000d60: b080 b101 2f00 0103 0000 0000 7377 6170 ..../.......swap 247 00000d70: 7065 722f 3000 0000 0000 0000 0000 0000 per/0........... 248 00000d80: 7800 0000 0000 0000 0000 0000 6b77 6f72 x...........kwor 249 00000d90: 6b65 722f 7531 363a 3600 0000 6401 0000 ker/u16:6...d... 250 00000da0: 7800 0000 103c 1200 2f00 0103 6401 0000 x....<../...d... 251 00000db0: 6b77 6f72 6b65 722f 7531 363a 3600 0000 kworker/u16:6... 252 00000dc0: 6401 0000 7800 0000 0100 0000 0000 0000 d...x........... 253 00000dd0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0....... 254 00000de0: 0000 0000 7800 0000 50ea 3800 2f00 0103 ....x...P.8./... 255 00000df0: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0... 256 00000e00: 0000 0000 0000 0000 7800 0000 0000 0000 ........x....... 257 00000e10: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16: 258 00000e20: 3600 0000 6401 0000 7800 0000 5032 0400 6...d...x...P2.. 259 00000e30: 2f00 0103 6401 0000 6b77 6f72 6b65 722f /...d...kworker/ 260 00000e40: 7531 363a 3600 0000 6401 0000 7800 0000 u16:6...d...x... 261 00000e50: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/ 262 00000e60: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x... 263 00000e70: 70f5 9000 2f00 0103 0000 0000 7377 6170 p.../.......swap 264 00000e80: 7065 722f 3000 0000 0000 0000 0000 0000 per/0........... 265 00000e90: 7800 0000 0000 0000 0000 0000 6b77 6f72 x...........kwor 266 00000ea0: 6b65 722f 7531 363a 3600 0000 6401 0000 ker/u16:6...d... 267 00000eb0: 7800 0000 10d7 0300 2f00 0103 6401 0000 x......./...d... 268 00000ec0: 6b77 6f72 6b65 722f 7531 363a 3600 0000 kworker/u16:6... 269 00000ed0: 6401 0000 7800 0000 0100 0000 0000 0000 d...x........... 270 00000ee0: 7377 6170 7065 722f 3000 0000 0000 0000 swapper/0....... 271 00000ef0: 0000 0000 7800 0000 907c 0900 2f00 0103 ....x....|../... 272 00000f00: 0000 0000 7377 6170 7065 722f 3000 0000 ....swapper/0... 273 00000f10: 0000 0000 0000 0000 7800 0000 0000 0000 ........x....... 274 00000f20: 0000 0000 6b77 6f72 6b65 722f 7531 363a ....kworker/u16: 275 00000f30: 3600 0000 6401 0000 7800 0000 7082 0300 6...d...x...p... 276 00000f40: 2f00 0103 6401 0000 6b77 6f72 6b65 722f /...d...kworker/ 277 00000f50: 7531 363a 3600 0000 6401 0000 7800 0000 u16:6...d...x... 278 00000f60: 0100 0000 0000 0000 7377 6170 7065 722f ........swapper/ 279 00000f70: 3000 0000 0000 0000 0000 0000 7800 0000 0...........x... 280 00000f80: f0ec 2100 2f00 0103 0000 0000 7377 6170 ..!./.......swap 281 00000f90: 7065 722f 3000 0000 0000 0000 0000 0000 per/0........... 282 00000fa0: 7800 0000 0000 0000 0000 0000 6b77 6f72 x...........kwor 283 00000fb0: 6b65 722f 7531 363a 3600 0000 6401 0000 ker/u16:6...d... 284 00000fc0: 7800 0000 0000 0000 0000 0000 0000 0000 x............... 285 00000fd0: 0000 0000 0000 0000 0000 0000 0000 0000 ................ 286 00000fe0: 0000 0000 0000 0000 0000 0000 0000 0000 ................ 287 00000ff0: 0000 0000 0000 0000 0000 0000 0000 0000 ................ 288 )", 289 }; 290 291 } // namespace 292 293 using perfetto::ExamplePage; 294 using perfetto::EventFilter; 295 using perfetto::ProtoTranslationTable; 296 using protozero::ScatteredStreamWriterNullDelegate; 297 using protozero::ScatteredStreamWriter; 298 using perfetto::GetTable; 299 using perfetto::PageFromXxd; 300 using perfetto::protos::pbzero::FtraceEventBundle; 301 using perfetto::CpuReader; 302 using perfetto::FtraceMetadata; 303 using perfetto::GroupAndName; 304 305 static void BM_ParsePageFullOfSchedSwitch(benchmark::State& state) { 306 const ExamplePage* test_case = &g_full_page_sched_switch; 307 308 ScatteredStreamWriterNullDelegate delegate(perfetto::base::kPageSize); 309 ScatteredStreamWriter stream(&delegate); 310 FtraceEventBundle writer; 311 312 ProtoTranslationTable* table = GetTable(test_case->name); 313 auto page = PageFromXxd(test_case->data); 314 315 EventFilter filter; 316 filter.AddEnabledEvent( 317 table->EventToFtraceId(GroupAndName("sched", "sched_switch"))); 318 319 FtraceMetadata metadata{}; 320 while (state.KeepRunning()) { 321 writer.Reset(&stream); 322 CpuReader::ParsePage(page.get(), &filter, &writer, table, &metadata); 323 metadata.Clear(); 324 } 325 } 326 BENCHMARK(BM_ParsePageFullOfSchedSwitch); 327