xref: /aosp_15_r20/system/extras/simpleperf/read_symbol_map_test.cpp (revision 288bf5226967eb3dac5cce6c939ccc2a7f2b4fe5)
1*288bf522SAndroid Build Coastguard Worker /*
2*288bf522SAndroid Build Coastguard Worker  * Copyright (C) 2020 The Android Open Source Project
3*288bf522SAndroid Build Coastguard Worker  *
4*288bf522SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*288bf522SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*288bf522SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*288bf522SAndroid Build Coastguard Worker  *
8*288bf522SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*288bf522SAndroid Build Coastguard Worker  *
10*288bf522SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*288bf522SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*288bf522SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*288bf522SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*288bf522SAndroid Build Coastguard Worker  * limitations under the License.
15*288bf522SAndroid Build Coastguard Worker  */
16*288bf522SAndroid Build Coastguard Worker 
17*288bf522SAndroid Build Coastguard Worker #include "read_symbol_map.h"
18*288bf522SAndroid Build Coastguard Worker 
19*288bf522SAndroid Build Coastguard Worker #include <string>
20*288bf522SAndroid Build Coastguard Worker #include <vector>
21*288bf522SAndroid Build Coastguard Worker 
22*288bf522SAndroid Build Coastguard Worker #include <gtest/gtest.h>
23*288bf522SAndroid Build Coastguard Worker 
24*288bf522SAndroid Build Coastguard Worker #include "dso.h"
25*288bf522SAndroid Build Coastguard Worker 
26*288bf522SAndroid Build Coastguard Worker using namespace simpleperf;
27*288bf522SAndroid Build Coastguard Worker 
28*288bf522SAndroid Build Coastguard Worker // @CddTest = 6.1/C-0-2
TEST(read_symbol_map,smoke)29*288bf522SAndroid Build Coastguard Worker TEST(read_symbol_map, smoke) {
30*288bf522SAndroid Build Coastguard Worker   std::string content(
31*288bf522SAndroid Build Coastguard Worker       "\n"  // skip
32*288bf522SAndroid Build Coastguard Worker       "   0x2000 0x20 two \n"
33*288bf522SAndroid Build Coastguard Worker       "0x4000\n"            // skip
34*288bf522SAndroid Build Coastguard Worker       "       0x40 four\n"  // skip
35*288bf522SAndroid Build Coastguard Worker       "0x1000 0x10 one\n"
36*288bf522SAndroid Build Coastguard Worker       "     \n"            // skip
37*288bf522SAndroid Build Coastguard Worker       "0x5000 0x50five\n"  // skip
38*288bf522SAndroid Build Coastguard Worker       " skip this line\n"  // skip
39*288bf522SAndroid Build Coastguard Worker       "0x6000 0x60 six six\n"
40*288bf522SAndroid Build Coastguard Worker       "0x3000 48   three   \n");
41*288bf522SAndroid Build Coastguard Worker 
42*288bf522SAndroid Build Coastguard Worker   auto symbols = ReadSymbolMapFromString(content);
43*288bf522SAndroid Build Coastguard Worker 
44*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(4u, symbols.size());
45*288bf522SAndroid Build Coastguard Worker 
46*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x1000, symbols[0].addr);
47*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x10, symbols[0].len);
48*288bf522SAndroid Build Coastguard Worker   ASSERT_STREQ("one", symbols[0].Name());
49*288bf522SAndroid Build Coastguard Worker 
50*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x2000, symbols[1].addr);
51*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x20, symbols[1].len);
52*288bf522SAndroid Build Coastguard Worker   ASSERT_STREQ("two", symbols[1].Name());
53*288bf522SAndroid Build Coastguard Worker 
54*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x3000, symbols[2].addr);
55*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x30, symbols[2].len);
56*288bf522SAndroid Build Coastguard Worker   ASSERT_STREQ("three", symbols[2].Name());
57*288bf522SAndroid Build Coastguard Worker 
58*288bf522SAndroid Build Coastguard Worker   // Specifically allow spaces in symbols, JIT runtimes such as V8 may generate
59*288bf522SAndroid Build Coastguard Worker   // them, as "my_function (./path/to/file.js:42:0)" or "get property_name" for
60*288bf522SAndroid Build Coastguard Worker   // example.
61*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x6000, symbols[3].addr);
62*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x60, symbols[3].len);
63*288bf522SAndroid Build Coastguard Worker   ASSERT_STREQ("six six", symbols[3].Name());
64*288bf522SAndroid Build Coastguard Worker }
65*288bf522SAndroid Build Coastguard Worker 
66*288bf522SAndroid Build Coastguard Worker // @CddTest = 6.1/C-0-2
TEST(read_symbol_map,v8_basic_perf_prof)67*288bf522SAndroid Build Coastguard Worker TEST(read_symbol_map, v8_basic_perf_prof) {
68*288bf522SAndroid Build Coastguard Worker   // Interesting sample of jitted function names generated by V8 running the
69*288bf522SAndroid Build Coastguard Worker   // JetStream2 benchmark.
70*288bf522SAndroid Build Coastguard Worker   std::string content(
71*288bf522SAndroid Build Coastguard Worker       "0x300019b02e 0x77 Script:~ cli.js:1:1\n"
72*288bf522SAndroid Build Coastguard Worker       "0x58f00097e0 0x4c8 JS:~initialize ./JetStreamDriver.js:373:21\n"
73*288bf522SAndroid Build Coastguard Worker       "0x58f003c120 0x4c8 JS:~ (d8):246158:16\n"
74*288bf522SAndroid Build Coastguard Worker       "0x58f065ad40 0x4c8 JS:~pp$1.parseEmptyStatement (d8):67313:37\n"
75*288bf522SAndroid Build Coastguard Worker       "0x58f06e7aa0 0x638 RegExp:([a-z0-9$_]+)(=|@|>|%)([a-z0-9$_]+)\n"
76*288bf522SAndroid Build Coastguard Worker       "0x5df00e05a0 0x324 JS:*runRichards (d8):1101:21\n"
77*288bf522SAndroid Build Coastguard Worker       "0x5df017cc20 0xb18 JS:^stringToUTF8Array (d8):386:27\n"
78*288bf522SAndroid Build Coastguard Worker       "0x7a4ddd2780 0x1c0 JS:wasm-to-js:iii:i-19-turbofan\n"
79*288bf522SAndroid Build Coastguard Worker       "0x7a4ddedae0 0x600 JS:wasm-function[74]-74-liftoff\n");
80*288bf522SAndroid Build Coastguard Worker 
81*288bf522SAndroid Build Coastguard Worker   auto symbols = ReadSymbolMapFromString(content);
82*288bf522SAndroid Build Coastguard Worker 
83*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(9u, symbols.size());
84*288bf522SAndroid Build Coastguard Worker 
85*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x300019b02e, symbols[0].addr);
86*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x77, symbols[0].len);
87*288bf522SAndroid Build Coastguard Worker   ASSERT_STREQ("Script:~ cli.js:1:1", symbols[0].Name());
88*288bf522SAndroid Build Coastguard Worker 
89*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x58f00097e0, symbols[1].addr);
90*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x4c8, symbols[1].len);
91*288bf522SAndroid Build Coastguard Worker   ASSERT_STREQ("JS:~initialize ./JetStreamDriver.js:373:21", symbols[1].Name());
92*288bf522SAndroid Build Coastguard Worker 
93*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x58f003c120, symbols[2].addr);
94*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x4c8, symbols[2].len);
95*288bf522SAndroid Build Coastguard Worker   ASSERT_STREQ("JS:~ (d8):246158:16", symbols[2].Name());
96*288bf522SAndroid Build Coastguard Worker 
97*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x58f065ad40, symbols[3].addr);
98*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x4c8, symbols[3].len);
99*288bf522SAndroid Build Coastguard Worker   ASSERT_STREQ("JS:~pp$1.parseEmptyStatement (d8):67313:37", symbols[3].Name());
100*288bf522SAndroid Build Coastguard Worker 
101*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x58f06e7aa0, symbols[4].addr);
102*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x638, symbols[4].len);
103*288bf522SAndroid Build Coastguard Worker   ASSERT_STREQ("RegExp:([a-z0-9$_]+)(=|@|>|%)([a-z0-9$_]+)", symbols[4].Name());
104*288bf522SAndroid Build Coastguard Worker 
105*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x5df00e05a0, symbols[5].addr);
106*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x324, symbols[5].len);
107*288bf522SAndroid Build Coastguard Worker   ASSERT_STREQ("JS:*runRichards (d8):1101:21", symbols[5].Name());
108*288bf522SAndroid Build Coastguard Worker 
109*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x5df017cc20, symbols[6].addr);
110*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0xb18, symbols[6].len);
111*288bf522SAndroid Build Coastguard Worker   ASSERT_STREQ("JS:^stringToUTF8Array (d8):386:27", symbols[6].Name());
112*288bf522SAndroid Build Coastguard Worker 
113*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x7a4ddd2780, symbols[7].addr);
114*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x1c0, symbols[7].len);
115*288bf522SAndroid Build Coastguard Worker   ASSERT_STREQ("JS:wasm-to-js:iii:i-19-turbofan", symbols[7].Name());
116*288bf522SAndroid Build Coastguard Worker 
117*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x7a4ddedae0, symbols[8].addr);
118*288bf522SAndroid Build Coastguard Worker   ASSERT_EQ(0x600, symbols[8].len);
119*288bf522SAndroid Build Coastguard Worker   ASSERT_STREQ("JS:wasm-function[74]-74-liftoff", symbols[8].Name());
120*288bf522SAndroid Build Coastguard Worker }
121