OSDN Git Service

[ThinLTO] Skip BlockAddresses while replacing uses in function import.
authorDmitry Mikulin <dmitry.mikulin@sony.com>
Thu, 8 Feb 2018 22:14:56 +0000 (22:14 +0000)
committerDmitry Mikulin <dmitry.mikulin@sony.com>
Thu, 8 Feb 2018 22:14:56 +0000 (22:14 +0000)
Differential Revision: https://reviews.llvm.org/D43027

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@324658 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/IPO/LowerTypeTests.cpp
test/Transforms/LowerTypeTests/Inputs/blockaddr-import.yaml [new file with mode: 0644]
test/Transforms/LowerTypeTests/blockaddr-import.ll [new file with mode: 0644]

index 5dd9fd3..3ec6e40 100644 (file)
@@ -983,7 +983,7 @@ void LowerTypeTestsModule::importFunction(Function *F, bool isDefinition) {
   if (F->isWeakForLinker())
     replaceWeakDeclarationWithJumpTablePtr(F, FDecl);
   else
-    F->replaceAllUsesWith(FDecl);
+    F->replaceUsesExceptBlockAddr(FDecl);
 }
 
 void LowerTypeTestsModule::lowerTypeTestCalls(
diff --git a/test/Transforms/LowerTypeTests/Inputs/blockaddr-import.yaml b/test/Transforms/LowerTypeTests/Inputs/blockaddr-import.yaml
new file mode 100644 (file)
index 0000000..0044cc6
--- /dev/null
@@ -0,0 +1,10 @@
+---
+TypeIdMap:
+  typeid1:
+    TTRes:
+      Kind:            AllOnes
+      SizeM1BitWidth:  7
+CfiFunctionDefs:
+  - m
+CfiFunctionDecls:
+...
diff --git a/test/Transforms/LowerTypeTests/blockaddr-import.ll b/test/Transforms/LowerTypeTests/blockaddr-import.ll
new file mode 100644 (file)
index 0000000..0529a34
--- /dev/null
@@ -0,0 +1,22 @@
+; RUN: opt -lowertypetests -lowertypetests-summary-action=import -lowertypetests-read-summary=%p/Inputs/blockaddr-import.yaml %s -S | FileCheck %s
+
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-unknown-linux"
+
+declare i1 @llvm.type.test(i8*, metadata) #1
+declare !type !11 i32 @o(...)
+
+define hidden void @m() #0 !type !3 {
+entry:
+  br label %n
+n:
+  %call = tail call i32 (i8*, ...) bitcast (i32 (...)* @o to i32 (i8*, ...)*)(i8* blockaddress(@m, %n)) #4
+; Make sure that blockaddress refers to the new function, m.cfi
+; CHECK: define hidden void @m.cfi()
+; CHECK: blockaddress(@m.cfi, %n)
+
+  ret void
+}
+
+!3 = !{i64 0, !"_ZTSFvE"}
+!11 = !{i64 0, !"_ZTSFiE"}