#include "llvm/Analysis/AliasSetTracker.h"
#include "llvm/Analysis/Dominators.h"
#include "llvm/Support/CFG.h"
-#include "llvm/Support/StableBasicBlockNumbering.h"
#include "llvm/Transforms/Utils/PromoteMemToReg.h"
#include "llvm/Transforms/Utils/Local.h"
#include "Support/CommandLine.h"
LoopInfo *LI; // Current LoopInfo
DominatorTree *DT; // Dominator Tree for the current Loop...
DominanceFrontier *DF; // Current Dominance Frontier
- StableBasicBlockNumbering *BBNum; // Stable IDs for basic blocks
// State that is updated as we process loops
bool Changed; // Set to true when we change anything.
/// runOnFunction - For LICM, this simply traverses the loop structure of the
/// function, hoisting expressions out of loops if possible.
///
-bool LICM::runOnFunction(Function &F) {
+bool LICM::runOnFunction(Function &) {
Changed = false;
// Get our Loop and Alias Analysis information...
DF = &getAnalysis<DominanceFrontier>();
DT = &getAnalysis<DominatorTree>();
- // Get a stable numbering of basic blocks.
- StableBasicBlockNumbering CurBBNum(&F);
- BBNum = &CurBBNum;
-
// Hoist expressions out of all of the top-level loops.
for (LoopInfo::iterator I = LI->begin(), E = LI->end(); I != E; ++I) {
AliasSetTracker AST(*AA);
}
const std::vector<DominatorTree::Node*> &Children = N->getChildren();
- std::vector<std::pair<unsigned, DominatorTree::Node*> > ChildrenWithIDs;
- ChildrenWithIDs.reserve(Children.size());
- for (unsigned i = 0, e = Children.size(); i != e; ++i) {
- unsigned ID = BBNum->getNumber(Children[i]->getBlock());
- ChildrenWithIDs.push_back(std::make_pair(ID, Children[i]));
- }
-
- std::sort(ChildrenWithIDs.begin(), ChildrenWithIDs.end());
for (unsigned i = 0, e = Children.size(); i != e; ++i)
- HoistRegion(ChildrenWithIDs[i].second);
+ HoistRegion(Children[i]);
}
/// canSinkOrHoistInst - Return true if the hoister and sinker can handle this