[PATCH] D43027: [ThinLTO] Skip BlockAddresses while replacing uses in function import
Dmitry Mikulin via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Feb 8 14:16:57 PST 2018
This revision was automatically updated to reflect the committed changes.
Closed by commit rL324658: [ThinLTO] Skip BlockAddresses while replacing uses in function import. (authored by dmikulin, committed by ).
Changed prior to commit:
https://reviews.llvm.org/D43027?vs=133478&id=133486#toc
Repository:
rL LLVM
https://reviews.llvm.org/D43027
Files:
llvm/trunk/lib/Transforms/IPO/LowerTypeTests.cpp
llvm/trunk/test/Transforms/LowerTypeTests/Inputs/blockaddr-import.yaml
llvm/trunk/test/Transforms/LowerTypeTests/blockaddr-import.ll
Index: llvm/trunk/lib/Transforms/IPO/LowerTypeTests.cpp
===================================================================
--- llvm/trunk/lib/Transforms/IPO/LowerTypeTests.cpp
+++ llvm/trunk/lib/Transforms/IPO/LowerTypeTests.cpp
@@ -983,7 +983,7 @@
if (F->isWeakForLinker())
replaceWeakDeclarationWithJumpTablePtr(F, FDecl);
else
- F->replaceAllUsesWith(FDecl);
+ F->replaceUsesExceptBlockAddr(FDecl);
}
void LowerTypeTestsModule::lowerTypeTestCalls(
Index: llvm/trunk/test/Transforms/LowerTypeTests/Inputs/blockaddr-import.yaml
===================================================================
--- llvm/trunk/test/Transforms/LowerTypeTests/Inputs/blockaddr-import.yaml
+++ llvm/trunk/test/Transforms/LowerTypeTests/Inputs/blockaddr-import.yaml
@@ -0,0 +1,10 @@
+---
+TypeIdMap:
+ typeid1:
+ TTRes:
+ Kind: AllOnes
+ SizeM1BitWidth: 7
+CfiFunctionDefs:
+ - m
+CfiFunctionDecls:
+...
Index: llvm/trunk/test/Transforms/LowerTypeTests/blockaddr-import.ll
===================================================================
--- llvm/trunk/test/Transforms/LowerTypeTests/blockaddr-import.ll
+++ llvm/trunk/test/Transforms/LowerTypeTests/blockaddr-import.ll
@@ -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"}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D43027.133486.patch
Type: text/x-patch
Size: 1938 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20180208/c5e1964a/attachment.bin>
More information about the llvm-commits
mailing list