mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-04 21:30:49 +00:00
Canonicalize (X+C1)*C2 -> X*C2+C1*C2
This implements Transforms/InstCombine/add.ll:test31 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@26519 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
5128d2323f
commit
ab51f3fa96
@ -1623,6 +1623,19 @@ Instruction *InstCombiner::visitMul(BinaryOperator &I) {
|
||||
return ReplaceInstUsesWith(I, Op0); // Eliminate 'mul double %X, 1.0'
|
||||
}
|
||||
|
||||
if (BinaryOperator *Op0I = dyn_cast<BinaryOperator>(Op0))
|
||||
if (Op0I->getOpcode() == Instruction::Add && Op0I->hasOneUse() &&
|
||||
isa<ConstantInt>(Op0I->getOperand(1))) {
|
||||
// Canonicalize (X+C1)*C2 -> X*C2+C1*C2.
|
||||
Instruction *Add = BinaryOperator::createMul(Op0I->getOperand(0),
|
||||
Op1, "tmp");
|
||||
InsertNewInstBefore(Add, I);
|
||||
Value *C1C2 = ConstantExpr::getMul(Op1,
|
||||
cast<Constant>(Op0I->getOperand(1)));
|
||||
return BinaryOperator::createAdd(Add, C1C2);
|
||||
|
||||
}
|
||||
|
||||
// Try to fold constant mul into select arguments.
|
||||
if (SelectInst *SI = dyn_cast<SelectInst>(Op0))
|
||||
if (Instruction *R = FoldOpIntoSelect(I, SI, this))
|
||||
|
Loading…
Reference in New Issue
Block a user