diff options
author | Dan Gohman <gohman@apple.com> | 2009-06-22 22:02:32 +0000 |
---|---|---|
committer | Dan Gohman <gohman@apple.com> | 2009-06-22 22:02:32 +0000 |
commit | bd5ce52740700bb482fb2b5a03bce781acbf2941 (patch) | |
tree | e2cbc3025d8f470db998aed7a664e58b993df750 /lib/Analysis/ValueTracking.cpp | |
parent | 753ad615f96c3d56d6f17983bdba88012e88677c (diff) |
Fix llvm::ComputeNumSignBits to handle pointer types
conservatively correctly, instead of aborting.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@73908 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/ValueTracking.cpp')
-rw-r--r-- | lib/Analysis/ValueTracking.cpp | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/lib/Analysis/ValueTracking.cpp b/lib/Analysis/ValueTracking.cpp index 17ffa2d2de..7509e91bdc 100644 --- a/lib/Analysis/ValueTracking.cpp +++ b/lib/Analysis/ValueTracking.cpp @@ -624,8 +624,12 @@ bool llvm::MaskedValueIsZero(Value *V, const APInt &Mask, /// 'Op' must have a scalar integer type. /// unsigned llvm::ComputeNumSignBits(Value *V, TargetData *TD, unsigned Depth) { + assert((TD || V->getType()->isIntOrIntVector()) && + "ComputeNumSignBits requires a TargetData object to operate " + "on non-integer values!"); const Type *Ty = V->getType(); - unsigned TyBits = Ty->getScalarSizeInBits(); + unsigned TyBits = TD ? TD->getTypeSizeInBits(V->getType()->getScalarType()) : + Ty->getScalarSizeInBits(); unsigned Tmp, Tmp2; unsigned FirstAnswer = 1; |