2017-06-06 00:24:25 +08:00
|
|
|
; REQUIRES: x86
|
2017-07-08 00:33:01 +08:00
|
|
|
; LTO
|
2017-06-06 00:24:25 +08:00
|
|
|
; RUN: llvm-as %s -o %t.o
|
|
|
|
; RUN: llvm-as %S/Inputs/wrap-bar.ll -o %t1.o
|
|
|
|
; RUN: ld.lld %t.o %t1.o -shared -o %t.so -wrap=bar
|
|
|
|
; RUN: llvm-objdump -d %t.so | FileCheck %s
|
2019-05-01 13:49:01 +08:00
|
|
|
; RUN: llvm-readobj --symbols %t.so | FileCheck -check-prefix=BIND %s
|
2017-06-06 00:24:25 +08:00
|
|
|
|
2017-07-08 00:33:01 +08:00
|
|
|
; ThinLTO
|
|
|
|
; RUN: opt -module-summary %s -o %t.o
|
|
|
|
; RUN: opt -module-summary %S/Inputs/wrap-bar.ll -o %t1.o
|
|
|
|
; RUN: ld.lld %t.o %t1.o -shared -o %t.so -wrap=bar
|
2019-03-21 03:05:05 +08:00
|
|
|
; RUN: llvm-objdump -d %t.so | FileCheck %s
|
2019-05-01 13:49:01 +08:00
|
|
|
; RUN: llvm-readobj --symbols %t.so | FileCheck -check-prefix=BIND %s
|
2017-07-08 00:33:01 +08:00
|
|
|
|
2017-06-06 00:24:25 +08:00
|
|
|
; Make sure that calls in foo() are not eliminated and that bar is
|
|
|
|
; routed to __wrap_bar and __real_bar is routed to bar.
|
|
|
|
|
2020-03-06 06:18:38 +08:00
|
|
|
; CHECK: <foo>:
|
2017-06-06 00:24:25 +08:00
|
|
|
; CHECK-NEXT: pushq %rax
|
2017-07-05 08:43:18 +08:00
|
|
|
; CHECK-NEXT: callq{{.*}}<__wrap_bar>
|
2019-03-21 03:05:05 +08:00
|
|
|
; CHECK-NEXT: popq %rax
|
|
|
|
; CHECK-NEXT: jmp{{.*}}<bar>
|
2017-07-08 00:33:01 +08:00
|
|
|
|
2017-06-06 00:24:25 +08:00
|
|
|
; Check that bar and __wrap_bar retain their original binding.
|
Change how we handle -wrap.
We have an issue with -wrap that the option doesn't work well when
renamed symbols get PLT entries. I'll explain what is the issue and
how this patch solves it.
For one -wrap option, we have three symbols: foo, wrap_foo and real_foo.
Currently, we use memcpy to overwrite wrapped symbols so that they get
the same contents. This works in most cases but doesn't when the relocation
processor sets some flags in the symbol. memcpy'ed symbols are just
aliases, so they always have to have the same contents, but the
relocation processor breaks that assumption.
r336609 is an attempt to fix the issue by memcpy'ing again after
processing relocations, so that symbols that are out of sync get the
same contents again. That works in most cases as well, but it breaks
ASan build in a mysterious way.
We could probably fix the issue by choosing symbol attributes that need
to be copied after they are updated. But it feels too complicated to me.
So, in this patch, I fixed it once and for all. With this patch, we no
longer memcpy symbols. All references to renamed symbols point to new
symbols after wrapSymbols() is done.
Differential Revision: https://reviews.llvm.org/D50569
llvm-svn: 340387
2018-08-22 15:02:26 +08:00
|
|
|
; BIND: Name: bar
|
2017-06-06 00:24:25 +08:00
|
|
|
; BIND-NEXT: Value:
|
|
|
|
; BIND-NEXT: Size:
|
|
|
|
; BIND-NEXT: Binding: Local
|
Change how we handle -wrap.
We have an issue with -wrap that the option doesn't work well when
renamed symbols get PLT entries. I'll explain what is the issue and
how this patch solves it.
For one -wrap option, we have three symbols: foo, wrap_foo and real_foo.
Currently, we use memcpy to overwrite wrapped symbols so that they get
the same contents. This works in most cases but doesn't when the relocation
processor sets some flags in the symbol. memcpy'ed symbols are just
aliases, so they always have to have the same contents, but the
relocation processor breaks that assumption.
r336609 is an attempt to fix the issue by memcpy'ing again after
processing relocations, so that symbols that are out of sync get the
same contents again. That works in most cases as well, but it breaks
ASan build in a mysterious way.
We could probably fix the issue by choosing symbol attributes that need
to be copied after they are updated. But it feels too complicated to me.
So, in this patch, I fixed it once and for all. With this patch, we no
longer memcpy symbols. All references to renamed symbols point to new
symbols after wrapSymbols() is done.
Differential Revision: https://reviews.llvm.org/D50569
llvm-svn: 340387
2018-08-22 15:02:26 +08:00
|
|
|
; BIND: Name: __wrap_bar
|
2017-06-06 00:24:25 +08:00
|
|
|
; BIND-NEXT: Value:
|
|
|
|
; BIND-NEXT: Size:
|
|
|
|
; BIND-NEXT: Binding: Local
|
|
|
|
|
2019-09-11 07:15:38 +08:00
|
|
|
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
|
2017-06-06 00:24:25 +08:00
|
|
|
target triple = "x86_64-unknown-linux-gnu"
|
|
|
|
|
|
|
|
declare void @bar()
|
|
|
|
declare void @__real_bar()
|
|
|
|
|
|
|
|
define void @foo() {
|
|
|
|
call void @bar()
|
|
|
|
call void @__real_bar()
|
|
|
|
ret void
|
|
|
|
}
|