mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-11 11:34:02 +00:00
only factor from expressions whose uses are empty and whose
base is the right expression type. This fixes PR5981. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@93045 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
d199636039
commit
c2d1b6949c
@ -792,6 +792,11 @@ Value *Reassociate::OptimizeAdd(Instruction *I,
|
||||
Instruction *DummyInst = BinaryOperator::CreateAdd(MaxOccVal, MaxOccVal);
|
||||
SmallVector<Value*, 4> NewMulOps;
|
||||
for (unsigned i = 0, e = Ops.size(); i != e; ++i) {
|
||||
// Only try to remove factors from expressions we're allowed to.
|
||||
BinaryOperator *BOp = dyn_cast<BinaryOperator>(Ops[i].Op);
|
||||
if (BOp == 0 || BOp->getOpcode() != Instruction::Mul || !BOp->use_empty())
|
||||
continue;
|
||||
|
||||
if (Value *V = RemoveFactorFromExpression(Ops[i].Op, MaxOccVal)) {
|
||||
NewMulOps.push_back(V);
|
||||
Ops.erase(Ops.begin()+i);
|
||||
|
@ -2,7 +2,7 @@
|
||||
|
||||
|
||||
; rdar://7507855
|
||||
define fastcc i32 @test() nounwind {
|
||||
define fastcc i32 @test1() nounwind {
|
||||
entry:
|
||||
%cond = select i1 undef, i32 1, i32 -1 ; <i32> [#uses=2]
|
||||
br label %for.cond
|
||||
@ -13,3 +13,21 @@ for.cond: ; preds = %for.body, %entry
|
||||
%add896 = sub i32 0, %cond ; <i32> [#uses=0]
|
||||
ret i32 undef
|
||||
}
|
||||
|
||||
; PR5981
|
||||
define i32 @test2() nounwind ssp {
|
||||
entry:
|
||||
%0 = load i32* undef, align 4
|
||||
%1 = mul nsw i32 undef, %0
|
||||
%2 = mul nsw i32 undef, %0
|
||||
%3 = add nsw i32 undef, %1
|
||||
%4 = add nsw i32 %3, %2
|
||||
%5 = add nsw i32 %4, 4
|
||||
%6 = shl i32 %0, 3 ; <i32> [#uses=1]
|
||||
%7 = add nsw i32 %5, %6
|
||||
br label %bb4.i9
|
||||
|
||||
bb4.i9: ; preds = %bb3.i7, %bb1.i25.i
|
||||
%8 = add nsw i32 undef, %1
|
||||
ret i32 0
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user