diff options
| author | Philip Reames <listmail@philipreames.com> | 2016-01-05 00:49:14 +0000 | 
|---|---|---|
| committer | Philip Reames <listmail@philipreames.com> | 2016-01-05 00:49:14 +0000 | 
| commit | a694a0b14101a02cd40e756911c4e5d603f0d6ed (patch) | |
| tree | ecaa04ea2867235e5e50b16ea7b897e954b5019b /llvm/lib | |
| parent | d9fe082ba75c6c0f42a795e441e3b7525fd07db1 (diff) | |
| download | bcm5719-llvm-a694a0b14101a02cd40e756911c4e5d603f0d6ed.tar.gz bcm5719-llvm-a694a0b14101a02cd40e756911c4e5d603f0d6ed.zip | |
[MDA] Don't be quite as conservative for noalias functions
If we encounter a noalias call that alias analysis can't analyse, we can fall down into the generic call handling rather than giving up entirely. I noticed this while reading through the code for another purpose.
I can't seem to write a test case which changes; that sorta makes sense given any test case would have to be an inconsistency in AA. Suggestions welcome.
Differential Revision: http://reviews.llvm.org/D15825
llvm-svn: 256802
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Analysis/MemoryDependenceAnalysis.cpp | 14 | 
1 files changed, 7 insertions, 7 deletions
| diff --git a/llvm/lib/Analysis/MemoryDependenceAnalysis.cpp b/llvm/lib/Analysis/MemoryDependenceAnalysis.cpp index 06dcf94676c..6918360536a 100644 --- a/llvm/lib/Analysis/MemoryDependenceAnalysis.cpp +++ b/llvm/lib/Analysis/MemoryDependenceAnalysis.cpp @@ -685,13 +685,13 @@ MemDepResult MemoryDependenceAnalysis::getSimplePointerDependencyFrom(          return MemDepResult::getDef(Inst);        if (isInvariantLoad)          continue; -      // Be conservative if the accessed pointer may alias the allocation. -      if (AA->alias(Inst, AccessPtr) != NoAlias) -        return MemDepResult::getClobber(Inst); -      // If the allocation is not aliased and does not read memory (like -      // strdup), it is safe to ignore. -      if (isa<AllocaInst>(Inst) || -          isMallocLikeFn(Inst, TLI) || isCallocLikeFn(Inst, TLI)) +      // Be conservative if the accessed pointer may alias the allocation - +      // fallback to the generic handling below. +      if ((AA->alias(Inst, AccessPtr) == NoAlias) && +          // If the allocation is not aliased and does not read memory (like +          // strdup), it is safe to ignore. +          (isa<AllocaInst>(Inst) || isMallocLikeFn(Inst, TLI) || +           isCallocLikeFn(Inst, TLI)))          continue;      } | 

