mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-26 23:32:58 +00:00
Support more cases...
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2490 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
fa78358a05
commit
b35dde1df4
@ -88,33 +88,52 @@ static bool SimplifyBinOp(BinaryOperator *I) {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// dyn_castNegInst - Given a 'sub' instruction, return the RHS of the
|
||||||
|
// instruction if the LHS is a constant zero (which is the 'negate' form).
|
||||||
|
//
|
||||||
|
static inline Value *dyn_castNegInst(Value *V) {
|
||||||
|
Instruction *I = dyn_cast<Instruction>(V);
|
||||||
|
if (!I || I->getOpcode() != Instruction::Sub) return 0;
|
||||||
|
|
||||||
|
if (I->getOperand(0) == Constant::getNullValue(I->getType()))
|
||||||
|
return I->getOperand(1);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
Instruction *InstCombiner::visitAdd(BinaryOperator *I) {
|
Instruction *InstCombiner::visitAdd(BinaryOperator *I) {
|
||||||
if (I->use_empty()) return 0; // Don't fix dead add instructions...
|
if (I->use_empty()) return 0; // Don't fix dead add instructions...
|
||||||
bool Changed = SimplifyBinOp(I);
|
bool Changed = SimplifyBinOp(I);
|
||||||
Value *Op1 = I->getOperand(0);
|
Value *LHS = I->getOperand(0), *RHS = I->getOperand(1);
|
||||||
|
|
||||||
// Simplify add instructions with a constant RHS...
|
|
||||||
if (Constant *Op2 = dyn_cast<Constant>(I->getOperand(1))) {
|
|
||||||
// Eliminate 'add int %X, 0'
|
// Eliminate 'add int %X, 0'
|
||||||
if (I->getType()->isIntegral() && Op2->isNullValue()) {
|
if (I->getType()->isIntegral() &&
|
||||||
|
RHS == Constant::getNullValue(I->getType())) {
|
||||||
AddUsesToWorkList(I); // Add all modified instrs to worklist
|
AddUsesToWorkList(I); // Add all modified instrs to worklist
|
||||||
I->replaceAllUsesWith(Op1);
|
I->replaceAllUsesWith(LHS);
|
||||||
return I;
|
return I;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (BinaryOperator *IOp1 = dyn_cast<BinaryOperator>(Op1)) {
|
// -B + A --> A - B
|
||||||
Changed |= SimplifyBinOp(IOp1);
|
if (Value *V = dyn_castNegInst(LHS))
|
||||||
|
return BinaryOperator::create(Instruction::Sub, RHS, LHS);
|
||||||
|
|
||||||
if (IOp1->getOpcode() == Instruction::Add &&
|
// A + -B --> A - B
|
||||||
isa<Constant>(IOp1->getOperand(1))) {
|
if (Value *V = dyn_castNegInst(RHS))
|
||||||
|
return BinaryOperator::create(Instruction::Sub, LHS, RHS);
|
||||||
|
|
||||||
|
// Simplify add instructions with a constant RHS...
|
||||||
|
if (Constant *Op2 = dyn_cast<Constant>(RHS)) {
|
||||||
|
if (BinaryOperator *ILHS = dyn_cast<BinaryOperator>(LHS)) {
|
||||||
|
if (ILHS->getOpcode() == Instruction::Add &&
|
||||||
|
isa<Constant>(ILHS->getOperand(1))) {
|
||||||
// Fold:
|
// Fold:
|
||||||
// %Y = add int %X, 1
|
// %Y = add int %X, 1
|
||||||
// %Z = add int %Y, 1
|
// %Z = add int %Y, 1
|
||||||
// into:
|
// into:
|
||||||
// %Z = add int %X, 2
|
// %Z = add int %X, 2
|
||||||
//
|
//
|
||||||
if (Constant *Val = *Op2 + *cast<Constant>(IOp1->getOperand(1))) {
|
if (Constant *Val = *Op2 + *cast<Constant>(ILHS->getOperand(1))) {
|
||||||
I->setOperand(0, IOp1->getOperand(0));
|
I->setOperand(0, ILHS->getOperand(0));
|
||||||
I->setOperand(1, Val);
|
I->setOperand(1, Val);
|
||||||
return I;
|
return I;
|
||||||
}
|
}
|
||||||
@ -142,6 +161,14 @@ Instruction *InstCombiner::visitSub(BinaryOperator *I) {
|
|||||||
if (Constant *RHS = *Constant::getNullValue(I->getType()) - *Op2) // 0 - RHS
|
if (Constant *RHS = *Constant::getNullValue(I->getType()) - *Op2) // 0 - RHS
|
||||||
return BinaryOperator::create(Instruction::Add, Op0, RHS, I->getName());
|
return BinaryOperator::create(Instruction::Add, Op0, RHS, I->getName());
|
||||||
|
|
||||||
|
// If this is a 'C = -B', check to see if 'B = -A', so that C = A...
|
||||||
|
if (Op0 == Constant::getNullValue(I->getType()))
|
||||||
|
if (Value *V = dyn_castNegInst(Op1)) {
|
||||||
|
AddUsesToWorkList(I); // Add all modified instrs to worklist
|
||||||
|
I->replaceAllUsesWith(V);
|
||||||
|
return I;
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user