1# REQUIRES: x86
2# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t.o
3# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %p/Inputs/undef.s -o %t2.o
4# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %p/Inputs/undef-debug.s -o %t3.o
5# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %p/Inputs/undef-bad-debug.s -o %t4.o
6# RUN: rm -f %t2.a
7# RUN: llvm-ar rc %t2.a %t2.o
8# RUN: not ld.lld %t.o %t2.a %t3.o %t4.o -o /dev/null 2>&1 \
9# RUN:   | FileCheck %s --implicit-check-not="error:" --implicit-check-not="warning:"
10# RUN: not ld.lld -pie %t.o %t2.a %t3.o %t4.o -o /dev/null 2>&1 \
11# RUN:   | FileCheck %s --implicit-check-not="error:" --implicit-check-not="warning:"
12
13# CHECK:      error: undefined symbol: foo
14# CHECK-NEXT: >>> referenced by undef.s
15# CHECK-NEXT:                   {{.*}}:(.text+0x1)
16
17# CHECK:      error: undefined symbol: bar
18# CHECK-NEXT: >>> referenced by undef.s
19# CHECK-NEXT: >>>               {{.*}}:(.text+0x6)
20
21# CHECK:      error: undefined symbol: foo(int)
22# CHECK-NEXT: >>> referenced by undef.s
23# CHECK-NEXT: >>>               {{.*}}:(.text+0x10)
24
25# CHECK:      error: undefined symbol: vtable for Foo
26# CHECK-NEXT: >>> referenced by undef.s
27# CHECK-NEXT: >>>               {{.*}}:(.text+0x15)
28# CHECK-NEXT: >>> the vtable symbol may be undefined because the class is missing its key function (see https://lld.llvm.org/missingkeyfunction)
29
30# Check that this symbol isn't demangled
31
32# CHECK:      error: undefined symbol: __Z3fooi
33# CHECK-NEXT: >>> referenced by undef.s
34# CHECK-NEXT: >>>               {{.*}}:(.text+0x1A)
35
36# CHECK:      error: undefined symbol: zed2
37# CHECK-NEXT: >>> referenced by {{.*}}.o:(.text+0x0) in archive {{.*}}2.a
38
39# CHECK:      error: undefined symbol: zed3
40# CHECK-NEXT: >>> referenced by undef-debug.s:3 (dir{{/|\\}}undef-debug.s:3)
41# CHECK-NEXT: >>>               {{.*}}.o:(.text+0x0)
42
43# CHECK:      error: undefined symbol: zed4
44# CHECK-NEXT: >>> referenced by undef-debug.s:7 (dir{{/|\\}}undef-debug.s:7)
45# CHECK-NEXT: >>>               {{.*}}.o:(.text.1+0x0)
46
47# CHECK:      error: undefined symbol: zed5
48# CHECK-NEXT: >>> referenced by undef-debug.s:11 (dir{{/|\\}}undef-debug.s:11)
49# CHECK-NEXT: >>>               {{.*}}.o:(.text.2+0x0)
50
51# Show that all line table problems are mentioned as soon as the object's line information
52# is requested, even if that particular part of the line information is not currently required.
53# Also show that the warnings are only printed once.
54# CHECK:      warning: unknown data in line table prologue at offset 0x00000000: parsing ended (at offset 0x00000037) before reaching the prologue end at offset 0x00000038
55# CHECK-NEXT: warning: parsing line table prologue at offset 0x0000005b: unsupported version 1
56# CHECK-NEXT: warning: last sequence in debug line table at offset 0x00000061 is not terminated
57# CHECK:      error: undefined symbol: zed6a
58# CHECK-NEXT: >>> referenced by undef-bad-debug.s:11 (dir{{/|\\}}undef-bad-debug.s:11)
59# CHECK-NEXT: >>>               {{.*}}4.o:(.text+0x0)
60# CHECK:      error: undefined symbol: zed6b
61# CHECK-NEXT: >>> referenced by undef-bad-debug.s:21 (dir{{/|\\}}undef-bad-debug.s:21)
62# CHECK-NEXT: >>>               {{.*}}4.o:(.text+0x8)
63
64# Show that a problem in a line table that prevents further parsing of that
65# table means that no line information is displayed in the wardning.
66# CHECK:      error: undefined symbol: zed7
67# CHECK-NEXT: >>> referenced by {{.*}}4.o:(.text+0x10)
68
69# Show that a problem with one line table's information doesn't affect getting information from
70# a different one in the same object.
71# CHECK:      error: undefined symbol: zed8
72# CHECK-NEXT: >>> referenced by undef-bad-debug2.s:11 (dir2{{/|\\}}undef-bad-debug2.s:11)
73# CHECK-NEXT: >>>               {{.*}}tmp4.o:(.text+0x18)
74
75# RUN: not ld.lld %t.o %t2.a -o /dev/null -no-demangle 2>&1 | \
76# RUN:   FileCheck -check-prefix=NO-DEMANGLE %s
77# NO-DEMANGLE: error: undefined symbol: _Z3fooi
78
79.file "undef.s"
80
81  .globl _start
82_start:
83  call foo
84  call bar
85  call zed1
86  call _Z3fooi
87  call _ZTV3Foo
88  call __Z3fooi
89