summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
diff options
context:
space:
mode:
authorCraig Topper <craig.topper@intel.com>2018-09-13 18:52:58 +0000
committerCraig Topper <craig.topper@intel.com>2018-09-13 18:52:58 +0000
commit8fc05ce34016bcdf2529ed6bcfcb05e450b4e034 (patch)
tree63864ae899b059f5421a48fc4264adf3cae26779 /llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
parent3fc5e72d84178c55faef8784c2d0e6c33a5639cd (diff)
downloadbcm5719-llvm-8fc05ce34016bcdf2529ed6bcfcb05e450b4e034.tar.gz
bcm5719-llvm-8fc05ce34016bcdf2529ed6bcfcb05e450b4e034.zip
[InstCombine] Fold (xor (min/max X, Y), -1) -> (max/min ~X, ~Y) when X and Y are freely invertible.
This allows the xor to be removed completely. This might help with recomitting r341674, but seems good regardless. Coincidentally fixes PR38915. Differential Revision: https://reviews.llvm.org/D51964 llvm-svn: 342163
Diffstat (limited to 'llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp')
-rw-r--r--llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp11
1 files changed, 11 insertions, 0 deletions
diff --git a/llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp b/llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
index a1a85339be6..898063871ac 100644
--- a/llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
+++ b/llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
@@ -2898,6 +2898,17 @@ Instruction *InstCombiner::visitXor(BinaryOperator &I) {
return SelectInst::Create(
Builder.CreateICmp(getInverseMinMaxPred(SPF), NotX, Y), NotX, Y);
}
+
+ // If both sides are freely invertible, then we can get rid of the xor
+ // completely.
+ if (IsFreeToInvert(LHS, !LHS->hasNUsesOrMore(3)) &&
+ IsFreeToInvert(RHS, !RHS->hasNUsesOrMore(3))) {
+ Value *NotLHS = Builder.CreateNot(LHS);
+ Value *NotRHS = Builder.CreateNot(RHS);
+ return SelectInst::Create(
+ Builder.CreateICmp(getInverseMinMaxPred(SPF), NotLHS, NotRHS),
+ NotLHS, NotRHS);
+ }
}
}
OpenPOWER on IntegriCloud