David Blaikie | fe2090a | 2017-09-08 21:10:01 +0000 | [diff] [blame] | 1 | RUN: rm -rf %t |
| 2 | RUN: mkdir -p %t |
David Blaikie | 1e91943 | 2018-12-21 22:25:01 +0000 | [diff] [blame] | 3 | RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x40113f" > %t.input |
| 4 | RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64.debuglink 0x40113f" >> %t.input |
| 5 | RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x401020" >> %t.input |
| 6 | RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x40110e" >> %t.input |
| 7 | RUN: echo "%p/Inputs/dwarfdump-test.elf-x86-64 0x401160" >> %t.input |
Kuba Mracek | 10854a2 | 2017-08-15 21:02:17 +0000 | [diff] [blame] | 8 | RUN: echo "%p/Inputs/dwarfdump-test2.elf-x86-64 0x4004e8" >> %t.input |
| 9 | RUN: echo "%p/Inputs/dwarfdump-test2.elf-x86-64 0x4004f4" >> %t.input |
| 10 | RUN: echo "%p/Inputs/dwarfdump-test4.elf-x86-64 0x62c" >> %t.input |
| 11 | RUN: echo "%p/Inputs/dwarfdump-inl-test.elf-x86-64 0x8dc" >> %t.input |
| 12 | RUN: echo "%p/Inputs/dwarfdump-inl-test.elf-x86-64 0xa05" >> %t.input |
| 13 | RUN: echo "%p/Inputs/dwarfdump-inl-test.elf-x86-64 0x987" >> %t.input |
| 14 | RUN: echo "%p/Inputs/dwarfdump-inl-test.high_pc.elf-x86-64 0x568" >> %t.input |
David Blaikie | fe2090a | 2017-09-08 21:10:01 +0000 | [diff] [blame] | 15 | RUN: cp "%p/Inputs/dwarfdump-test3.elf-x86-64-space" "%t/dwarfdump-test3.elf-x86-64 space" |
| 16 | RUN: echo "\"%t/dwarfdump-test3.elf-x86-64 space\" 0x640" >> %t.input |
| 17 | RUN: echo "\"%t/dwarfdump-test3.elf-x86-64 space\" 0x633" >> %t.input |
| 18 | RUN: echo "\"%t/dwarfdump-test3.elf-x86-64 space\" 0x62d" >> %t.input |
Kuba Mracek | 10854a2 | 2017-08-15 21:02:17 +0000 | [diff] [blame] | 19 | RUN: echo "%p/Inputs/macho-universal 0x1f84" >> %t.input |
| 20 | RUN: echo "%p/Inputs/macho-universal:i386 0x1f67" >> %t.input |
| 21 | RUN: echo "%p/Inputs/macho-universal:x86_64 0x100000f05" >> %t.input |
| 22 | RUN: echo "%p/Inputs/llvm-symbolizer-dwo-test 0x400514" >> %t.input |
David Blaikie | df69f1f | 2018-05-01 18:08:45 +0000 | [diff] [blame] | 23 | RUN: echo "%p/Inputs/llvm-symbolizer-local-mem-func-gcc.elf-x86-64 0x61a" >> %t.input |
Kuba Mracek | 10854a2 | 2017-08-15 21:02:17 +0000 | [diff] [blame] | 24 | RUN: echo "%p/Inputs/fission-ranges.elf-x86_64 0x720" >> %t.input |
| 25 | RUN: echo "%p/Inputs/arange-overlap.elf-x86_64 0x714" >> %t.input |
David Blaikie | fe2090a | 2017-09-08 21:10:01 +0000 | [diff] [blame] | 26 | RUN: cp %p/Inputs/split-dwarf-test.dwo %t |
| 27 | RUN: echo "%p/Inputs/split-dwarf-test 0x400504" >> %t.input |
| 28 | RUN: echo "%p/Inputs/split-dwarf-test 0x4004f4" >> %t.input |
Kuba Mracek | 10854a2 | 2017-08-15 21:02:17 +0000 | [diff] [blame] | 29 | RUN: echo "%p/Inputs/cross-cu-inlining.x86_64-macho.o 0x17" >> %t.input |
David Blaikie | fe2090a | 2017-09-08 21:10:01 +0000 | [diff] [blame] | 30 | RUN: cp %p/Inputs/split-dwarf-multiple-cu.dwo %t |
Kuba Mracek | 10854a2 | 2017-08-15 21:02:17 +0000 | [diff] [blame] | 31 | RUN: echo "%p/Inputs/split-dwarf-multiple-cu.o 0x4" >> %t.input |
David Blaikie | fe2090a | 2017-09-08 21:10:01 +0000 | [diff] [blame] | 32 | RUN: cp %p/Inputs/split-dwarf-addr-object-relocation.dwo %t |
Kuba Mracek | 10854a2 | 2017-08-15 21:02:17 +0000 | [diff] [blame] | 33 | RUN: echo "%p/Inputs/split-dwarf-addr-object-relocation.o 0x14" >> %t.input |
David Blaikie | fe2090a | 2017-09-08 21:10:01 +0000 | [diff] [blame] | 34 | RUN: cp %p/Inputs/split-dwarf-dwp.o %t |
| 35 | RUN: cp %p/Inputs/split-dwarf-dwp.o.dwp %t |
| 36 | RUN: echo "%t/split-dwarf-dwp.o 0x4" >> %t.input |
Alexey Samsonov | 1c4d286 | 2013-04-05 08:30:13 +0000 | [diff] [blame] | 37 | |
David Blaikie | fe2090a | 2017-09-08 21:10:01 +0000 | [diff] [blame] | 38 | RUN: cd %t |
Alexey Samsonov | bf6e3f9 | 2014-05-17 00:07:48 +0000 | [diff] [blame] | 39 | RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \ |
Kuba Mracek | 10854a2 | 2017-08-15 21:02:17 +0000 | [diff] [blame] | 40 | RUN: --default-arch=i386 < %t.input | FileCheck --check-prefix=CHECK --check-prefix=SPLIT --check-prefix=DWO %s |
David Blaikie | 4fc8e6f | 2016-04-22 21:32:59 +0000 | [diff] [blame] | 41 | |
| 42 | Ensure we get the same results in the absence of gmlt-like data in the executable but the presence of a .dwo file |
| 43 | |
David Blaikie | fe2090a | 2017-09-08 21:10:01 +0000 | [diff] [blame] | 44 | RUN: echo "%p/Inputs/split-dwarf-test-nogmlt 0x400504" >> %t.input |
| 45 | RUN: echo "%p/Inputs/split-dwarf-test-nogmlt 0x4004f4" >> %t.input |
David Blaikie | 4fc8e6f | 2016-04-22 21:32:59 +0000 | [diff] [blame] | 46 | RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \ |
Kuba Mracek | 10854a2 | 2017-08-15 21:02:17 +0000 | [diff] [blame] | 47 | RUN: --default-arch=i386 < %t.input | FileCheck --check-prefix=SPLIT --check-prefix=DWO %s |
David Blaikie | 4fc8e6f | 2016-04-22 21:32:59 +0000 | [diff] [blame] | 48 | |
| 49 | Ensure we get gmlt like results in the absence of a .dwo file but the presence of gmlt-like data in the executable |
| 50 | |
David Blaikie | fe2090a | 2017-09-08 21:10:01 +0000 | [diff] [blame] | 51 | RUN: rm %t/split-dwarf-test.dwo |
| 52 | RUN: echo "%p/Inputs/split-dwarf-test 0x400504" >> %t.input |
| 53 | RUN: echo "%p/Inputs/split-dwarf-test 0x4004f4" >> %t.input |
David Blaikie | 4fc8e6f | 2016-04-22 21:32:59 +0000 | [diff] [blame] | 54 | RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \ |
Kuba Mracek | 10854a2 | 2017-08-15 21:02:17 +0000 | [diff] [blame] | 55 | RUN: --default-arch=i386 < %t.input | FileCheck --check-prefix=SPLIT --check-prefix=NODWO %s |
Alexey Samsonov | 1c4d286 | 2013-04-05 08:30:13 +0000 | [diff] [blame] | 56 | |
David Blaikie | fe2090a | 2017-09-08 21:10:01 +0000 | [diff] [blame] | 57 | RUN: cp %p/Inputs/split-dwarf-dwp.o %t/split-dwarf-dwp-different-name.o |
| 58 | RUN: echo "%t/split-dwarf-dwp-different-name.o 0x54" > %t.input |
David Blaikie | 4cf772e | 2017-07-30 01:34:08 +0000 | [diff] [blame] | 59 | RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \ |
| 60 | RUN: --default-arch=i386 --dwp=%p/Inputs/split-dwarf-dwp.o.dwp < %t.input | FileCheck --check-prefix=DWP %s |
| 61 | |
Alexey Samsonov | 1c4d286 | 2013-04-05 08:30:13 +0000 | [diff] [blame] | 62 | CHECK: main |
| 63 | CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:16 |
Alexey Samsonov | 888ca96 | 2013-06-04 07:57:38 +0000 | [diff] [blame] | 64 | |
Alexey Samsonov | 6889483 | 2013-08-14 17:09:30 +0000 | [diff] [blame] | 65 | CHECK: main |
| 66 | CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:16 |
| 67 | |
Alexey Samsonov | 888ca96 | 2013-06-04 07:57:38 +0000 | [diff] [blame] | 68 | CHECK: _start |
| 69 | |
Alexey Samsonov | 8ad418b | 2014-05-19 18:45:32 +0000 | [diff] [blame] | 70 | CHECK: _Z1fii |
| 71 | CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:11 |
| 72 | |
| 73 | CHECK: DummyClass |
| 74 | CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:4 |
| 75 | |
| 76 | CHECK: a |
| 77 | CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test2-helper.cc:2 |
| 78 | |
| 79 | CHECK: main |
| 80 | CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test2-main.cc:4 |
| 81 | |
Alexey Samsonov | 1c4d286 | 2013-04-05 08:30:13 +0000 | [diff] [blame] | 82 | CHECK: _Z1cv |
| 83 | CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test4-part1.cc:2 |
Alexey Samsonov | 888ca96 | 2013-06-04 07:57:38 +0000 | [diff] [blame] | 84 | |
Alexey Samsonov | 1c4d286 | 2013-04-05 08:30:13 +0000 | [diff] [blame] | 85 | CHECK: inlined_h |
| 86 | CHECK-NEXT: dwarfdump-inl-test.h:2 |
| 87 | CHECK-NEXT: inlined_g |
| 88 | CHECK-NEXT: dwarfdump-inl-test.h:7 |
| 89 | CHECK-NEXT: inlined_f |
| 90 | CHECK-NEXT: dwarfdump-inl-test.cc:3 |
| 91 | CHECK-NEXT: main |
Alexey Samsonov | 8ad418b | 2014-05-19 18:45:32 +0000 | [diff] [blame] | 92 | CHECK-NEXT: dwarfdump-inl-test.cc:8 |
| 93 | |
| 94 | CHECK: inlined_g |
| 95 | CHECK-NEXT: dwarfdump-inl-test.h:7 |
| 96 | CHECK-NEXT: inlined_f |
| 97 | CHECK-NEXT: dwarfdump-inl-test.cc:3 |
| 98 | CHECK-NEXT: main |
| 99 | CHECK-NEXT: dwarfdump-inl-test.cc:8 |
| 100 | |
| 101 | CHECK: inlined_f |
| 102 | CHECK-NEXT: dwarfdump-inl-test.cc:3 |
| 103 | CHECK-NEXT: main |
| 104 | CHECK-NEXT: dwarfdump-inl-test.cc:8 |
Alexey Samsonov | ef148af | 2013-04-05 09:22:24 +0000 | [diff] [blame] | 105 | |
Will Dietz | b7b1abe | 2013-10-30 20:27:17 +0000 | [diff] [blame] | 106 | CHECK: inlined_h |
| 107 | CHECK-NEXT: dwarfdump-inl-test.h:3 |
| 108 | CHECK-NEXT: inlined_g |
| 109 | CHECK-NEXT: dwarfdump-inl-test.h:7 |
| 110 | CHECK-NEXT: inlined_f |
| 111 | CHECK-NEXT: dwarfdump-inl-test.cc:3 |
| 112 | CHECK-NEXT: main |
Alexey Samsonov | 8ad418b | 2014-05-19 18:45:32 +0000 | [diff] [blame] | 113 | CHECK-NEXT: dwarfdump-inl-test.cc:8 |
Will Dietz | b7b1abe | 2013-10-30 20:27:17 +0000 | [diff] [blame] | 114 | |
Alexey Samsonov | 8ad418b | 2014-05-19 18:45:32 +0000 | [diff] [blame] | 115 | CHECK: C |
| 116 | CHECK-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test3.cc:3 |
| 117 | |
| 118 | CHECK: _Z3do1v |
| 119 | CHECK-NEXT: /tmp/include{{[/\\]}}dwarfdump-test3-decl.h:7 |
| 120 | |
| 121 | CHECK: _Z3do2v |
| 122 | CHECK-NEXT: /tmp/dbginfo{{[/\\]}}include{{[/\\]}}dwarfdump-test3-decl2.h:1 |
Alexey Samsonov | 625b109 | 2013-06-03 14:12:39 +0000 | [diff] [blame] | 123 | |
Alexey Samsonov | 8c6e324 | 2013-06-28 14:25:52 +0000 | [diff] [blame] | 124 | CHECK: main |
| 125 | CHECK: _Z3inci |
| 126 | CHECK: _Z3inci |
Alexey Samsonov | 8175bc3 | 2013-06-28 08:15:40 +0000 | [diff] [blame] | 127 | |
Alexey Samsonov | e0d2d7f | 2014-04-18 22:22:44 +0000 | [diff] [blame] | 128 | CHECK: main |
| 129 | CHECK-NEXT: llvm-symbolizer-dwo-test.cc:11 |
| 130 | |
David Blaikie | df69f1f | 2018-05-01 18:08:45 +0000 | [diff] [blame] | 131 | CHECK-NOT: local_mem_func |
| 132 | CHECK: _ZZ2f1vEN3foo14local_mem_funcEv |
| 133 | CHECK-NEXT: {{.*}}local-mem-func.cpp:3:0 |
| 134 | |
Alexey Samsonov | 4dfa681 | 2014-06-12 18:52:35 +0000 | [diff] [blame] | 135 | CHECK: main |
| 136 | CHECK-NEXT: {{.*}}fission-ranges.cc:6 |
| 137 | |
Alexey Samsonov | 740a759 | 2014-06-12 23:58:49 +0000 | [diff] [blame] | 138 | CHECK: _ZN1S3bazEv |
| 139 | CHECK-NEXT: {{.*}}arange-overlap.cc:6 |
| 140 | |
David Blaikie | 4fc8e6f | 2016-04-22 21:32:59 +0000 | [diff] [blame] | 141 | DWO: _Z2f2v |
| 142 | NODWO: {{^f2$}} |
David Blaikie | fe2090a | 2017-09-08 21:10:01 +0000 | [diff] [blame] | 143 | SPLIT-NEXT: {{.*}}split-dwarf-test.cpp |
David Blaikie | 4fc8e6f | 2016-04-22 21:32:59 +0000 | [diff] [blame] | 144 | SPLIT-NEXT: main |
David Blaikie | fe2090a | 2017-09-08 21:10:01 +0000 | [diff] [blame] | 145 | SPLIT-NEXT: {{.*}}split-dwarf-test.cpp |
Alexey Samsonov | 54543af | 2014-09-05 19:29:45 +0000 | [diff] [blame] | 146 | |
David Blaikie | 4fc8e6f | 2016-04-22 21:32:59 +0000 | [diff] [blame] | 147 | SPLIT: _Z2f1v |
David Blaikie | fe2090a | 2017-09-08 21:10:01 +0000 | [diff] [blame] | 148 | SPLIT-NEXT: {{.*}}split-dwarf-test.cpp |
Alexey Samsonov | 54543af | 2014-09-05 19:29:45 +0000 | [diff] [blame] | 149 | |
Frederic Riss | cc55b73 | 2014-09-22 12:35:53 +0000 | [diff] [blame] | 150 | ; 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 |
| 152 | CHECK: func |
| 153 | CHECK-NEXT: /tmp{{[/\\]}}cross-cu-inlining.c:16:3 |
| 154 | CHECK-NEXT: main |
| 155 | CHECK-NEXT: /tmp{{[/\\]}}cross-cu-inlining.c:11:0 |
| 156 | |
David Blaikie | 0025fa1 | 2017-05-20 03:32:49 +0000 | [diff] [blame] | 157 | CHECK: f2 |
David Blaikie | fe2090a | 2017-09-08 21:10:01 +0000 | [diff] [blame] | 158 | CHECK-NEXT: split-dwarf-multiple-cu.cpp:3:3 |
David Blaikie | 0025fa1 | 2017-05-20 03:32:49 +0000 | [diff] [blame] | 159 | CHECK-NEXT: f3 |
David Blaikie | fe2090a | 2017-09-08 21:10:01 +0000 | [diff] [blame] | 160 | CHECK-NEXT: split-dwarf-multiple-cu.cpp:6:0 |
David Blaikie | 0025fa1 | 2017-05-20 03:32:49 +0000 | [diff] [blame] | 161 | |
David Blaikie | 9031fd9 | 2017-05-22 07:02:47 +0000 | [diff] [blame] | 162 | CHECK: f2 |
| 163 | CHECK-NEXT: split-dwarf-addr-object-relocation.cpp:3:3 |
| 164 | CHECK-NEXT: f3 |
| 165 | CHECK-NEXT: split-dwarf-addr-object-relocation.cpp:6:0 |
| 166 | |
David Blaikie | 4cf772e | 2017-07-30 01:34:08 +0000 | [diff] [blame] | 167 | DWP: f2 |
| 168 | DWP-NEXT: split-dwarf-dwp.cpp:3:3 |
David Blaikie | 61dba57 | 2017-08-02 20:16:22 +0000 | [diff] [blame] | 169 | DWP-NEXT: main |
| 170 | DWP-NEXT: split-dwarf-dwp.cpp:10:0 |
David Blaikie | 893c346 | 2017-05-23 06:48:53 +0000 | [diff] [blame] | 171 | |
Kuba Mracek | 10854a2 | 2017-08-15 21:02:17 +0000 | [diff] [blame] | 172 | RUN: echo "unexisting-file 0x1234" > %t.input2 |
| 173 | RUN: llvm-symbolizer < %t.input2 2>&1 | FileCheck %s --check-prefix=MISSING-FILE |
Alexey Samsonov | a6c7bb0 | 2015-11-04 00:30:19 +0000 | [diff] [blame] | 174 | |
Alexey Samsonov | fa3207e | 2015-11-04 01:09:37 +0000 | [diff] [blame] | 175 | MISSING-FILE: LLVMSymbolizer: error reading file: {{[Nn]}}o such file or directory |
Alexey Samsonov | 8175bc3 | 2013-06-28 08:15:40 +0000 | [diff] [blame] | 176 | |
Kuba Mracek | 10854a2 | 2017-08-15 21:02:17 +0000 | [diff] [blame] | 177 | RUN: echo "%p/Inputs/macho-universal 0x1f84" > %t.input3 |
| 178 | RUN: llvm-symbolizer < %t.input3 | FileCheck %s --check-prefix=UNKNOWN-ARCH |
Alexey Samsonov | 8175bc3 | 2013-06-28 08:15:40 +0000 | [diff] [blame] | 179 | |
| 180 | UNKNOWN-ARCH-NOT: main |
| 181 | UNKNOWN-ARCH: ?? |
| 182 | UNKNOWN-ARCH-NOT: main |
Alexey Samsonov | 42c9ecb | 2013-12-24 19:33:22 +0000 | [diff] [blame] | 183 | |
David Blaikie | 1e91943 | 2018-12-21 22:25:01 +0000 | [diff] [blame] | 184 | RUN: echo "0x40113f" > %t.input4 |
| 185 | RUN: echo "0x401020" >> %t.input4 |
Kuba Mracek | 10854a2 | 2017-08-15 21:02:17 +0000 | [diff] [blame] | 186 | RUN: llvm-symbolizer --obj %p/Inputs/dwarfdump-test.elf-x86-64 < %t.input4 \ |
Alexey Samsonov | 42c9ecb | 2013-12-24 19:33:22 +0000 | [diff] [blame] | 187 | RUN: | FileCheck %s --check-prefix=BINARY |
| 188 | |
| 189 | BINARY: main |
| 190 | BINARY-NEXT: /tmp/dbginfo{{[/\\]}}dwarfdump-test.cc:16 |
| 191 | BINARY: _start |
Ed Maste | 22939fa | 2014-01-16 17:25:12 +0000 | [diff] [blame] | 192 | |
David Blaikie | 1e91943 | 2018-12-21 22:25:01 +0000 | [diff] [blame] | 193 | RUN: echo "0x401140" > %t.input5 |
| 194 | RUN: echo "0x401020" >> %t.input5 |
| 195 | RUN: echo "0x401120" >> %t.input5 |
Kuba Mracek | 10854a2 | 2017-08-15 21:02:17 +0000 | [diff] [blame] | 196 | RUN: llvm-symbolizer --obj %p/Inputs/llvm-symbolizer-test.elf-x86-64 < %t.input5 \ |
Ed Maste | 22939fa | 2014-01-16 17:25:12 +0000 | [diff] [blame] | 197 | RUN: | FileCheck %s --check-prefix=BINARY_C |
| 198 | |
| 199 | BINARY_C: main |
| 200 | BINARY_C-NEXT: /tmp/dbginfo{{[/\\]}}llvm-symbolizer-test.c:10 |
| 201 | BINARY_C: _start |
| 202 | BINARY_C: {{g$}} |
Alexey Samsonov | 12c9f92 | 2014-02-26 13:10:01 +0000 | [diff] [blame] | 203 | |
Kuba Mracek | 10854a2 | 2017-08-15 21:02:17 +0000 | [diff] [blame] | 204 | RUN: echo "0x1f1" > %t.input6 |
| 205 | RUN: llvm-symbolizer --obj %p/Inputs/shared-object-stripped.elf-i386 < %t.input6 \ |
Alexey Samsonov | 12c9f92 | 2014-02-26 13:10:01 +0000 | [diff] [blame] | 206 | RUN: | FileCheck %s --check-prefix=STRIPPED |
| 207 | |
| 208 | STRIPPED: global_func |
Alexey Samsonov | bf6e3f9 | 2014-05-17 00:07:48 +0000 | [diff] [blame] | 209 | |
Kuba Mracek | 10854a2 | 2017-08-15 21:02:17 +0000 | [diff] [blame] | 210 | RUN: echo "%p/Inputs/dwarfdump-test4.elf-x86-64 0x62c" > %t.input7 |
| 211 | RUN: llvm-symbolizer --functions=short --demangle=false < %t.input7 \ |
Alexey Samsonov | bf6e3f9 | 2014-05-17 00:07:48 +0000 | [diff] [blame] | 212 | RUN: | FileCheck %s --check-prefix=SHORT_FUNCTION_NAME |
Dmitry Venikov | 2eebdab | 2019-01-16 07:05:58 +0000 | [diff] [blame] | 213 | RUN: llvm-symbolizer --functions=short -C=false < %t.input7 \ |
| 214 | RUN: | FileCheck %s --check-prefix=SHORT_FUNCTION_NAME |
Alexey Samsonov | bf6e3f9 | 2014-05-17 00:07:48 +0000 | [diff] [blame] | 215 | |
| 216 | SHORT_FUNCTION_NAME-NOT: _Z1cv |