blob: a26e43b6989605b7bf350c5614cfc005bee455ac [file] [edit]
// REQUIRES: x86
// Check that we can wrap a dllimported symbol, so that references to
// __imp_<symbol> gets redirected to a symbol that already exists or a defined
// local import instead.
// RUN: split-file %s %t.dir
// RUN: llvm-mc -filetype=obj -triple=i686-win32-gnu %t.dir/main.s -o %t.main.obj
// RUN: llvm-mc -filetype=obj -triple=i686-win32-gnu %t.dir/other.s -o %t.other.obj
// RUN: lld-link -dll -out:%t.dll %t.other.obj -noentry -safeseh:no -export:foo -export:bar -implib:%t.lib
// RUN: lld-link -out:%t.exe %t.main.obj %t.lib -entry:entry -subsystem:console -debug:symtab -safeseh:no -wrap:foo -wrap:bar -lldmap:%t.map
// RUN: llvm-objdump -s -d --print-imm-hex %t.exe | FileCheck %s
// CHECK: Contents of section .rdata:
// CHECK-NEXT: 402000 0c104000
// CHECK: Disassembly of section .text:
// CHECK-EMPTY:
// CHECK: 00401000 <_entry>:
// CHECK-NEXT: 401000: ff 25 00 20 40 00 jmpl *0x402000
// CHECK-NEXT: 401006: ff 25 00 00 00 00 jmpl *0x0
// CHECK-EMPTY:
// CHECK-NEXT: 0040100c <___wrap_foo>:
// CHECK-NEXT: 40100c: c3 retl
// CHECK-EMPTY:
// CHECK-NEXT: 0040100d <___wrap_bar>:
// CHECK-NEXT: 40100d: c3 retl
// The first jmpl instruction in _entry points at an address in 0x402000,
// which is the first 4 bytes of the .rdata section (above), which is a
// pointer that points at ___wrap_foo.
// The second jmpl instruction in _entry points to null because the referenced
// symbol `__imp____wrap_bar` is declared as a weak reference to prevent pull a
// reference from an external DLL.
#--- main.s
.global _entry
_entry:
jmpl *__imp__foo
jmpl *__imp__bar
.global ___wrap_foo
___wrap_foo:
ret
.weak __imp____wrap_bar
.global ___wrap_bar
___wrap_bar:
ret
#--- other.s
.global _foo
_foo:
ret
.global _bar
_bar:
ret