mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 20:32:21 +00:00
Handle a special case xor undef, undef -> 0. Technically this should be transformed to undef. But this is such a common idiom (misuse) we are going to handle it.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@48791 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
1cf962b874
commit
d34af7875b
@ -4425,8 +4425,13 @@ Instruction *InstCombiner::visitXor(BinaryOperator &I) {
|
||||
bool Changed = SimplifyCommutative(I);
|
||||
Value *Op0 = I.getOperand(0), *Op1 = I.getOperand(1);
|
||||
|
||||
if (isa<UndefValue>(Op1))
|
||||
if (isa<UndefValue>(Op1)) {
|
||||
if (isa<UndefValue>(Op0))
|
||||
// Handle undef ^ undef -> 0 special case. This is a common
|
||||
// idiom (misuse).
|
||||
return ReplaceInstUsesWith(I, Constant::getNullValue(I.getType()));
|
||||
return ReplaceInstUsesWith(I, Op1); // X ^ undef -> undef
|
||||
}
|
||||
|
||||
// xor X, X = 0, even if X is nested in a sequence of Xor's.
|
||||
if (Instruction *Result = AssociativeOpt(I, XorSelf(Op1))) {
|
||||
|
6
test/Transforms/InstCombine/xor-undef.ll
Normal file
6
test/Transforms/InstCombine/xor-undef.ll
Normal file
@ -0,0 +1,6 @@
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep zeroinitializer
|
||||
|
||||
define <2 x i64> @f() {
|
||||
%tmp = xor <2 x i64> undef, undef
|
||||
ret <2 x i64> %tmp
|
||||
}
|
Loading…
Reference in New Issue
Block a user