diff options
author | Teresa Johnson <tejohnson@google.com> | 2016-10-08 16:11:42 +0000 |
---|---|---|
committer | Teresa Johnson <tejohnson@google.com> | 2016-10-08 16:11:42 +0000 |
commit | 897bab9b35dd80e10e8a9c34dcac072c173fcffb (patch) | |
tree | d40861de5457f17703e145f77cf0a3c07f205c67 /llvm/test/Bitcode/thinlto-alias2.ll | |
parent | eb65d72d9cf0f39bcfa793ae6afa7a90022993a5 (diff) | |
download | bcm5719-llvm-897bab9b35dd80e10e8a9c34dcac072c173fcffb.tar.gz bcm5719-llvm-897bab9b35dd80e10e8a9c34dcac072c173fcffb.zip |
[ThinLTO] Record calls to aliases
Summary:
When there is a call to an alias in the same module, we were not
adding a call edge. So we could incorrectly think that the alias
was dead if it was inlined in that function, despite having a
reference imported elsewhere. This resulted in unsats at link time.
Add a call edge when the call is to an alias.
Reviewers: davide, mehdi_amini
Subscribers: llvm-commits
Differential Revision: https://reviews.llvm.org/D25384
llvm-svn: 283664
Diffstat (limited to 'llvm/test/Bitcode/thinlto-alias2.ll')
-rw-r--r-- | llvm/test/Bitcode/thinlto-alias2.ll | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/llvm/test/Bitcode/thinlto-alias2.ll b/llvm/test/Bitcode/thinlto-alias2.ll new file mode 100644 index 00000000000..d2b7f723fa4 --- /dev/null +++ b/llvm/test/Bitcode/thinlto-alias2.ll @@ -0,0 +1,28 @@ +; Test to check the callgraph for call to alias in module. +; RUN: opt -module-summary %s -o %t.o +; RUN: llvm-bcanalyzer -dump %t.o | FileCheck %s + +; CHECK: <GLOBALVAL_SUMMARY_BLOCK +; CHECK-NEXT: <VERSION +; CHECK-NEXT: <PERMODULE {{.*}} op3=0 op4=[[ALIASID:[0-9]+]]/> +; CHECK-NEXT: <PERMODULE {{.*}} op0=[[ALIASEEID:[0-9]+]] +; CHECK-NEXT: <ALIAS {{.*}} op0=[[ALIASID]] {{.*}} op2=[[ALIASEEID]]/> +; CHECK-NEXT: </GLOBALVAL_SUMMARY_BLOCK> + +; ModuleID = 'thinlto-alias2.ll' +target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" +target triple = "x86_64-unknown-linux-gnu" + +define i32 @main() { +entry: + call void (...) @analias() + ret i32 0 +} + +@analias = alias void (...), bitcast (void ()* @aliasee to void (...)*) + +define void @aliasee() #0 { +entry: + ret void +} + |