llvm/lld/test/ELF/wrap-dynamic-undef.s

# REQUIRES: x86
# RUN: split-file %s %t
# RUN: llvm-mc -filetype=obj -triple=x86_64 %t/a.s -o %t/a.o
# RUN: llvm-mc -filetype=obj -triple=x86_64 %t/def.s -o %t/def.o
# RUN: ld.lld %t/def.o -o %t/def.so -shared --soname=def
# RUN: ld.lld %t/a.o %t/def.so -o %t1 --wrap foo
# RUN: llvm-readelf --dyn-syms %t1 | FileCheck %s

# Test that the dynamic relocation uses foo. We used to produce a
# relocation with __real_foo.

# CHECK:      Symbol table '.dynsym' contains 2 entries:
# CHECK:      NOTYPE  LOCAL  DEFAULT  UND
# CHECK-NEXT: NOTYPE  GLOBAL DEFAULT  UND foo

# RUN: llvm-mc -filetype=obj -triple=x86_64 %t/b.s -o %t/b.o
# RUN: ld.lld -shared --wrap foo %t/b.o -o %t2.so
# RUN: llvm-readelf --dyn-syms %t2.so | FileCheck %s --check-prefix=SYM2

# SYM2:      Symbol table '.dynsym' contains 4 entries:
# SYM2:      NOTYPE  LOCAL  DEFAULT   UND
# SYM2-NEXT: NOTYPE  WEAK   DEFAULT   UND foo
# SYM2-NEXT: NOTYPE  WEAK   DEFAULT   UND __wrap_foo
# SYM2-NEXT: NOTYPE  GLOBAL DEFAULT [[#]] _start

#--- a.s
.global _start
_start:
	callq	__real_foo@plt

#--- def.s
.globl foo
foo:

#--- b.s
.weak foo
.weak __real_foo
.global _start
_start:
  call __real_foo@plt
  call foo@plt