blob: f0db8f4b921f880ca1a76a6f809ebed9cdce8ed2 [file] [log] [blame]
Alexey Samsonovc6ee5832013-04-05 08:30:13 +00001RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x400559" > %t.input
Alexey Samsonov3e9997f2013-08-14 17:09:30 +00002RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64.debuglink 0x400559" >> %t.input
Alexey Samsonov5239d582013-06-04 07:57:38 +00003RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x400436" >> %t.input
Alexey Samsonove3218792014-05-19 18:45:32 +00004RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x400528" >> %t.input
5RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x400586" >> %t.input
6RUN: echo "%p/Inputs/dwarfdump-test2.elf-x86-64 0x4004e8" >> %t.input
7RUN: echo "%p/Inputs/dwarfdump-test2.elf-x86-64 0x4004f4" >> %t.input
Alexey Samsonovc6ee5832013-04-05 08:30:13 +00008RUN: echo "%p/Inputs/dwarfdump-test4.elf-x86-64 0x62c" >> %t.input
David Blaikie3a7ce252014-09-19 17:03:16 +00009RUN: echo "%p/Inputs/dwarfdump-inl-test.elf-x86-64 0x8dc" >> %t.input
10RUN: echo "%p/Inputs/dwarfdump-inl-test.elf-x86-64 0xa05" >> %t.input
11RUN: echo "%p/Inputs/dwarfdump-inl-test.elf-x86-64 0x987" >> %t.input
Will Dietzb67a7142013-10-30 20:27:17 +000012RUN: echo "%p/Inputs/dwarfdump-inl-test.high_pc.elf-x86-64 0x568" >> %t.input
Alexey Samsonove3218792014-05-19 18:45:32 +000013RUN: echo "\"%p/Inputs/dwarfdump-test3.elf-x86-64 space\" 0x640" >> %t.input
Chandler Carrutha6d5e3e2013-04-08 10:07:50 +000014RUN: echo "\"%p/Inputs/dwarfdump-test3.elf-x86-64 space\" 0x633" >> %t.input
Alexey Samsonove3218792014-05-19 18:45:32 +000015RUN: echo "\"%p/Inputs/dwarfdump-test3.elf-x86-64 space\" 0x62d" >> %t.input
Alexey Samsonov2ca65362013-06-28 08:15:40 +000016RUN: echo "%p/Inputs/macho-universal 0x1f84" >> %t.input
17RUN: echo "%p/Inputs/macho-universal:i386 0x1f67" >> %t.input
18RUN: echo "%p/Inputs/macho-universal:x86_64 0x100000f05" >> %t.input
Alexey Samsonov5c39fdf2014-04-18 22:22:44 +000019RUN: echo "%p/Inputs/llvm-symbolizer-dwo-test 0x400514" >> %t.input
Alexey Samsonovf0e40342014-06-12 18:52:35 +000020RUN: echo "%p/Inputs/fission-ranges.elf-x86_64 0x720" >> %t.input
Alexey Samsonov0670cfa2014-06-12 23:58:49 +000021RUN: echo "%p/Inputs/arange-overlap.elf-x86_64 0x714" >> %t.input
Alexey Samsonovd3e12132014-09-05 19:29:45 +000022RUN: cp %p/Inputs/split-dwarf-test.dwo %T
David Blaikie9a4f3cb2016-04-22 21:32:59 +000023RUN: echo "%p/Inputs/split-dwarf-test 0x4005d4" >> %t.input
24RUN: echo "%p/Inputs/split-dwarf-test 0x4005c4" >> %t.input
Frederic Riss58ed53c2014-09-22 12:35:53 +000025RUN: echo "%p/Inputs/cross-cu-inlining.x86_64-macho.o 0x17" >> %t.input
David Blaikie8d039d42017-05-20 03:32:49 +000026RUN: cp %p/Inputs/split-dwarf-multiple-cu.dwo %T
27RUN: echo "%p/Inputs/split-dwarf-multiple-cu.o 0x4" >> %t.input
David Blaikied2f3a942017-05-22 07:02:47 +000028RUN: cp %p/Inputs/split-dwarf-addr-object-relocation.dwo %T
29RUN: echo "%p/Inputs/split-dwarf-addr-object-relocation.o 0x14" >> %t.input
Alexey Samsonovc6ee5832013-04-05 08:30:13 +000030
Alexey Samsonovcd014722014-05-17 00:07:48 +000031RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
David Blaikie9a4f3cb2016-04-22 21:32:59 +000032RUN: --default-arch=i386 < %t.input | FileCheck --check-prefix=CHECK --check-prefix=SPLIT --check-prefix=DWO %s
33
34Ensure we get the same results in the absence of gmlt-like data in the executable but the presence of a .dwo file
35
36RUN: echo "%p/Inputs/split-dwarf-test-nogmlt 0x4005d4" >> %t.input
37RUN: echo "%p/Inputs/split-dwarf-test-nogmlt 0x4005c4" >> %t.input
38RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
39RUN: --default-arch=i386 < %t.input | FileCheck --check-prefix=SPLIT --check-prefix=DWO %s
40
41Ensure we get gmlt like results in the absence of a .dwo file but the presence of gmlt-like data in the executable
42
43RUN: rm %T/split-dwarf-test.dwo
44RUN: echo "%p/Inputs/split-dwarf-test 0x4005d4" >> %t.input
45RUN: echo "%p/Inputs/split-dwarf-test 0x4005c4" >> %t.input
46RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \
47RUN: --default-arch=i386 < %t.input | FileCheck --check-prefix=SPLIT --check-prefix=NODWO %s
Alexey Samsonovc6ee5832013-04-05 08:30:13 +000048
Alexey Samsonovc6ee5832013-04-05 08:30:13 +000049CHECK: main
50CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:16
Alexey Samsonov5239d582013-06-04 07:57:38 +000051
Alexey Samsonov3e9997f2013-08-14 17:09:30 +000052CHECK: main
53CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:16
54
Alexey Samsonov5239d582013-06-04 07:57:38 +000055CHECK: _start
56
Alexey Samsonove3218792014-05-19 18:45:32 +000057CHECK: _Z1fii
58CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:11
59
60CHECK: DummyClass
61CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:4
62
63CHECK: a
64CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test2-helper.cc:2
65
66CHECK: main
67CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test2-main.cc:4
68
Alexey Samsonovc6ee5832013-04-05 08:30:13 +000069CHECK: _Z1cv
70CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test4-part1.cc:2
Alexey Samsonov5239d582013-06-04 07:57:38 +000071
Alexey Samsonovc6ee5832013-04-05 08:30:13 +000072CHECK: inlined_h
73CHECK-NEXT: dwarfdump-inl-test.h:2
74CHECK-NEXT: inlined_g
75CHECK-NEXT: dwarfdump-inl-test.h:7
76CHECK-NEXT: inlined_f
77CHECK-NEXT: dwarfdump-inl-test.cc:3
78CHECK-NEXT: main
Alexey Samsonove3218792014-05-19 18:45:32 +000079CHECK-NEXT: dwarfdump-inl-test.cc:8
80
81CHECK: inlined_g
82CHECK-NEXT: dwarfdump-inl-test.h:7
83CHECK-NEXT: inlined_f
84CHECK-NEXT: dwarfdump-inl-test.cc:3
85CHECK-NEXT: main
86CHECK-NEXT: dwarfdump-inl-test.cc:8
87
88CHECK: inlined_f
89CHECK-NEXT: dwarfdump-inl-test.cc:3
90CHECK-NEXT: main
91CHECK-NEXT: dwarfdump-inl-test.cc:8
Alexey Samsonovd2069322013-04-05 09:22:24 +000092
Will Dietzb67a7142013-10-30 20:27:17 +000093CHECK: inlined_h
94CHECK-NEXT: dwarfdump-inl-test.h:3
95CHECK-NEXT: inlined_g
96CHECK-NEXT: dwarfdump-inl-test.h:7
97CHECK-NEXT: inlined_f
98CHECK-NEXT: dwarfdump-inl-test.cc:3
99CHECK-NEXT: main
Alexey Samsonove3218792014-05-19 18:45:32 +0000100CHECK-NEXT: dwarfdump-inl-test.cc:8
Will Dietzb67a7142013-10-30 20:27:17 +0000101
Alexey Samsonove3218792014-05-19 18:45:32 +0000102CHECK: C
103CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test3.cc:3
104
105CHECK: _Z3do1v
106CHECK-NEXT: /tmp/include{{[/\\]}}dwarfdump-test3-decl.h:7
107
108CHECK: _Z3do2v
109CHECK-NEXT: /tmp/dbginfo{{[/\\]}}include{{[/\\]}}dwarfdump-test3-decl2.h:1
Alexey Samsonov213527d2013-06-03 14:12:39 +0000110
Alexey Samsonov73233832013-06-28 14:25:52 +0000111CHECK: main
112CHECK: _Z3inci
113CHECK: _Z3inci
Alexey Samsonov2ca65362013-06-28 08:15:40 +0000114
Alexey Samsonov5c39fdf2014-04-18 22:22:44 +0000115CHECK: main
116CHECK-NEXT: llvm-symbolizer-dwo-test.cc:11
117
Alexey Samsonovf0e40342014-06-12 18:52:35 +0000118CHECK: main
119CHECK-NEXT: {{.*}}fission-ranges.cc:6
120
Alexey Samsonov0670cfa2014-06-12 23:58:49 +0000121CHECK: _ZN1S3bazEv
122CHECK-NEXT: {{.*}}arange-overlap.cc:6
123
David Blaikie9a4f3cb2016-04-22 21:32:59 +0000124DWO: _Z2f2v
125NODWO: {{^f2$}}
126SPLIT-NEXT: {{.*}}split-dwarf-test.cc
127SPLIT-NEXT: main
128SPLIT-NEXT: {{.*}}split-dwarf-test.cc
Alexey Samsonovd3e12132014-09-05 19:29:45 +0000129
David Blaikie9a4f3cb2016-04-22 21:32:59 +0000130SPLIT: _Z2f1v
131SPLIT-NEXT: {{.*}}split-dwarf-test.cc
Alexey Samsonovd3e12132014-09-05 19:29:45 +0000132
Frederic Riss58ed53c2014-09-22 12:35:53 +0000133; func has been inlined into main by LTO. Check that the symbolizer is able
134; to resolve the cross-cu reference and retrieve func's name
135CHECK: func
136CHECK-NEXT: /tmp{{[/\\]}}cross-cu-inlining.c:16:3
137CHECK-NEXT: main
138CHECK-NEXT: /tmp{{[/\\]}}cross-cu-inlining.c:11:0
139
David Blaikie8d039d42017-05-20 03:32:49 +0000140CHECK: f2
141CHECK-NEXT: b.cpp:3:3
142CHECK-NEXT: f3
143CHECK-NEXT: b.cpp:6:0
144
David Blaikied2f3a942017-05-22 07:02:47 +0000145CHECK: f2
146CHECK-NEXT: split-dwarf-addr-object-relocation.cpp:3:3
147CHECK-NEXT: f3
148CHECK-NEXT: split-dwarf-addr-object-relocation.cpp:6:0
149
Alexey Samsonov213527d2013-06-03 14:12:39 +0000150RUN: echo "unexisting-file 0x1234" > %t.input2
Alexey Samsonovb0742312015-11-04 00:30:19 +0000151RUN: llvm-symbolizer < %t.input2 2>&1 | FileCheck %s --check-prefix=MISSING-FILE
152
Alexey Samsonov24519d92015-11-04 01:09:37 +0000153MISSING-FILE: LLVMSymbolizer: error reading file: {{[Nn]}}o such file or directory
Alexey Samsonov2ca65362013-06-28 08:15:40 +0000154
155RUN: echo "%p/Inputs/macho-universal 0x1f84" > %t.input3
156RUN: llvm-symbolizer < %t.input3 | FileCheck %s --check-prefix=UNKNOWN-ARCH
157
158UNKNOWN-ARCH-NOT: main
159UNKNOWN-ARCH: ??
160UNKNOWN-ARCH-NOT: main
Alexey Samsonov60e59e22013-12-24 19:33:22 +0000161
162RUN: echo "0x400559" > %t.input4
163RUN: echo "0x400436" >> %t.input4
164RUN: llvm-symbolizer --obj %p/Inputs/dwarfdump-test.elf-x86-64 < %t.input4 \
165RUN: | FileCheck %s --check-prefix=BINARY
166
167BINARY: main
168BINARY-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:16
169BINARY: _start
Ed Masteef6fed72014-01-16 17:25:12 +0000170
171RUN: echo "0x400720" > %t.input5
172RUN: echo "0x4004a0" >> %t.input5
173RUN: echo "0x4006f0" >> %t.input5
174RUN: llvm-symbolizer --obj %p/Inputs/llvm-symbolizer-test.elf-x86-64 < %t.input5 \
175RUN: | FileCheck %s --check-prefix=BINARY_C
176
177BINARY_C: main
178BINARY_C-NEXT: /tmp/dbginfo{{[/\\]}}llvm-symbolizer-test.c:10
179BINARY_C: _start
180BINARY_C: {{g$}}
Alexey Samsonova5f07682014-02-26 13:10:01 +0000181
182RUN: echo "0x1f1" > %t.input6
183RUN: llvm-symbolizer --obj %p/Inputs/shared-object-stripped.elf-i386 < %t.input6 \
184RUN: | FileCheck %s --check-prefix=STRIPPED
185
186STRIPPED: global_func
Alexey Samsonovcd014722014-05-17 00:07:48 +0000187
188RUN: echo "%p/Inputs/dwarfdump-test4.elf-x86-64 0x62c" > %t.input7
Alexey Samsonovf3ecfd32015-10-26 20:12:29 +0000189RUN: llvm-symbolizer --functions=short --demangle=false < %t.input7 \
Alexey Samsonovcd014722014-05-17 00:07:48 +0000190RUN: | FileCheck %s --check-prefix=SHORT_FUNCTION_NAME
191
192SHORT_FUNCTION_NAME-NOT: _Z1cv