diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2017-04-16 16:01:22 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2017-04-16 16:01:22 +0000 | 
| commit | 71d5a2540a98c81f5bcaeb48805e0e2881f530ef (patch) | |
| tree | 5343938942df402b49ec7300a1c25a2d4ccd5821 /lib/Analysis/AliasAnalysis.cpp | |
| parent | 31bbf64f3a4974a2d6c8b3b27ad2f519caf74057 (diff) | |
Diffstat (limited to 'lib/Analysis/AliasAnalysis.cpp')
| -rw-r--r-- | lib/Analysis/AliasAnalysis.cpp | 18 | 
1 files changed, 13 insertions, 5 deletions
| diff --git a/lib/Analysis/AliasAnalysis.cpp b/lib/Analysis/AliasAnalysis.cpp index 84da76be98bb..4c29aeaa622f 100644 --- a/lib/Analysis/AliasAnalysis.cpp +++ b/lib/Analysis/AliasAnalysis.cpp @@ -332,8 +332,8 @@ FunctionModRefBehavior AAResults::getModRefBehavior(const Function *F) {  ModRefInfo AAResults::getModRefInfo(const LoadInst *L,                                      const MemoryLocation &Loc) { -  // Be conservative in the face of volatile/atomic. -  if (!L->isUnordered()) +  // Be conservative in the face of atomic. +  if (isStrongerThan(L->getOrdering(), AtomicOrdering::Unordered))      return MRI_ModRef;    // If the load address doesn't alias the given address, it doesn't read @@ -347,8 +347,8 @@ ModRefInfo AAResults::getModRefInfo(const LoadInst *L,  ModRefInfo AAResults::getModRefInfo(const StoreInst *S,                                      const MemoryLocation &Loc) { -  // Be conservative in the face of volatile/atomic. -  if (!S->isUnordered()) +  // Be conservative in the face of atomic. +  if (isStrongerThan(S->getOrdering(), AtomicOrdering::Unordered))      return MRI_ModRef;    if (Loc.Ptr) { @@ -367,6 +367,14 @@ ModRefInfo AAResults::getModRefInfo(const StoreInst *S,    return MRI_Mod;  } +ModRefInfo AAResults::getModRefInfo(const FenceInst *S, const MemoryLocation &Loc) { +  // If we know that the location is a constant memory location, the fence +  // cannot modify this location. +  if (Loc.Ptr && pointsToConstantMemory(Loc)) +    return MRI_Ref; +  return MRI_ModRef; +} +  ModRefInfo AAResults::getModRefInfo(const VAArgInst *V,                                      const MemoryLocation &Loc) { @@ -689,7 +697,7 @@ AAResults llvm::createLegacyPMAAResults(Pass &P, Function &F,  bool llvm::isNoAliasCall(const Value *V) {    if (auto CS = ImmutableCallSite(V)) -    return CS.paramHasAttr(0, Attribute::NoAlias); +    return CS.hasRetAttr(Attribute::NoAlias);    return false;  } | 
