| Owen Anderson | 9b8f34f | 2007-10-31 03:30:14 +0000 | [diff] [blame] | 1 | //===- MachineDominators.cpp - Machine Dominator Calculation --------------===// | 
|  | 2 | // | 
|  | 3 | //                     The LLVM Compiler Infrastructure | 
|  | 4 | // | 
| Chris Lattner | f3ebc3f | 2007-12-29 20:36:04 +0000 | [diff] [blame] | 5 | // This file is distributed under the University of Illinois Open Source | 
|  | 6 | // License. See LICENSE.TXT for details. | 
| Owen Anderson | 9b8f34f | 2007-10-31 03:30:14 +0000 | [diff] [blame] | 7 | // | 
|  | 8 | //===----------------------------------------------------------------------===// | 
|  | 9 | // | 
|  | 10 | // This file implements simple dominator construction algorithms for finding | 
|  | 11 | // forward dominators on machine functions. | 
|  | 12 | // | 
|  | 13 | //===----------------------------------------------------------------------===// | 
|  | 14 |  | 
|  | 15 | #include "llvm/CodeGen/MachineDominators.h" | 
| Bill Wendling | 0c20943 | 2008-01-04 20:54:55 +0000 | [diff] [blame] | 16 | #include "llvm/CodeGen/Passes.h" | 
| Owen Anderson | 9b8f34f | 2007-10-31 03:30:14 +0000 | [diff] [blame] | 17 |  | 
|  | 18 | using namespace llvm; | 
|  | 19 |  | 
| John McCall | 323c30c | 2009-12-16 00:13:24 +0000 | [diff] [blame] | 20 | namespace llvm { | 
| Owen Anderson | 9b8f34f | 2007-10-31 03:30:14 +0000 | [diff] [blame] | 21 | TEMPLATE_INSTANTIATION(class DomTreeNodeBase<MachineBasicBlock>); | 
|  | 22 | TEMPLATE_INSTANTIATION(class DominatorTreeBase<MachineBasicBlock>); | 
| John McCall | 323c30c | 2009-12-16 00:13:24 +0000 | [diff] [blame] | 23 | } | 
| Owen Anderson | 9b8f34f | 2007-10-31 03:30:14 +0000 | [diff] [blame] | 24 |  | 
| Chris Lattner | 647e61a | 2008-01-05 20:15:42 +0000 | [diff] [blame] | 25 | char MachineDominatorTree::ID = 0; | 
|  | 26 |  | 
| Dan Gohman | d78c400 | 2008-05-13 00:00:25 +0000 | [diff] [blame] | 27 | static RegisterPass<MachineDominatorTree> | 
|  | 28 | E("machinedomtree", "MachineDominator Tree Construction", true); | 
| Bill Wendling | 0c20943 | 2008-01-04 20:54:55 +0000 | [diff] [blame] | 29 |  | 
| Dan Gohman | 0479aa5 | 2008-05-13 02:05:11 +0000 | [diff] [blame] | 30 | const PassInfo *const llvm::MachineDominatorsID = &E; | 
| Dan Gohman | 906152a | 2009-01-05 17:59:02 +0000 | [diff] [blame] | 31 |  | 
|  | 32 | void MachineDominatorTree::getAnalysisUsage(AnalysisUsage &AU) const { | 
|  | 33 | AU.setPreservesAll(); | 
|  | 34 | MachineFunctionPass::getAnalysisUsage(AU); | 
|  | 35 | } | 
|  | 36 |  | 
|  | 37 | bool MachineDominatorTree::runOnMachineFunction(MachineFunction &F) { | 
|  | 38 | DT->recalculate(F); | 
|  | 39 |  | 
|  | 40 | return false; | 
|  | 41 | } | 
|  | 42 |  | 
|  | 43 | MachineDominatorTree::MachineDominatorTree() | 
| Dan Gohman | 38a9631 | 2009-02-18 05:09:16 +0000 | [diff] [blame] | 44 | : MachineFunctionPass(&ID) { | 
| Dan Gohman | 906152a | 2009-01-05 17:59:02 +0000 | [diff] [blame] | 45 | DT = new DominatorTreeBase<MachineBasicBlock>(false); | 
|  | 46 | } | 
|  | 47 |  | 
|  | 48 | MachineDominatorTree::~MachineDominatorTree() { | 
|  | 49 | DT->releaseMemory(); | 
|  | 50 | delete DT; | 
|  | 51 | } | 
|  | 52 |  | 
|  | 53 | void MachineDominatorTree::releaseMemory() { | 
|  | 54 | DT->releaseMemory(); | 
|  | 55 | } | 
| Chris Lattner | b1d782b | 2009-08-23 05:17:37 +0000 | [diff] [blame] | 56 |  | 
| Chris Lattner | 1362602 | 2009-08-23 06:03:38 +0000 | [diff] [blame] | 57 | void MachineDominatorTree::print(raw_ostream &OS, const Module*) const { | 
|  | 58 | DT->print(OS); | 
| Chris Lattner | b1d782b | 2009-08-23 05:17:37 +0000 | [diff] [blame] | 59 | } |