diff options
author | Duncan Sands <baldrick@free.fr> | 2011-10-26 20:55:21 +0000 |
---|---|---|
committer | Duncan Sands <baldrick@free.fr> | 2011-10-26 20:55:21 +0000 |
commit | ba286d7c73f2d1929c6fd627b49006cd5fb4f069 (patch) | |
tree | bffb40c2eb372c8da327b32c7c003e752ac7c231 /llvm/lib/Analysis/InstructionSimplify.cpp | |
parent | b005070b838126fe0b3bed69ccccb613c4f727ff (diff) | |
download | bcm5719-llvm-ba286d7c73f2d1929c6fd627b49006cd5fb4f069.tar.gz bcm5719-llvm-ba286d7c73f2d1929c6fd627b49006cd5fb4f069.zip |
The maximum power of 2 dividing a power of 2 is itself. This occurs
in 403.gcc and was spotted by my super-optimizer.
llvm-svn: 143054
Diffstat (limited to 'llvm/lib/Analysis/InstructionSimplify.cpp')
-rw-r--r-- | llvm/lib/Analysis/InstructionSimplify.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/llvm/lib/Analysis/InstructionSimplify.cpp b/llvm/lib/Analysis/InstructionSimplify.cpp index 131cc97d237..d9e3400f895 100644 --- a/llvm/lib/Analysis/InstructionSimplify.cpp +++ b/llvm/lib/Analysis/InstructionSimplify.cpp @@ -1197,6 +1197,15 @@ static Value *SimplifyAndInst(Value *Op0, Value *Op1, const TargetData *TD, (A == Op0 || B == Op0)) return Op0; + // A & (-A) = A if A is a power of two or zero. + if (match(Op0, m_Neg(m_Specific(Op1))) || + match(Op1, m_Neg(m_Specific(Op0)))) { + if (isPowerOfTwo(Op0, TD, /*OrZero*/true)) + return Op0; + if (isPowerOfTwo(Op1, TD, /*OrZero*/true)) + return Op1; + } + // Try some generic simplifications for associative operations. if (Value *V = SimplifyAssociativeBinOp(Instruction::And, Op0, Op1, TD, DT, MaxRecurse)) |