diff options
author | Dan Gohman <gohman@apple.com> | 2010-09-09 18:37:31 +0000 |
---|---|---|
committer | Dan Gohman <gohman@apple.com> | 2010-09-09 18:37:31 +0000 |
commit | c8ddbdabb697b20b948c1a56af6062f26691532a (patch) | |
tree | 5d824f38bab1ab4ea837b4fbac39c8023cffc53e | |
parent | e744541788298d0ef129aa2d38e9aef865218311 (diff) | |
download | external_llvm-c8ddbdabb697b20b948c1a56af6062f26691532a.zip external_llvm-c8ddbdabb697b20b948c1a56af6062f26691532a.tar.gz external_llvm-c8ddbdabb697b20b948c1a56af6062f26691532a.tar.bz2 |
Extend the getDependence query with support for PHI translation.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@113521 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/llvm/Analysis/AliasAnalysis.h | 9 | ||||
-rw-r--r-- | lib/Analysis/AliasAnalysis.cpp | 61 | ||||
-rw-r--r-- | lib/Analysis/BasicAliasAnalysis.cpp | 9 |
3 files changed, 64 insertions, 15 deletions
diff --git a/include/llvm/Analysis/AliasAnalysis.h b/include/llvm/Analysis/AliasAnalysis.h index c74f9e1..a03e0c8 100644 --- a/include/llvm/Analysis/AliasAnalysis.h +++ b/include/llvm/Analysis/AliasAnalysis.h @@ -340,17 +340,20 @@ public: /// WARNING: This is an experimental interface. DependenceResult getDependence(const Instruction *First, const Instruction *Second) { - return getDependence(First, Default, Second, Default); + return getDependence(First, 0, Default, Second, 0, Default); } /// getDependence - Determine the dependence relationship between the /// instructions. This does not include "register" dependencies; it just /// considers memory references and other side effects. This overload - /// accepts additional flags to refine the query. + /// has additional parameters to allow phi-translated addresses to be + /// specified, and additional flags to refine the query. /// WARNING: This is an experimental interface. virtual DependenceResult getDependence(const Instruction *First, + const Value *FirstPHITranslatedAddr, DependenceQueryFlags FirstFlags, const Instruction *Second, + const Value *SecondPHITranslatedAddr, DependenceQueryFlags SecondFlags); //===--------------------------------------------------------------------===// @@ -403,8 +406,10 @@ protected: /// getDependenceViaModRefInfo - Helper function for implementing getDependence /// in implementations which already have getModRefInfo implementations. DependenceResult getDependenceViaModRefInfo(const Instruction *First, + const Value *FirstPHITranslatedAddr, DependenceQueryFlags FirstFlags, const Instruction *Second, + const Value *SecondPHITranslatedAddr, DependenceQueryFlags SecondFlags); }; diff --git a/lib/Analysis/AliasAnalysis.cpp b/lib/Analysis/AliasAnalysis.cpp index 536b759..93597ca 100644 --- a/lib/Analysis/AliasAnalysis.cpp +++ b/lib/Analysis/AliasAnalysis.cpp @@ -190,11 +190,14 @@ AliasAnalysis::getModRefBehavior(const Function *F) { AliasAnalysis::DependenceResult AliasAnalysis::getDependence(const Instruction *First, + const Value *FirstPHITranslatedAddr, DependenceQueryFlags FirstFlags, const Instruction *Second, + const Value *SecondPHITranslatedAddr, DependenceQueryFlags SecondFlags) { assert(AA && "AA didn't call InitializeAliasAnalyais in its run method!"); - return AA->getDependence(First, FirstFlags, Second, SecondFlags); + return AA->getDependence(First, FirstPHITranslatedAddr, FirstFlags, + Second, SecondPHITranslatedAddr, SecondFlags); } //===----------------------------------------------------------------------===// @@ -255,17 +258,23 @@ AliasAnalysis::getModRefInfo(const VAArgInst *V, const Value *P, unsigned Size) AliasAnalysis::DependenceResult AliasAnalysis::getDependenceViaModRefInfo(const Instruction *First, + const Value *FirstPHITranslatedAddr, DependenceQueryFlags FirstFlags, const Instruction *Second, + const Value *SecondPHITranslatedAddr, DependenceQueryFlags SecondFlags) { if (const LoadInst *L = dyn_cast<LoadInst>(First)) { // Be over-conservative with volatile for now. if (L->isVolatile()) return Unknown; + // If we don't have a phi-translated address, use the actual one. + if (!FirstPHITranslatedAddr) + FirstPHITranslatedAddr = L->getPointerOperand(); + // Forward this query to getModRefInfo. switch (getModRefInfo(Second, - L->getPointerOperand(), + FirstPHITranslatedAddr, getTypeStoreSize(L->getType()))) { case NoModRef: // Second doesn't reference First's memory, so they're independent. @@ -280,10 +289,14 @@ AliasAnalysis::getDependenceViaModRefInfo(const Instruction *First, // If it's loading the same size from the same address, we can // give a more precise result. if (const LoadInst *SecondL = dyn_cast<LoadInst>(Second)) { + // If we don't have a phi-translated address, use the actual one. + if (!SecondPHITranslatedAddr) + SecondPHITranslatedAddr = SecondL->getPointerOperand(); + unsigned LSize = getTypeStoreSize(L->getType()); unsigned SecondLSize = getTypeStoreSize(SecondL->getType()); - if (alias(L->getPointerOperand(), LSize, - SecondL->getPointerOperand(), SecondLSize) == + if (alias(FirstPHITranslatedAddr, LSize, + SecondPHITranslatedAddr, SecondLSize) == MustAlias) { // If the loads are the same size, it's ReadThenRead. if (LSize == SecondLSize) @@ -307,10 +320,14 @@ AliasAnalysis::getDependenceViaModRefInfo(const Instruction *First, // If it's storing the same size to the same address, we can // give a more precise result. if (const StoreInst *SecondS = dyn_cast<StoreInst>(Second)) { + // If we don't have a phi-translated address, use the actual one. + if (!SecondPHITranslatedAddr) + SecondPHITranslatedAddr = SecondS->getPointerOperand(); + unsigned LSize = getTypeStoreSize(L->getType()); unsigned SecondSSize = getTypeStoreSize(SecondS->getType()); - if (alias(L->getPointerOperand(), LSize, - SecondS->getPointerOperand(), SecondSSize) == + if (alias(FirstPHITranslatedAddr, LSize, + SecondPHITranslatedAddr, SecondSSize) == MustAlias) { // If the load and the store are the same size, it's ReadThenWrite. if (LSize == SecondSSize) @@ -332,9 +349,13 @@ AliasAnalysis::getDependenceViaModRefInfo(const Instruction *First, if (S->isVolatile()) return Unknown; + // If we don't have a phi-translated address, use the actual one. + if (!FirstPHITranslatedAddr) + FirstPHITranslatedAddr = S->getPointerOperand(); + // Forward this query to getModRefInfo. switch (getModRefInfo(Second, - S->getPointerOperand(), + FirstPHITranslatedAddr, getTypeStoreSize(S->getValueOperand()->getType()))) { case NoModRef: // Second doesn't reference First's memory, so they're independent. @@ -349,10 +370,14 @@ AliasAnalysis::getDependenceViaModRefInfo(const Instruction *First, // If it's loading the same size from the same address, we can // give a more precise result. if (const LoadInst *SecondL = dyn_cast<LoadInst>(Second)) { + // If we don't have a phi-translated address, use the actual one. + if (!SecondPHITranslatedAddr) + SecondPHITranslatedAddr = SecondL->getPointerOperand(); + unsigned SSize = getTypeStoreSize(S->getValueOperand()->getType()); unsigned SecondLSize = getTypeStoreSize(SecondL->getType()); - if (alias(S->getPointerOperand(), SSize, - SecondL->getPointerOperand(), SecondLSize) == + if (alias(FirstPHITranslatedAddr, SSize, + SecondPHITranslatedAddr, SecondLSize) == MustAlias) { // If the store and the load are the same size, it's WriteThenRead. if (SSize == SecondLSize) @@ -376,10 +401,14 @@ AliasAnalysis::getDependenceViaModRefInfo(const Instruction *First, // If it's storing the same size to the same address, we can // give a more precise result. if (const StoreInst *SecondS = dyn_cast<StoreInst>(Second)) { + // If we don't have a phi-translated address, use the actual one. + if (!SecondPHITranslatedAddr) + SecondPHITranslatedAddr = SecondS->getPointerOperand(); + unsigned SSize = getTypeStoreSize(S->getValueOperand()->getType()); unsigned SecondSSize = getTypeStoreSize(SecondS->getType()); - if (alias(S->getPointerOperand(), SSize, - SecondS->getPointerOperand(), SecondSSize) == + if (alias(FirstPHITranslatedAddr, SSize, + SecondPHITranslatedAddr, SecondSSize) == MustAlias) { // If the stores are the same size, it's WriteThenWrite. if (SSize == SecondSSize) @@ -401,12 +430,20 @@ AliasAnalysis::getDependenceViaModRefInfo(const Instruction *First, } } else if (const VAArgInst *V = dyn_cast<VAArgInst>(First)) { + // If we don't have a phi-translated address, use the actual one. + if (!FirstPHITranslatedAddr) + FirstPHITranslatedAddr = V->getPointerOperand(); + // Forward this query to getModRefInfo. - if (getModRefInfo(Second, V->getOperand(0), UnknownSize) == NoModRef) + if (getModRefInfo(Second, FirstPHITranslatedAddr, UnknownSize) == NoModRef) // Second doesn't reference First's memory, so they're independent. return Independent; } else if (ImmutableCallSite FirstCS = cast<Value>(First)) { + assert(!FirstPHITranslatedAddr && + !SecondPHITranslatedAddr && + "PHI translation with calls not supported yet!"); + // If both instructions are calls/invokes we can use the two-callsite // form of getModRefInfo. if (ImmutableCallSite SecondCS = cast<Value>(Second)) diff --git a/lib/Analysis/BasicAliasAnalysis.cpp b/lib/Analysis/BasicAliasAnalysis.cpp index 597e34b..354e66d 100644 --- a/lib/Analysis/BasicAliasAnalysis.cpp +++ b/lib/Analysis/BasicAliasAnalysis.cpp @@ -172,8 +172,10 @@ namespace { } virtual DependenceResult getDependence(const Instruction *First, + const Value *FirstPHITranslatedAddr, DependenceQueryFlags FirstFlags, const Instruction *Second, + const Value *SecondPHITranslatedAddr, DependenceQueryFlags SecondFlags) { return Unknown; } @@ -531,8 +533,10 @@ namespace { virtual ModRefBehavior getModRefBehavior(const Function *F); virtual DependenceResult getDependence(const Instruction *First, + const Value *FirstPHITranslatedAddr, DependenceQueryFlags FirstFlags, const Instruction *Second, + const Value *SecondPHITranslatedAddr, DependenceQueryFlags SecondFlags); /// getAdjustedAnalysisPointer - This method is used when a pass implements @@ -748,11 +752,14 @@ BasicAliasAnalysis::getModRefInfo(ImmutableCallSite CS, AliasAnalysis::DependenceResult BasicAliasAnalysis::getDependence(const Instruction *First, + const Value *FirstPHITranslatedAddr, DependenceQueryFlags FirstFlags, const Instruction *Second, + const Value *SecondPHITranslatedAddr, DependenceQueryFlags SecondFlags) { // We don't have anything special to say yet. - return getDependenceViaModRefInfo(First, FirstFlags, Second, SecondFlags); + return getDependenceViaModRefInfo(First, FirstPHITranslatedAddr, FirstFlags, + Second, SecondPHITranslatedAddr, SecondFlags); } /// aliasGEP - Provide a bunch of ad-hoc rules to disambiguate a GEP instruction |