mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-03-28 06:35:49 +00:00
Implement xor.ll:test22
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@21713 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
d152380ba8
commit
7aed7ac5e1
@ -3550,6 +3550,15 @@ Instruction *InstCombiner::visitCastInst(CastInst &CI) {
|
||||
->getOpcode(), Op0c, Op1c);
|
||||
}
|
||||
}
|
||||
|
||||
// cast (xor bool X, true) to int --> xor (cast bool X to int), 1
|
||||
if (SrcBitSize == 1 && SrcI->getOpcode() == Instruction::Xor &&
|
||||
Op1 == ConstantBool::True &&
|
||||
(!Op0->hasOneUse() || !isa<SetCondInst>(Op0))) {
|
||||
Value *New = InsertOperandCastBefore(Op0, DestTy, &CI);
|
||||
return BinaryOperator::createXor(New,
|
||||
ConstantInt::get(CI.getType(), 1));
|
||||
}
|
||||
break;
|
||||
case Instruction::Shl:
|
||||
// Allow changing the sign of the source operand. Do not allow changing
|
||||
|
Loading…
x
Reference in New Issue
Block a user