diff options
| author | Chris Lattner <sabre@nondot.org> | 2005-03-17 20:16:58 +0000 | 
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2005-03-17 20:16:58 +0000 | 
| commit | b5525529bde86c0ff71e53e2dfcc102788c72f13 (patch) | |
| tree | ed524c2aecb1ba27fad41cb0e9e8184955aa57fb /llvm/lib | |
| parent | 8dd1491e713fd44b0a3ffdaa8db1d25c48d944ed (diff) | |
| download | bcm5719-llvm-b5525529bde86c0ff71e53e2dfcc102788c72f13.tar.gz bcm5719-llvm-b5525529bde86c0ff71e53e2dfcc102788c72f13.zip | |
simplify this function a bit, allow DS-AA to build on/improve the mod/ref
results returned by AA, not just use one or the other.
llvm-svn: 20662
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Analysis/DataStructure/DataStructureAA.cpp | 19 | 
1 files changed, 11 insertions, 8 deletions
| diff --git a/llvm/lib/Analysis/DataStructure/DataStructureAA.cpp b/llvm/lib/Analysis/DataStructure/DataStructureAA.cpp index 74fdb1f590f..2d62162d1d9 100644 --- a/llvm/lib/Analysis/DataStructure/DataStructureAA.cpp +++ b/llvm/lib/Analysis/DataStructure/DataStructureAA.cpp @@ -173,9 +173,11 @@ AliasAnalysis::AliasResult DSAA::alias(const Value *V1, unsigned V1Size,  ///  AliasAnalysis::ModRefResult  DSAA::getModRefInfo(CallSite CS, Value *P, unsigned Size) { +  AliasAnalysis::ModRefResult Result =AliasAnalysis::getModRefInfo(CS, P, Size);    Function *F = CS.getCalledFunction(); -  if (!F || F->isExternal()) -    return AliasAnalysis::getModRefInfo(CS, P, Size); + +  if (!F || F->isExternal() || Result == NoModRef) +    return Result;    // Clone the function TD graph, clearing off Mod/Ref flags    const Function *csParent = CS.getInstruction()->getParent()->getParent(); @@ -189,12 +191,13 @@ DSAA::getModRefInfo(CallSite CS, Value *P, unsigned Size) {    // Report the flags that have been added    const DSNodeHandle &DSH = TDGraph.getNodeForValue(P); -  if (const DSNode *N = DSH.getNode()) -    if (N->isModified()) -      return N->isRead() ? ModRef : Mod; -    else -      return N->isRead() ? Ref : NoModRef; -  return NoModRef; +  if (const DSNode *N = DSH.getNode()) { +    if (!N->isModified())   // We proved it was not modified. +      Result = ModRefResult(Result & ~Mod); +    if (!N->isRead())       // We proved it was not read. +      Result = ModRefResult(Result & ~Ref); +  } +  return Result;  } | 

