blob: 91d9a422bbe3bcf89cdb0cfddfffc80015baa2fe [file] [log] [blame]
David Blaikiefe2090a2017-09-08 21:10:01 +00001RUN: rm -rf %t
2RUN: mkdir -p %t
David Blaikie1e919432018-12-21 22:25:01 +00003RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x40113f" > %t.input
4RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64.debuglink 0x40113f" >> %t.input
5RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x401020" >> %t.input
6RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x40110e" >> %t.input
7RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x401160" >> %t.input
Kuba Mracek10854a22017-08-15 21:02:17 +00008RUN: echo "%p/Inputs/dwarfdump-test2.elf-x86-64 0x4004e8" >> %t.input
9RUN: echo "%p/Inputs/dwarfdump-test2.elf-x86-64 0x4004f4" >> %t.input
10RUN: echo "%p/Inputs/dwarfdump-test4.elf-x86-64 0x62c" >> %t.input
11RUN: echo "%p/Inputs/dwarfdump-inl-test.elf-x86-64 0x8dc" >> %t.input
12RUN: echo "%p/Inputs/dwarfdump-inl-test.elf-x86-64 0xa05" >> %t.input
13RUN: echo "%p/Inputs/dwarfdump-inl-test.elf-x86-64 0x987" >> %t.input
14RUN: echo "%p/Inputs/dwarfdump-inl-test.high_pc.elf-x86-64 0x568" >> %t.input
David Blaikiefe2090a2017-09-08 21:10:01 +000015RUN: cp "%p/Inputs/dwarfdump-test3.elf-x86-64-space" "%t/dwarfdump-test3.elf-x86-64 space"
16RUN: echo "\"%t/dwarfdump-test3.elf-x86-64 space\" 0x640" >> %t.input
17RUN: echo "\"%t/dwarfdump-test3.elf-x86-64 space\" 0x633" >> %t.input
18RUN: echo "\"%t/dwarfdump-test3.elf-x86-64 space\" 0x62d" >> %t.input
Kuba Mracek10854a22017-08-15 21:02:17 +000019RUN: echo "%p/Inputs/macho-universal 0x1f84" >> %t.input
20RUN: echo "%p/Inputs/macho-universal:i386 0x1f67" >> %t.input
21RUN: echo "%p/Inputs/macho-universal:x86_64 0x100000f05" >> %t.input
22RUN: echo "%p/Inputs/llvm-symbolizer-dwo-test 0x400514" >> %t.input
David Blaikiedf69f1f2018-05-01 18:08:45 +000023RUN: echo "%p/Inputs/llvm-symbolizer-local-mem-func-gcc.elf-x86-64 0x61a" >> %t.input
Kuba Mracek10854a22017-08-15 21:02:17 +000024RUN: echo "%p/Inputs/fission-ranges.elf-x86_64 0x720" >> %t.input
25RUN: echo "%p/Inputs/arange-overlap.elf-x86_64 0x714" >> %t.input
David Blaikiefe2090a2017-09-08 21:10:01 +000026RUN: cp %p/Inputs/split-dwarf-test.dwo %t
27RUN: echo "%p/Inputs/split-dwarf-test 0x400504" >> %t.input
28RUN: echo "%p/Inputs/split-dwarf-test 0x4004f4" >> %t.input
Kuba Mracek10854a22017-08-15 21:02:17 +000029RUN: echo "%p/Inputs/cross-cu-inlining.x86_64-macho.o 0x17" >> %t.input
David Blaikiefe2090a2017-09-08 21:10:01 +000030RUN: cp %p/Inputs/split-dwarf-multiple-cu.dwo %t
Kuba Mracek10854a22017-08-15 21:02:17 +000031RUN: echo "%p/Inputs/split-dwarf-multiple-cu.o 0x4" >> %t.input
David Blaikiefe2090a2017-09-08 21:10:01 +000032RUN: cp %p/Inputs/split-dwarf-addr-object-relocation.dwo %t
Kuba Mracek10854a22017-08-15 21:02:17 +000033RUN: echo "%p/Inputs/split-dwarf-addr-object-relocation.o 0x14" >> %t.input
David Blaikiefe2090a2017-09-08 21:10:01 +000034RUN: cp %p/Inputs/split-dwarf-dwp.o %t
35RUN: cp %p/Inputs/split-dwarf-dwp.o.dwp %t
36RUN: echo "%t/split-dwarf-dwp.o 0x4" >> %t.input
Alexey Samsonov1c4d2862013-04-05 08:30:13 +000037
David Blaikiefe2090a2017-09-08 21:10:01 +000038RUN: cd %t
Alexey Samsonovbf6e3f92014-05-17 00:07:48 +000039RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
Kuba Mracek10854a22017-08-15 21:02:17 +000040RUN: --default-arch=i386 < %t.input | FileCheck --check-prefix=CHECK --check-prefix=SPLIT --check-prefix=DWO %s
David Blaikie4fc8e6f2016-04-22 21:32:59 +000041
42Ensure we get the same results in the absence of gmlt-like data in the executable but the presence of a .dwo file
43
David Blaikiefe2090a2017-09-08 21:10:01 +000044RUN: echo "%p/Inputs/split-dwarf-test-nogmlt 0x400504" >> %t.input
45RUN: echo "%p/Inputs/split-dwarf-test-nogmlt 0x4004f4" >> %t.input
David Blaikie4fc8e6f2016-04-22 21:32:59 +000046RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
Kuba Mracek10854a22017-08-15 21:02:17 +000047RUN: --default-arch=i386 < %t.input | FileCheck --check-prefix=SPLIT --check-prefix=DWO %s
David Blaikie4fc8e6f2016-04-22 21:32:59 +000048
49Ensure we get gmlt like results in the absence of a .dwo file but the presence of gmlt-like data in the executable
50
David Blaikiefe2090a2017-09-08 21:10:01 +000051RUN: rm %t/split-dwarf-test.dwo
52RUN: echo "%p/Inputs/split-dwarf-test 0x400504" >> %t.input
53RUN: echo "%p/Inputs/split-dwarf-test 0x4004f4" >> %t.input
David Blaikie4fc8e6f2016-04-22 21:32:59 +000054RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
Kuba Mracek10854a22017-08-15 21:02:17 +000055RUN: --default-arch=i386 < %t.input | FileCheck --check-prefix=SPLIT --check-prefix=NODWO %s
Alexey Samsonov1c4d2862013-04-05 08:30:13 +000056
David Blaikiefe2090a2017-09-08 21:10:01 +000057RUN: cp %p/Inputs/split-dwarf-dwp.o %t/split-dwarf-dwp-different-name.o
58RUN: echo "%t/split-dwarf-dwp-different-name.o 0x54" > %t.input
David Blaikie4cf772e2017-07-30 01:34:08 +000059RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
60RUN: --default-arch=i386 --dwp=%p/Inputs/split-dwarf-dwp.o.dwp < %t.input | FileCheck --check-prefix=DWP %s
61
Alexey Samsonov1c4d2862013-04-05 08:30:13 +000062CHECK: main
63CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:16
Alexey Samsonov888ca962013-06-04 07:57:38 +000064
Alexey Samsonov68894832013-08-14 17:09:30 +000065CHECK: main
66CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:16
67
Alexey Samsonov888ca962013-06-04 07:57:38 +000068CHECK: _start
69
Alexey Samsonov8ad418b2014-05-19 18:45:32 +000070CHECK: _Z1fii
71CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:11
72
73CHECK: DummyClass
74CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:4
75
76CHECK: a
77CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test2-helper.cc:2
78
79CHECK: main
80CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test2-main.cc:4
81
Alexey Samsonov1c4d2862013-04-05 08:30:13 +000082CHECK: _Z1cv
83CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test4-part1.cc:2
Alexey Samsonov888ca962013-06-04 07:57:38 +000084
Alexey Samsonov1c4d2862013-04-05 08:30:13 +000085CHECK: inlined_h
86CHECK-NEXT: dwarfdump-inl-test.h:2
87CHECK-NEXT: inlined_g
88CHECK-NEXT: dwarfdump-inl-test.h:7
89CHECK-NEXT: inlined_f
90CHECK-NEXT: dwarfdump-inl-test.cc:3
91CHECK-NEXT: main
Alexey Samsonov8ad418b2014-05-19 18:45:32 +000092CHECK-NEXT: dwarfdump-inl-test.cc:8
93
94CHECK: inlined_g
95CHECK-NEXT: dwarfdump-inl-test.h:7
96CHECK-NEXT: inlined_f
97CHECK-NEXT: dwarfdump-inl-test.cc:3
98CHECK-NEXT: main
99CHECK-NEXT: dwarfdump-inl-test.cc:8
100
101CHECK: inlined_f
102CHECK-NEXT: dwarfdump-inl-test.cc:3
103CHECK-NEXT: main
104CHECK-NEXT: dwarfdump-inl-test.cc:8
Alexey Samsonovef148af2013-04-05 09:22:24 +0000105
Will Dietzb7b1abe2013-10-30 20:27:17 +0000106CHECK: inlined_h
107CHECK-NEXT: dwarfdump-inl-test.h:3
108CHECK-NEXT: inlined_g
109CHECK-NEXT: dwarfdump-inl-test.h:7
110CHECK-NEXT: inlined_f
111CHECK-NEXT: dwarfdump-inl-test.cc:3
112CHECK-NEXT: main
Alexey Samsonov8ad418b2014-05-19 18:45:32 +0000113CHECK-NEXT: dwarfdump-inl-test.cc:8
Will Dietzb7b1abe2013-10-30 20:27:17 +0000114
Alexey Samsonov8ad418b2014-05-19 18:45:32 +0000115CHECK: C
116CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test3.cc:3
117
118CHECK: _Z3do1v
119CHECK-NEXT: /tmp/include{{[/\\]}}dwarfdump-test3-decl.h:7
120
121CHECK: _Z3do2v
122CHECK-NEXT: /tmp/dbginfo{{[/\\]}}include{{[/\\]}}dwarfdump-test3-decl2.h:1
Alexey Samsonov625b1092013-06-03 14:12:39 +0000123
Alexey Samsonov8c6e3242013-06-28 14:25:52 +0000124CHECK: main
125CHECK: _Z3inci
126CHECK: _Z3inci
Alexey Samsonov8175bc32013-06-28 08:15:40 +0000127
Alexey Samsonove0d2d7f2014-04-18 22:22:44 +0000128CHECK: main
129CHECK-NEXT: llvm-symbolizer-dwo-test.cc:11
130
David Blaikiedf69f1f2018-05-01 18:08:45 +0000131CHECK-NOT: local_mem_func
132CHECK: _ZZ2f1vEN3foo14local_mem_funcEv
133CHECK-NEXT: {{.*}}local-mem-func.cpp:3:0
134
Alexey Samsonov4dfa6812014-06-12 18:52:35 +0000135CHECK: main
136CHECK-NEXT: {{.*}}fission-ranges.cc:6
137
Alexey Samsonov740a7592014-06-12 23:58:49 +0000138CHECK: _ZN1S3bazEv
139CHECK-NEXT: {{.*}}arange-overlap.cc:6
140
David Blaikie4fc8e6f2016-04-22 21:32:59 +0000141DWO: _Z2f2v
142NODWO: {{^f2$}}
David Blaikiefe2090a2017-09-08 21:10:01 +0000143SPLIT-NEXT: {{.*}}split-dwarf-test.cpp
David Blaikie4fc8e6f2016-04-22 21:32:59 +0000144SPLIT-NEXT: main
David Blaikiefe2090a2017-09-08 21:10:01 +0000145SPLIT-NEXT: {{.*}}split-dwarf-test.cpp
Alexey Samsonov54543af2014-09-05 19:29:45 +0000146
David Blaikie4fc8e6f2016-04-22 21:32:59 +0000147SPLIT: _Z2f1v
David Blaikiefe2090a2017-09-08 21:10:01 +0000148SPLIT-NEXT: {{.*}}split-dwarf-test.cpp
Alexey Samsonov54543af2014-09-05 19:29:45 +0000149
Frederic Risscc55b732014-09-22 12:35:53 +0000150; func has been inlined into main by LTO. Check that the symbolizer is able
151; to resolve the cross-cu reference and retrieve func's name
152CHECK: func
153CHECK-NEXT: /tmp{{[/\\]}}cross-cu-inlining.c:16:3
154CHECK-NEXT: main
155CHECK-NEXT: /tmp{{[/\\]}}cross-cu-inlining.c:11:0
156
David Blaikie0025fa12017-05-20 03:32:49 +0000157CHECK: f2
David Blaikiefe2090a2017-09-08 21:10:01 +0000158CHECK-NEXT: split-dwarf-multiple-cu.cpp:3:3
David Blaikie0025fa12017-05-20 03:32:49 +0000159CHECK-NEXT: f3
David Blaikiefe2090a2017-09-08 21:10:01 +0000160CHECK-NEXT: split-dwarf-multiple-cu.cpp:6:0
David Blaikie0025fa12017-05-20 03:32:49 +0000161
David Blaikie9031fd92017-05-22 07:02:47 +0000162CHECK: f2
163CHECK-NEXT: split-dwarf-addr-object-relocation.cpp:3:3
164CHECK-NEXT: f3
165CHECK-NEXT: split-dwarf-addr-object-relocation.cpp:6:0
166
David Blaikie4cf772e2017-07-30 01:34:08 +0000167DWP: f2
168DWP-NEXT: split-dwarf-dwp.cpp:3:3
David Blaikie61dba572017-08-02 20:16:22 +0000169DWP-NEXT: main
170DWP-NEXT: split-dwarf-dwp.cpp:10:0
David Blaikie893c3462017-05-23 06:48:53 +0000171
Kuba Mracek10854a22017-08-15 21:02:17 +0000172RUN: echo "unexisting-file 0x1234" > %t.input2
173RUN: llvm-symbolizer < %t.input2 2>&1 | FileCheck %s --check-prefix=MISSING-FILE
Alexey Samsonova6c7bb02015-11-04 00:30:19 +0000174
Alexey Samsonovfa3207e2015-11-04 01:09:37 +0000175MISSING-FILE: LLVMSymbolizer: error reading file: {{[Nn]}}o such file or directory
Alexey Samsonov8175bc32013-06-28 08:15:40 +0000176
Kuba Mracek10854a22017-08-15 21:02:17 +0000177RUN: echo "%p/Inputs/macho-universal 0x1f84" > %t.input3
178RUN: llvm-symbolizer < %t.input3 | FileCheck %s --check-prefix=UNKNOWN-ARCH
Alexey Samsonov8175bc32013-06-28 08:15:40 +0000179
180UNKNOWN-ARCH-NOT: main
181UNKNOWN-ARCH: ??
182UNKNOWN-ARCH-NOT: main
Alexey Samsonov42c9ecb2013-12-24 19:33:22 +0000183
David Blaikie1e919432018-12-21 22:25:01 +0000184RUN: echo "0x40113f" > %t.input4
185RUN: echo "0x401020" >> %t.input4
Kuba Mracek10854a22017-08-15 21:02:17 +0000186RUN: llvm-symbolizer --obj %p/Inputs/dwarfdump-test.elf-x86-64 < %t.input4 \
Alexey Samsonov42c9ecb2013-12-24 19:33:22 +0000187RUN: | FileCheck %s --check-prefix=BINARY
188
189BINARY: main
190BINARY-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:16
191BINARY: _start
Ed Maste22939fa2014-01-16 17:25:12 +0000192
David Blaikie1e919432018-12-21 22:25:01 +0000193RUN: echo "0x401140" > %t.input5
194RUN: echo "0x401020" >> %t.input5
195RUN: echo "0x401120" >> %t.input5
Kuba Mracek10854a22017-08-15 21:02:17 +0000196RUN: llvm-symbolizer --obj %p/Inputs/llvm-symbolizer-test.elf-x86-64 < %t.input5 \
Ed Maste22939fa2014-01-16 17:25:12 +0000197RUN: | FileCheck %s --check-prefix=BINARY_C
198
199BINARY_C: main
200BINARY_C-NEXT: /tmp/dbginfo{{[/\\]}}llvm-symbolizer-test.c:10
201BINARY_C: _start
202BINARY_C: {{g$}}
Alexey Samsonov12c9f922014-02-26 13:10:01 +0000203
Kuba Mracek10854a22017-08-15 21:02:17 +0000204RUN: echo "0x1f1" > %t.input6
205RUN: llvm-symbolizer --obj %p/Inputs/shared-object-stripped.elf-i386 < %t.input6 \
Alexey Samsonov12c9f922014-02-26 13:10:01 +0000206RUN: | FileCheck %s --check-prefix=STRIPPED
207
208STRIPPED: global_func
Alexey Samsonovbf6e3f92014-05-17 00:07:48 +0000209
Kuba Mracek10854a22017-08-15 21:02:17 +0000210RUN: echo "%p/Inputs/dwarfdump-test4.elf-x86-64 0x62c" > %t.input7
211RUN: llvm-symbolizer --functions=short --demangle=false < %t.input7 \
Alexey Samsonovbf6e3f92014-05-17 00:07:48 +0000212RUN: | FileCheck %s --check-prefix=SHORT_FUNCTION_NAME
Dmitry Venikov2eebdab2019-01-16 07:05:58 +0000213RUN: llvm-symbolizer --functions=short -C=false < %t.input7 \
214RUN: | FileCheck %s --check-prefix=SHORT_FUNCTION_NAME
Alexey Samsonovbf6e3f92014-05-17 00:07:48 +0000215
216SHORT_FUNCTION_NAME-NOT: _Z1cv