Skip to content

Commit

Permalink
Add back FoldOpIntoPhi optimizations with fix. Included test cases to…
Browse files Browse the repository at this point in the history
… help catch these errors and to test the presence of the optimization itself

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@170248 91177308-0d34-0410-b5e6-96231b3b80d8
  • Loading branch information
milseman committed Dec 14, 2012
1 parent f53e7cb commit 07acee7
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 0 deletions.
4 changes: 4 additions & 0 deletions lib/Transforms/InstCombine/InstCombineAddSub.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -354,6 +354,10 @@ Instruction *InstCombiner::visitFAdd(BinaryOperator &I) {
if (Value *V = SimplifyFAddInst(LHS, RHS, I.getFastMathFlags(), TD))
return ReplaceInstUsesWith(I, V);

if (isa<Constant>(RHS) && isa<PHINode>(LHS))
if (Instruction *NV = FoldOpIntoPhi(I))
return NV;

// -A + B --> B - A
// -A + -B --> -(A + B)
if (Value *LHSV = dyn_castFNegVal(LHS))
Expand Down
39 changes: 39 additions & 0 deletions test/Transforms/InstCombine/fold-phi.ll
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
; RUN: opt < %s -instcombine -S | FileCheck %s

; CHECK: no_crash
define float @no_crash(float %a) nounwind {
entry:
br label %for.body

for.body:
%sum.057 = phi float [ 0.000000e+00, %entry ], [ %add5, %bb0 ]
%add5 = fadd float %sum.057, %a ; PR14592
br i1 undef, label %bb0, label %end

bb0:
br label %for.body

end:
ret float %add5
}

; CHECK: fold_phi
define float @fold_phi(float %a) nounwind {
entry:
br label %for.body

for.body:
; CHECK: phi float
; CHECK-NEXT: br i1 undef
%sum.057 = phi float [ 0.000000e+00, %entry ], [ %add5, %bb0 ]
%add5 = fadd float %sum.057, 1.0 ;; Should be moved to the latch!
br i1 undef, label %bb0, label %end

; CHECK: bb0:
bb0:
; CHECK: fadd float
br label %for.body

end:
ret float %add5
}

0 comments on commit 07acee7

Please sign in to comment.