Skip to content

Commit

Permalink
Ignore indirect branches from callbr.
Browse files Browse the repository at this point in the history
Summary:
We can't speculate around indirect branches: indirectbr and invoke. The
callbr instruction needs to be included here.

Reviewers: nickdesaulniers, manojgupta, chandlerc

Reviewed By: chandlerc

Subscribers: llvm-commits

Tags: #llvm

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

llvm-svn: 368873
  • Loading branch information
isanbard committed Aug 14, 2019
1 parent 8664998 commit cc2bebe
Show file tree
Hide file tree
Showing 2 changed files with 48 additions and 2 deletions.
6 changes: 4 additions & 2 deletions llvm/lib/Transforms/Scalar/SpeculateAroundPHIs.cpp
Expand Up @@ -777,8 +777,10 @@ static bool tryToSpeculatePHIs(SmallVectorImpl<PHINode *> &PNs,
// speculation if the predecessor is an invoke. This doesn't seem
// fundamental and we should probably be splitting critical edges
// differently.
if (isa<IndirectBrInst>(PredBB->getTerminator()) ||
isa<InvokeInst>(PredBB->getTerminator())) {
const auto *TermInst = PredBB->getTerminator();
if (isa<IndirectBrInst>(TermInst) ||
isa<InvokeInst>(TermInst) ||
isa<CallBrInst>(TermInst)) {
LLVM_DEBUG(dbgs() << " Invalid: predecessor terminator: "
<< PredBB->getName() << "\n");
return false;
Expand Down
44 changes: 44 additions & 0 deletions llvm/test/Transforms/SpeculateAroundPHIs/pr42991.ll
@@ -0,0 +1,44 @@
; RUN: opt -S -passes=spec-phis %s

; This testcase crashes during the speculate around PHIs pass. The pass however
; results in no changes.

define i32 @test1() {
entry:
callbr void asm sideeffect "", "X,X,~{dirflag},~{fpsr},~{flags}"(i8* blockaddress(@test1, %return), i8* blockaddress(@test1, %f))
to label %asm.fallthrough [label %return, label %f]

asm.fallthrough:
br label %return

f:
br label %return

return:
%retval.0 = phi i32 [ 0, %f ], [ 1, %asm.fallthrough ], [ 1, %entry ]
ret i32 %retval.0
}

define void @test2() {
entry:
br label %tailrecurse

tailrecurse:
%call = tail call i32 @test3()
%tobool1 = icmp eq i32 %call, 0
callbr void asm sideeffect "", "X,X,~{dirflag},~{fpsr},~{flags}"(i8* blockaddress(@test2, %test1.exit), i8* blockaddress(@test2, %f.i))
to label %if.end6 [label %test1.exit, label %f.i]

f.i:
br label %test1.exit

test1.exit:
%retval.0.i = phi i1 [ false, %f.i ], [ true, %tailrecurse ]
%brmerge = or i1 %tobool1, %retval.0.i
br i1 %brmerge, label %if.end6, label %tailrecurse

if.end6:
ret void
}

declare i32 @test3()

0 comments on commit cc2bebe

Please sign in to comment.