blob: 1fcc61cbdf97ed9c640d8be32409e94f20989e59 [file] [log] [blame]
David Blaikiebd20f842017-09-08 21:10:01 +00001RUN: rm -rf %t
2RUN: mkdir -p %t
Alexey Samsonovc6ee5832013-04-05 08:30:13 +00003RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x400559" > %t.input
Alexey Samsonov3e9997f2013-08-14 17:09:30 +00004RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64.debuglink 0x400559" >> %t.input
Kuba Mracekc0301b22017-08-15 21:02:17 +00005RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x400436" >> %t.input
6RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x400528" >> %t.input
7RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x400586" >> %t.input
8RUN: 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 Blaikiebd20f842017-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 Mracekc0301b22017-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
23RUN: echo "%p/Inputs/fission-ranges.elf-x86_64 0x720" >> %t.input
24RUN: echo "%p/Inputs/arange-overlap.elf-x86_64 0x714" >> %t.input
David Blaikiebd20f842017-09-08 21:10:01 +000025RUN: cp %p/Inputs/split-dwarf-test.dwo %t
26RUN: echo "%p/Inputs/split-dwarf-test 0x400504" >> %t.input
27RUN: echo "%p/Inputs/split-dwarf-test 0x4004f4" >> %t.input
Kuba Mracekc0301b22017-08-15 21:02:17 +000028RUN: echo "%p/Inputs/cross-cu-inlining.x86_64-macho.o 0x17" >> %t.input
David Blaikiebd20f842017-09-08 21:10:01 +000029RUN: cp %p/Inputs/split-dwarf-multiple-cu.dwo %t
Kuba Mracekc0301b22017-08-15 21:02:17 +000030RUN: echo "%p/Inputs/split-dwarf-multiple-cu.o 0x4" >> %t.input
David Blaikiebd20f842017-09-08 21:10:01 +000031RUN: cp %p/Inputs/split-dwarf-addr-object-relocation.dwo %t
Kuba Mracekc0301b22017-08-15 21:02:17 +000032RUN: echo "%p/Inputs/split-dwarf-addr-object-relocation.o 0x14" >> %t.input
David Blaikiebd20f842017-09-08 21:10:01 +000033RUN: cp %p/Inputs/split-dwarf-dwp.o %t
34RUN: cp %p/Inputs/split-dwarf-dwp.o.dwp %t
35RUN: echo "%t/split-dwarf-dwp.o 0x4" >> %t.input
Alexey Samsonovc6ee5832013-04-05 08:30:13 +000036
David Blaikiebd20f842017-09-08 21:10:01 +000037RUN: cd %t
Alexey Samsonovcd014722014-05-17 00:07:48 +000038RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
Kuba Mracekc0301b22017-08-15 21:02:17 +000039RUN: --default-arch=i386 < %t.input | FileCheck --check-prefix=CHECK --check-prefix=SPLIT --check-prefix=DWO %s
David Blaikie9a4f3cb2016-04-22 21:32:59 +000040
41Ensure we get the same results in the absence of gmlt-like data in the executable but the presence of a .dwo file
42
David Blaikiebd20f842017-09-08 21:10:01 +000043RUN: echo "%p/Inputs/split-dwarf-test-nogmlt 0x400504" >> %t.input
44RUN: echo "%p/Inputs/split-dwarf-test-nogmlt 0x4004f4" >> %t.input
David Blaikie9a4f3cb2016-04-22 21:32:59 +000045RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
Kuba Mracekc0301b22017-08-15 21:02:17 +000046RUN: --default-arch=i386 < %t.input | FileCheck --check-prefix=SPLIT --check-prefix=DWO %s
David Blaikie9a4f3cb2016-04-22 21:32:59 +000047
48Ensure we get gmlt like results in the absence of a .dwo file but the presence of gmlt-like data in the executable
49
David Blaikiebd20f842017-09-08 21:10:01 +000050RUN: rm %t/split-dwarf-test.dwo
51RUN: echo "%p/Inputs/split-dwarf-test 0x400504" >> %t.input
52RUN: echo "%p/Inputs/split-dwarf-test 0x4004f4" >> %t.input
David Blaikie9a4f3cb2016-04-22 21:32:59 +000053RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
Kuba Mracekc0301b22017-08-15 21:02:17 +000054RUN: --default-arch=i386 < %t.input | FileCheck --check-prefix=SPLIT --check-prefix=NODWO %s
Alexey Samsonovc6ee5832013-04-05 08:30:13 +000055
David Blaikiebd20f842017-09-08 21:10:01 +000056RUN: cp %p/Inputs/split-dwarf-dwp.o %t/split-dwarf-dwp-different-name.o
57RUN: echo "%t/split-dwarf-dwp-different-name.o 0x54" > %t.input
David Blaikiee5adb682017-07-30 01:34:08 +000058RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
59RUN: --default-arch=i386 --dwp=%p/Inputs/split-dwarf-dwp.o.dwp < %t.input | FileCheck --check-prefix=DWP %s
60
Alexey Samsonovc6ee5832013-04-05 08:30:13 +000061CHECK: main
62CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:16
Alexey Samsonov5239d582013-06-04 07:57:38 +000063
Alexey Samsonov3e9997f2013-08-14 17:09:30 +000064CHECK: main
65CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:16
66
Alexey Samsonov5239d582013-06-04 07:57:38 +000067CHECK: _start
68
Alexey Samsonove3218792014-05-19 18:45:32 +000069CHECK: _Z1fii
70CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:11
71
72CHECK: DummyClass
73CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:4
74
75CHECK: a
76CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test2-helper.cc:2
77
78CHECK: main
79CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test2-main.cc:4
80
Alexey Samsonovc6ee5832013-04-05 08:30:13 +000081CHECK: _Z1cv
82CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test4-part1.cc:2
Alexey Samsonov5239d582013-06-04 07:57:38 +000083
Alexey Samsonovc6ee5832013-04-05 08:30:13 +000084CHECK: inlined_h
85CHECK-NEXT: dwarfdump-inl-test.h:2
86CHECK-NEXT: inlined_g
87CHECK-NEXT: dwarfdump-inl-test.h:7
88CHECK-NEXT: inlined_f
89CHECK-NEXT: dwarfdump-inl-test.cc:3
90CHECK-NEXT: main
Alexey Samsonove3218792014-05-19 18:45:32 +000091CHECK-NEXT: dwarfdump-inl-test.cc:8
92
93CHECK: inlined_g
94CHECK-NEXT: dwarfdump-inl-test.h:7
95CHECK-NEXT: inlined_f
96CHECK-NEXT: dwarfdump-inl-test.cc:3
97CHECK-NEXT: main
98CHECK-NEXT: dwarfdump-inl-test.cc:8
99
100CHECK: inlined_f
101CHECK-NEXT: dwarfdump-inl-test.cc:3
102CHECK-NEXT: main
103CHECK-NEXT: dwarfdump-inl-test.cc:8
Alexey Samsonovd2069322013-04-05 09:22:24 +0000104
Will Dietzb67a7142013-10-30 20:27:17 +0000105CHECK: inlined_h
106CHECK-NEXT: dwarfdump-inl-test.h:3
107CHECK-NEXT: inlined_g
108CHECK-NEXT: dwarfdump-inl-test.h:7
109CHECK-NEXT: inlined_f
110CHECK-NEXT: dwarfdump-inl-test.cc:3
111CHECK-NEXT: main
Alexey Samsonove3218792014-05-19 18:45:32 +0000112CHECK-NEXT: dwarfdump-inl-test.cc:8
Will Dietzb67a7142013-10-30 20:27:17 +0000113
Alexey Samsonove3218792014-05-19 18:45:32 +0000114CHECK: C
115CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test3.cc:3
116
117CHECK: _Z3do1v
118CHECK-NEXT: /tmp/include{{[/\\]}}dwarfdump-test3-decl.h:7
119
120CHECK: _Z3do2v
121CHECK-NEXT: /tmp/dbginfo{{[/\\]}}include{{[/\\]}}dwarfdump-test3-decl2.h:1
Alexey Samsonov213527d2013-06-03 14:12:39 +0000122
Alexey Samsonov73233832013-06-28 14:25:52 +0000123CHECK: main
124CHECK: _Z3inci
125CHECK: _Z3inci
Alexey Samsonov2ca65362013-06-28 08:15:40 +0000126
Alexey Samsonov5c39fdf2014-04-18 22:22:44 +0000127CHECK: main
128CHECK-NEXT: llvm-symbolizer-dwo-test.cc:11
129
Alexey Samsonovf0e40342014-06-12 18:52:35 +0000130CHECK: main
131CHECK-NEXT: {{.*}}fission-ranges.cc:6
132
Alexey Samsonov0670cfa2014-06-12 23:58:49 +0000133CHECK: _ZN1S3bazEv
134CHECK-NEXT: {{.*}}arange-overlap.cc:6
135
David Blaikie9a4f3cb2016-04-22 21:32:59 +0000136DWO: _Z2f2v
137NODWO: {{^f2$}}
David Blaikiebd20f842017-09-08 21:10:01 +0000138SPLIT-NEXT: {{.*}}split-dwarf-test.cpp
David Blaikie9a4f3cb2016-04-22 21:32:59 +0000139SPLIT-NEXT: main
David Blaikiebd20f842017-09-08 21:10:01 +0000140SPLIT-NEXT: {{.*}}split-dwarf-test.cpp
Alexey Samsonovd3e12132014-09-05 19:29:45 +0000141
David Blaikie9a4f3cb2016-04-22 21:32:59 +0000142SPLIT: _Z2f1v
David Blaikiebd20f842017-09-08 21:10:01 +0000143SPLIT-NEXT: {{.*}}split-dwarf-test.cpp
Alexey Samsonovd3e12132014-09-05 19:29:45 +0000144
Frederic Riss58ed53c2014-09-22 12:35:53 +0000145; func has been inlined into main by LTO. Check that the symbolizer is able
146; to resolve the cross-cu reference and retrieve func's name
147CHECK: func
148CHECK-NEXT: /tmp{{[/\\]}}cross-cu-inlining.c:16:3
149CHECK-NEXT: main
150CHECK-NEXT: /tmp{{[/\\]}}cross-cu-inlining.c:11:0
151
David Blaikie8d039d42017-05-20 03:32:49 +0000152CHECK: f2
David Blaikiebd20f842017-09-08 21:10:01 +0000153CHECK-NEXT: split-dwarf-multiple-cu.cpp:3:3
David Blaikie8d039d42017-05-20 03:32:49 +0000154CHECK-NEXT: f3
David Blaikiebd20f842017-09-08 21:10:01 +0000155CHECK-NEXT: split-dwarf-multiple-cu.cpp:6:0
David Blaikie8d039d42017-05-20 03:32:49 +0000156
David Blaikied2f3a942017-05-22 07:02:47 +0000157CHECK: f2
158CHECK-NEXT: split-dwarf-addr-object-relocation.cpp:3:3
159CHECK-NEXT: f3
160CHECK-NEXT: split-dwarf-addr-object-relocation.cpp:6:0
161
David Blaikiee5adb682017-07-30 01:34:08 +0000162DWP: f2
163DWP-NEXT: split-dwarf-dwp.cpp:3:3
David Blaikie22dc4472017-08-02 20:16:22 +0000164DWP-NEXT: main
165DWP-NEXT: split-dwarf-dwp.cpp:10:0
David Blaikie15d85fc2017-05-23 06:48:53 +0000166
Kuba Mracekc0301b22017-08-15 21:02:17 +0000167RUN: echo "unexisting-file 0x1234" > %t.input2
168RUN: llvm-symbolizer < %t.input2 2>&1 | FileCheck %s --check-prefix=MISSING-FILE
Alexey Samsonovb0742312015-11-04 00:30:19 +0000169
Alexey Samsonov24519d92015-11-04 01:09:37 +0000170MISSING-FILE: LLVMSymbolizer: error reading file: {{[Nn]}}o such file or directory
Alexey Samsonov2ca65362013-06-28 08:15:40 +0000171
Kuba Mracekc0301b22017-08-15 21:02:17 +0000172RUN: echo "%p/Inputs/macho-universal 0x1f84" > %t.input3
173RUN: llvm-symbolizer < %t.input3 | FileCheck %s --check-prefix=UNKNOWN-ARCH
Alexey Samsonov2ca65362013-06-28 08:15:40 +0000174
175UNKNOWN-ARCH-NOT: main
176UNKNOWN-ARCH: ??
177UNKNOWN-ARCH-NOT: main
Alexey Samsonov60e59e22013-12-24 19:33:22 +0000178
Kuba Mracekc0301b22017-08-15 21:02:17 +0000179RUN: echo "0x400559" > %t.input4
180RUN: echo "0x400436" >> %t.input4
181RUN: llvm-symbolizer --obj %p/Inputs/dwarfdump-test.elf-x86-64 < %t.input4 \
Alexey Samsonov60e59e22013-12-24 19:33:22 +0000182RUN: | FileCheck %s --check-prefix=BINARY
183
184BINARY: main
185BINARY-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:16
186BINARY: _start
Ed Masteef6fed72014-01-16 17:25:12 +0000187
Kuba Mracekc0301b22017-08-15 21:02:17 +0000188RUN: echo "0x400720" > %t.input5
189RUN: echo "0x4004a0" >> %t.input5
190RUN: echo "0x4006f0" >> %t.input5
191RUN: llvm-symbolizer --obj %p/Inputs/llvm-symbolizer-test.elf-x86-64 < %t.input5 \
Ed Masteef6fed72014-01-16 17:25:12 +0000192RUN: | FileCheck %s --check-prefix=BINARY_C
193
194BINARY_C: main
195BINARY_C-NEXT: /tmp/dbginfo{{[/\\]}}llvm-symbolizer-test.c:10
196BINARY_C: _start
197BINARY_C: {{g$}}
Alexey Samsonova5f07682014-02-26 13:10:01 +0000198
Kuba Mracekc0301b22017-08-15 21:02:17 +0000199RUN: echo "0x1f1" > %t.input6
200RUN: llvm-symbolizer --obj %p/Inputs/shared-object-stripped.elf-i386 < %t.input6 \
Alexey Samsonova5f07682014-02-26 13:10:01 +0000201RUN: | FileCheck %s --check-prefix=STRIPPED
202
203STRIPPED: global_func
Alexey Samsonovcd014722014-05-17 00:07:48 +0000204
Kuba Mracekc0301b22017-08-15 21:02:17 +0000205RUN: echo "%p/Inputs/dwarfdump-test4.elf-x86-64 0x62c" > %t.input7
206RUN: llvm-symbolizer --functions=short --demangle=false < %t.input7 \
Alexey Samsonovcd014722014-05-17 00:07:48 +0000207RUN: | FileCheck %s --check-prefix=SHORT_FUNCTION_NAME
208
209SHORT_FUNCTION_NAME-NOT: _Z1cv