diff options
author | David Bolvansky <david.bolvansky@gmail.com> | 2018-05-22 20:27:36 +0000 |
---|---|---|
committer | David Bolvansky <david.bolvansky@gmail.com> | 2018-05-22 20:27:36 +0000 |
commit | 1f343fa0e0fe95055ff29c571821c5f91215daeb (patch) | |
tree | f3c18fd19c52fa1fa9051ce0e54d619fba04801e /llvm/lib/Analysis/ValueTracking.cpp | |
parent | 3ad27e92bcd4b761a174eca003cfcad6ad36a436 (diff) | |
download | llvm-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.cpp | 30 |
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); |