From: Devang Patel Date: Tue, 31 Jul 2007 08:01:41 +0000 (+0000) Subject: Implement Simple Analysis interfaces - cloneBasicBlockAnalysis and deleteAnalysisValue. X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=91d22c8b1ec2ad8f2f29804b729473ccf720fb3e;p=oota-llvm.git Implement Simple Analysis interfaces - cloneBasicBlockAnalysis and deleteAnalysisValue. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@40626 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Scalar/LICM.cpp b/lib/Transforms/Scalar/LICM.cpp index a4aa12ababd..669afa33ac9 100644 --- a/lib/Transforms/Scalar/LICM.cpp +++ b/lib/Transforms/Scalar/LICM.cpp @@ -102,6 +102,13 @@ namespace { AliasSetTracker *CurAST; // AliasSet information for the current loop... std::map LoopToAliasMap; + /// cloneBasicBlockAnalysis - Simple Analysis hook. Clone alias set info. + void cloneBasicBlockAnalysis(BasicBlock *From, BasicBlock *To, Loop *L); + + /// deleteAnalysisValue - Simple Analysis hook. Delete value V from alias + /// set. + void deleteAnalysisValue(Value *V, Loop *L); + /// SinkRegion - Walk the specified region of the CFG (defined by all blocks /// dominated by the specified block, and that are in the current loop) in /// reverse depth first order w.r.t the DominatorTree. This allows us to @@ -798,3 +805,22 @@ void LICM::FindPromotableValuesInLoop( } } } + +/// cloneBasicBlockAnalysis - Simple Analysis hook. Clone alias set info. +void LICM::cloneBasicBlockAnalysis(BasicBlock *From, BasicBlock *To, Loop *L) { + AliasSetTracker *AST = LoopToAliasMap[L]; + if (!AST) + return; + + AST->copyValue(From, To); +} + +/// deleteAnalysisValue - Simple Analysis hook. Delete value V from alias +/// set. +void LICM::deleteAnalysisValue(Value *V, Loop *L) { + AliasSetTracker *AST = LoopToAliasMap[L]; + if (!AST) + return; + + AST->deleteValue(V); +}