mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Implement InstCombine/xor.ll:test(15|16)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@9708 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -1002,7 +1002,14 @@ Instruction *InstCombiner::visitXor(BinaryOperator &I) { | ||||
|                                  SCI->getOperand(0), SCI->getOperand(1)); | ||||
|            | ||||
|       if (ConstantInt *Op0CI = dyn_cast<ConstantInt>(Op0I->getOperand(1))) | ||||
|         if (Op0I->getOpcode() == Instruction::And) { | ||||
|         if (Op0I->getOpcode() == Instruction::Add) { | ||||
|           // ~(X-c) --> (-c-1)-X | ||||
|           if (RHS->isAllOnesValue())  | ||||
|             return BinaryOperator::create(Instruction::Sub, | ||||
|                                           *-*Op0CI - | ||||
|                                               *ConstantInt::get(I.getType(), 1), | ||||
|                                           Op0I->getOperand(0)); | ||||
|         } else if (Op0I->getOpcode() == Instruction::And) { | ||||
|           // (X & C1) ^ C2 --> (X & C1) | C2 iff (C1&C2) == 0 | ||||
|           if ((*RHS & *Op0CI)->isNullValue()) | ||||
|             return BinaryOperator::create(Instruction::Or, Op0, RHS); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user