summaryrefslogtreecommitdiff
path: root/lib/Analysis/ValueTracking.cpp
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2009-06-22 22:02:32 +0000
committerDan Gohman <gohman@apple.com>2009-06-22 22:02:32 +0000
commitbd5ce52740700bb482fb2b5a03bce781acbf2941 (patch)
treee2cbc3025d8f470db998aed7a664e58b993df750 /lib/Analysis/ValueTracking.cpp
parent753ad615f96c3d56d6f17983bdba88012e88677c (diff)
downloadllvm-bd5ce52740700bb482fb2b5a03bce781acbf2941.tar.gz
llvm-bd5ce52740700bb482fb2b5a03bce781acbf2941.tar.bz2
llvm-bd5ce52740700bb482fb2b5a03bce781acbf2941.tar.xz
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.cpp6
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;