[PATCH] D36012: Update phi nodes in LowerTypeTests control flow simplification
Vlad Tsyrklevich via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Jul 28 13:35:23 PDT 2017
vlad.tsyrklevich updated this revision to Diff 108701.
vlad.tsyrklevich marked an inline comment as done.
https://reviews.llvm.org/D36012
Files:
lib/Transforms/IPO/LowerTypeTests.cpp
test/Transforms/LowerTypeTests/simplify_phi.ll
Index: test/Transforms/LowerTypeTests/simplify_phi.ll
===================================================================
--- /dev/null
+++ test/Transforms/LowerTypeTests/simplify_phi.ll
@@ -0,0 +1,20 @@
+; Ensure that LowerTypeTests control flow simplification correctly handle phi nodes.
+; RUN: opt -S -lowertypetests -lowertypetests-summary-action=import -lowertypetests-read-summary=%S/Inputs/import.yaml < %s | FileCheck %s
+
+target datalayout = "e-p:64:64"
+
+declare i1 @llvm.type.test(i8* %ptr, metadata %bitset) nounwind readnone
+
+; CHECK: define i1 @bytearray7(i8* [[p:%.*]])
+define i1 @bytearray7(i8* %p) {
+ %x = call i1 @llvm.type.test(i8* %p, metadata !"bytearray7")
+ br i1 %x, label %t, label %f
+
+t:
+ br label %f
+
+f:
+ ; CHECK: %test = phi i1 [ false, %{{[0-9]+}} ], [ true, %t ], [ false, %0 ]
+ %test = phi i1 [ false, %0 ], [ true, %t ]
+ ret i1 %test
+}
Index: lib/Transforms/IPO/LowerTypeTests.cpp
===================================================================
--- lib/Transforms/IPO/LowerTypeTests.cpp
+++ lib/Transforms/IPO/LowerTypeTests.cpp
@@ -634,6 +634,10 @@
Br->getMetadata(LLVMContext::MD_prof));
ReplaceInstWithInst(InitialBB->getTerminator(), NewBr);
+ // Update phis in Else resulting from InitialBB being split
+ for (auto &Phi : Else->phis())
+ Phi.addIncoming(Phi.getIncomingValueForBlock(Then), InitialBB);
+
IRBuilder<> ThenB(CI);
return createBitSetTest(ThenB, TIL, BitOffset);
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D36012.108701.patch
Type: text/x-patch
Size: 1527 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20170728/9e17e5f6/attachment.bin>
More information about the llvm-commits
mailing list