diff options
| author | Chris Lattner <sabre@nondot.org> | 2003-03-10 18:24:17 +0000 | 
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2003-03-10 18:24:17 +0000 | 
| commit | 1bbb7b6f19571bb150e3ad70082426ecc42c5ce1 (patch) | |
| tree | 7b978f1c1a94e210bbf2e30ce4910c79230761b7 /llvm/lib/Transforms/Scalar | |
| parent | 96c4dd94ef854becaa608485d05e37e6eda86d02 (diff) | |
| download | bcm5719-llvm-1bbb7b6f19571bb150e3ad70082426ecc42c5ce1.tar.gz bcm5719-llvm-1bbb7b6f19571bb150e3ad70082426ecc42c5ce1.zip | |
Implement:  (A|B)^B == A & (~B)
llvm-svn: 5728
Diffstat (limited to 'llvm/lib/Transforms/Scalar')
| -rw-r--r-- | llvm/lib/Transforms/Scalar/InstructionCombining.cpp | 25 | 
1 files changed, 25 insertions, 0 deletions
| diff --git a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp index 890f1fb6051..0dfb235d892 100644 --- a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp @@ -493,6 +493,31 @@ Instruction *InstCombiner::visitXor(BinaryOperator &I) {        return ReplaceInstUsesWith(I,                                  ConstantIntegral::getAllOnesValue(I.getType())); + + +  if (Instruction *Op1I = dyn_cast<Instruction>(Op1)) +    if (Op1I->getOpcode() == Instruction::Or) +      if (Op1I->getOperand(0) == Op0) {              // B^(B|A) == (A|B)^B +        cast<BinaryOperator>(Op1I)->swapOperands(); +        I.swapOperands(); +        std::swap(Op0, Op1); +      } else if (Op1I->getOperand(1) == Op0) {       // B^(A|B) == (A|B)^B +        I.swapOperands(); +        std::swap(Op0, Op1); +      } + +  if (Instruction *Op0I = dyn_cast<Instruction>(Op0)) +    if (Op0I->getOpcode() == Instruction::Or && Op0I->use_size() == 1) { +      if (Op0I->getOperand(0) == Op1)                // (B|A)^B == (A|B)^B +        cast<BinaryOperator>(Op0I)->swapOperands(); +      if (Op0I->getOperand(1) == Op1) {              // (A|B)^B == A & ~B +        Value *NotB = BinaryOperator::createNot(Op1, Op1->getName()+".not", &I); +        WorkList.push_back(cast<Instruction>(NotB)); +        return BinaryOperator::create(Instruction::And, Op0I->getOperand(0), +                                      NotB); +      } +    } +    return Changed ? &I : 0;  } | 

