diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2011-08-17 19:31:49 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2011-08-17 19:31:49 +0000 |
commit | ad3cfe7933513804a826cfdc6f13aa242c6f6a31 (patch) | |
tree | ec7a54afaebed69375c2e616bc868444a5001787 /llvm/lib | |
parent | 004df6e0536802fb291f25c88d3ee029502a805c (diff) | |
download | bcm5719-llvm-ad3cfe7933513804a826cfdc6f13aa242c6f6a31.tar.gz bcm5719-llvm-ad3cfe7933513804a826cfdc6f13aa242c6f6a31.zip |
Revert r137781; I agree with Duncan's comment that the situation in question is clearly impossible given the current structure of the code.
llvm-svn: 137853
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/Analysis/InstructionSimplify.cpp | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/llvm/lib/Analysis/InstructionSimplify.cpp b/llvm/lib/Analysis/InstructionSimplify.cpp index 89e55a46516..cfff9c03c83 100644 --- a/llvm/lib/Analysis/InstructionSimplify.cpp +++ b/llvm/lib/Analysis/InstructionSimplify.cpp @@ -1348,11 +1348,6 @@ static Value *SimplifyXorInst(Value *Op0, Value *Op1, const TargetData *TD, std::swap(Op0, Op1); } - // A ^ A = 0 - // Do this first so that we catch the undef ^ undef "idiom". - if (Op0 == Op1) - return Constant::getNullValue(Op0->getType()); - // A ^ undef -> undef if (match(Op1, m_Undef())) return Op1; @@ -1361,6 +1356,10 @@ static Value *SimplifyXorInst(Value *Op0, Value *Op1, const TargetData *TD, if (match(Op1, m_Zero())) return Op0; + // A ^ A = 0 + if (Op0 == Op1) + return Constant::getNullValue(Op0->getType()); + // A ^ ~A = ~A ^ A = -1 if (match(Op0, m_Not(m_Specific(Op1))) || match(Op1, m_Not(m_Specific(Op0)))) |