Skip to content

Commit

Permalink
Update phi nodes in LowerTypeTests control flow simplification
Browse files Browse the repository at this point in the history
D33925 added a control flow simplification for -O2 --lto-O0 builds that
manually splits blocks and reassigns conditional branches but does not
correctly update phi nodes. If the else case being branched to had
incoming phi nodes the control-flow simplification would leave phi nodes
in that BB with an unhandled predecessor.

Patch by Vlad Tsyrklevich!

Differential Revision: https://reviews.llvm.org/D36012

llvm-svn: 309621
  • Loading branch information
pcc committed Jul 31, 2017
1 parent f3ed393 commit bcd204b
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 0 deletions.
4 changes: 4 additions & 0 deletions llvm/lib/Transforms/IPO/LowerTypeTests.cpp
Expand Up @@ -634,6 +634,10 @@ Value *LowerTypeTestsModule::lowerTypeTestCall(Metadata *TypeId, CallInst *CI,
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);
}
Expand Down
20 changes: 20 additions & 0 deletions llvm/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
}

0 comments on commit bcd204b

Please sign in to comment.