diff options
author | Sanjay Patel <spatel@rotateright.com> | 2016-06-23 17:41:59 +0000 |
---|---|---|
committer | Sanjay Patel <spatel@rotateright.com> | 2016-06-23 17:41:59 +0000 |
commit | e0536210718c5958e58773eb219f9424d7864509 (patch) | |
tree | 2c9b30384f8c9cd6f23bd8eb19c64fc81257e2aa /llvm/lib/Analysis/ValueTracking.cpp | |
parent | ef3358d5797a2d38f6f885a9f1d5fe771b6e7119 (diff) | |
download | llvm-e0536210718c5958e58773eb219f9424d7864509.zip llvm-e0536210718c5958e58773eb219f9424d7864509.tar.gz llvm-e0536210718c5958e58773eb219f9424d7864509.tar.bz2 |
[ValueTracking] simplify logic in ComputeNumSignBits (NFCI)
This was noted in http://reviews.llvm.org/D21610 . The previous code
predated the use of APInt ( http://reviews.llvm.org/rL47654 ), so it
had to account for the fixed width of uint64_t.
Now that we're using the variable width APInt, we can remove some
complexity.
llvm-svn: 273584
Diffstat (limited to 'llvm/lib/Analysis/ValueTracking.cpp')
-rw-r--r-- | llvm/lib/Analysis/ValueTracking.cpp | 25 |
1 files changed, 9 insertions, 16 deletions
diff --git a/llvm/lib/Analysis/ValueTracking.cpp b/llvm/lib/Analysis/ValueTracking.cpp index 97b3692..16dd307 100644 --- a/llvm/lib/Analysis/ValueTracking.cpp +++ b/llvm/lib/Analysis/ValueTracking.cpp @@ -2153,25 +2153,18 @@ unsigned ComputeNumSignBits(Value *V, unsigned Depth, const Query &Q) { return VecSignBits; APInt KnownZero(TyBits, 0), KnownOne(TyBits, 0); - APInt Mask; computeKnownBits(V, KnownZero, KnownOne, Depth, Q); - if (KnownZero.isNegative()) { // sign bit is 0 - Mask = KnownZero; - } else if (KnownOne.isNegative()) { // sign bit is 1; - Mask = KnownOne; - } else { - // Nothing known. - return FirstAnswer; - } + // If we know that the sign bit is either zero or one, determine the number of + // identical bits in the top of the input value. + if (KnownZero.isNegative()) + return std::max(FirstAnswer, KnownZero.countLeadingOnes()); + + if (KnownOne.isNegative()) + return std::max(FirstAnswer, KnownOne.countLeadingOnes()); - // Okay, we know that the sign bit in Mask is set. Use CLZ to determine - // the number of identical bits in the top of the input value. - Mask = ~Mask; - Mask <<= Mask.getBitWidth()-TyBits; - // Return # leading zeros. We use 'min' here in case Val was zero before - // shifting. We don't want to return '64' as for an i32 "0". - return std::max(FirstAnswer, std::min(TyBits, Mask.countLeadingZeros())); + // computeKnownBits gave us no extra information about the top bits. + return FirstAnswer; } /// This function computes the integer multiple of Base that equals V. |