aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Analysis/DataStructure/DataStructureAA.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-03-17 20:16:58 +0000
committerChris Lattner <sabre@nondot.org>2005-03-17 20:16:58 +0000
commitb5525529bde86c0ff71e53e2dfcc102788c72f13 (patch)
treeed524c2aecb1ba27fad41cb0e9e8184955aa57fb /llvm/lib/Analysis/DataStructure/DataStructureAA.cpp
parent8dd1491e713fd44b0a3ffdaa8db1d25c48d944ed (diff)
downloadllvm-b5525529bde86c0ff71e53e2dfcc102788c72f13.zip
llvm-b5525529bde86c0ff71e53e2dfcc102788c72f13.tar.gz
llvm-b5525529bde86c0ff71e53e2dfcc102788c72f13.tar.bz2
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/Analysis/DataStructure/DataStructureAA.cpp')
-rw-r--r--llvm/lib/Analysis/DataStructure/DataStructureAA.cpp19
1 files changed, 11 insertions, 8 deletions
diff --git a/llvm/lib/Analysis/DataStructure/DataStructureAA.cpp b/llvm/lib/Analysis/DataStructure/DataStructureAA.cpp
index 74fdb1f..2d62162 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;
}