aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Analysis/BasicAliasAnalysis.cpp
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2010-09-08 01:32:20 +0000
committerDan Gohman <gohman@apple.com>2010-09-08 01:32:20 +0000
commit65924111bf648db8f20599f485be918c7aa1e7ef (patch)
tree1eb9bd1eebce3d470fe216ed7739711ee0174458 /lib/Analysis/BasicAliasAnalysis.cpp
parent0cfcf93c95af91e809ef740eb0ab368477226b40 (diff)
downloadexternal_llvm-65924111bf648db8f20599f485be918c7aa1e7ef.zip
external_llvm-65924111bf648db8f20599f485be918c7aa1e7ef.tar.gz
external_llvm-65924111bf648db8f20599f485be918c7aa1e7ef.tar.bz2
Add a new experimental generalized dependence query interface to
AliasAnalysis, and some code for implementing the new query on top of existing implementations by making standard alias and getModRefInfo queries. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@113329 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/BasicAliasAnalysis.cpp')
-rw-r--r--lib/Analysis/BasicAliasAnalysis.cpp20
1 files changed, 20 insertions, 0 deletions
diff --git a/lib/Analysis/BasicAliasAnalysis.cpp b/lib/Analysis/BasicAliasAnalysis.cpp
index 113c72b..597e34b 100644
--- a/lib/Analysis/BasicAliasAnalysis.cpp
+++ b/lib/Analysis/BasicAliasAnalysis.cpp
@@ -171,6 +171,13 @@ namespace {
return ModRef;
}
+ virtual DependenceResult getDependence(const Instruction *First,
+ DependenceQueryFlags FirstFlags,
+ const Instruction *Second,
+ DependenceQueryFlags SecondFlags) {
+ return Unknown;
+ }
+
virtual void deleteValue(Value *V) {}
virtual void copyValue(Value *From, Value *To) {}
@@ -523,6 +530,11 @@ namespace {
/// For use when the call site is not known.
virtual ModRefBehavior getModRefBehavior(const Function *F);
+ virtual DependenceResult getDependence(const Instruction *First,
+ DependenceQueryFlags FirstFlags,
+ const Instruction *Second,
+ DependenceQueryFlags SecondFlags);
+
/// getAdjustedAnalysisPointer - This method is used when a pass implements
/// an analysis interface through multiple inheritance. If needed, it
/// should override this to adjust the this pointer as needed for the
@@ -734,6 +746,14 @@ BasicAliasAnalysis::getModRefInfo(ImmutableCallSite CS,
return AliasAnalysis::getModRefInfo(CS, P, Size);
}
+AliasAnalysis::DependenceResult
+BasicAliasAnalysis::getDependence(const Instruction *First,
+ DependenceQueryFlags FirstFlags,
+ const Instruction *Second,
+ DependenceQueryFlags SecondFlags) {
+ // We don't have anything special to say yet.
+ return getDependenceViaModRefInfo(First, FirstFlags, Second, SecondFlags);
+}
/// aliasGEP - Provide a bunch of ad-hoc rules to disambiguate a GEP instruction
/// against another pointer. We know that V1 is a GEP, but we don't know