aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Analysis/ValueTracking.cpp
diff options
context:
space:
mode:
authorDavid Bolvansky <david.bolvansky@gmail.com>2018-05-22 20:27:36 +0000
committerDavid Bolvansky <david.bolvansky@gmail.com>2018-05-22 20:27:36 +0000
commit1f343fa0e0fe95055ff29c571821c5f91215daeb (patch)
treef3c18fd19c52fa1fa9051ce0e54d619fba04801e /llvm/lib/Analysis/ValueTracking.cpp
parent3ad27e92bcd4b761a174eca003cfcad6ad36a436 (diff)
downloadllvm-1f343fa0e0fe95055ff29c571821c5f91215daeb.zip
llvm-1f343fa0e0fe95055ff29c571821c5f91215daeb.tar.gz
llvm-1f343fa0e0fe95055ff29c571821c5f91215daeb.tar.bz2
[InstCombine] Remove calloc transformations
Summary: Previous patch does not care if a value is changed between calloc and strlen. This needs to be removed from InstCombine and maybe moved to DSE later after some rework. Reviewers: efriedma Reviewed By: efriedma Subscribers: llvm-commits Differential Revision: https://reviews.llvm.org/D47218 llvm-svn: 333022
Diffstat (limited to 'llvm/lib/Analysis/ValueTracking.cpp')
-rw-r--r--llvm/lib/Analysis/ValueTracking.cpp30
1 files changed, 1 insertions, 29 deletions
diff --git a/llvm/lib/Analysis/ValueTracking.cpp b/llvm/lib/Analysis/ValueTracking.cpp
index 95e7a9b..0b0dfde 100644
--- a/llvm/lib/Analysis/ValueTracking.cpp
+++ b/llvm/lib/Analysis/ValueTracking.cpp
@@ -3372,39 +3372,11 @@ static uint64_t GetStringLengthH(const Value *V,
return NullIndex + 1;
}
-static bool isStringFromCalloc(const Value *Str, const TargetLibraryInfo *TLI) {
- const CallInst *Calloc = dyn_cast<CallInst>(Str);
- if (!Calloc)
- return false;
-
- const Function *InnerCallee = Calloc->getCalledFunction();
- if (!InnerCallee)
- return false;
-
- LibFunc Func;
- if (!TLI->getLibFunc(*InnerCallee, Func) || !TLI->has(Func) ||
- Func != LibFunc_calloc)
- return false;
-
- const ConstantInt *N = dyn_cast<ConstantInt>(Calloc->getOperand(0));
- const ConstantInt *Size = dyn_cast<ConstantInt>(Calloc->getOperand(1));
-
- if (!N || !Size)
- return false;
-
- if (N->isNullValue() || Size->isNullValue())
- return false;
-
- return true;
-}
-
/// If we can compute the length of the string pointed to by
/// the specified pointer, return 'len+1'. If we can't, return 0.
-uint64_t llvm::GetStringLength(const Value *V, const TargetLibraryInfo *TLI, unsigned CharSize) {
+uint64_t llvm::GetStringLength(const Value *V, unsigned CharSize) {
if (!V->getType()->isPointerTy())
return 0;
- if (isStringFromCalloc(V, TLI))
- return 1;
SmallPtrSet<const PHINode*, 32> PHIs;
uint64_t Len = GetStringLengthH(V, PHIs, CharSize);