diff options
Diffstat (limited to 'llvm/lib/Transforms')
-rw-r--r-- | llvm/lib/Transforms/Scalar/InstructionCombining.cpp | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp index 041122401ce..709c6a91129 100644 --- a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp @@ -510,11 +510,11 @@ Instruction *InstCombiner::visitXor(BinaryOperator &I) { 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 + if (Op0I->getOperand(1) == Op1) { // (A|B)^B == ~B & A 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 BinaryOperator::create(Instruction::And, NotB, + Op0I->getOperand(0)); } } |