Chris Lattner | 4c9df7c | 2002-08-02 16:43:03 +0000 | [diff] [blame] | 1 | //===- PostDominators.cpp - Post-Dominator Calculation --------------------===// |
Misha Brukman | 2b37d7c | 2005-04-21 21:13:18 +0000 | [diff] [blame] | 2 | // |
John Criswell | b576c94 | 2003-10-20 19:43:21 +0000 | [diff] [blame] | 3 | // The LLVM Compiler Infrastructure |
| 4 | // |
Chris Lattner | 4ee451d | 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. |
Misha Brukman | 2b37d7c | 2005-04-21 21:13:18 +0000 | [diff] [blame] | 7 | // |
John Criswell | b576c94 | 2003-10-20 19:43:21 +0000 | [diff] [blame] | 8 | //===----------------------------------------------------------------------===// |
Chris Lattner | 1715229 | 2001-07-02 05:46:38 +0000 | [diff] [blame] | 9 | // |
Chris Lattner | 4c9df7c | 2002-08-02 16:43:03 +0000 | [diff] [blame] | 10 | // This file implements the post-dominator construction algorithms. |
Chris Lattner | 1715229 | 2001-07-02 05:46:38 +0000 | [diff] [blame] | 11 | // |
| 12 | //===----------------------------------------------------------------------===// |
| 13 | |
Owen Anderson | 1f23e16 | 2008-04-16 04:21:16 +0000 | [diff] [blame] | 14 | #define DEBUG_TYPE "postdomtree" |
| 15 | |
Chris Lattner | a69fd90 | 2002-08-21 23:43:50 +0000 | [diff] [blame] | 16 | #include "llvm/Analysis/PostDominators.h" |
Misha Brukman | 47b14a4 | 2004-07-29 17:30:56 +0000 | [diff] [blame] | 17 | #include "llvm/Instructions.h" |
Chris Lattner | 221d688 | 2002-02-12 21:07:25 +0000 | [diff] [blame] | 18 | #include "llvm/Support/CFG.h" |
Owen Anderson | 1f23e16 | 2008-04-16 04:21:16 +0000 | [diff] [blame] | 19 | #include "llvm/Support/Debug.h" |
Reid Spencer | 551ccae | 2004-09-01 22:55:40 +0000 | [diff] [blame] | 20 | #include "llvm/ADT/DepthFirstIterator.h" |
| 21 | #include "llvm/ADT/SetOperations.h" |
Chris Lattner | 9fc5cdf | 2011-01-02 22:09:33 +0000 | [diff] [blame] | 22 | #include "llvm/Assembly/Writer.h" |
Owen Anderson | 9cb7f49 | 2007-10-03 21:25:45 +0000 | [diff] [blame] | 23 | #include "llvm/Analysis/DominatorInternals.h" |
Chris Lattner | cd7c287 | 2003-12-07 00:35:42 +0000 | [diff] [blame] | 24 | using namespace llvm; |
Brian Gaeke | d0fde30 | 2003-11-11 22:41:34 +0000 | [diff] [blame] | 25 | |
Chris Lattner | 94108ab | 2001-07-06 16:58:22 +0000 | [diff] [blame] | 26 | //===----------------------------------------------------------------------===// |
Owen Anderson | 3dc6776 | 2007-04-15 08:47:27 +0000 | [diff] [blame] | 27 | // PostDominatorTree Implementation |
Nate Begeman | 442b32b | 2006-03-11 02:20:46 +0000 | [diff] [blame] | 28 | //===----------------------------------------------------------------------===// |
| 29 | |
Devang Patel | 1997473 | 2007-05-03 01:11:54 +0000 | [diff] [blame] | 30 | char PostDominatorTree::ID = 0; |
Owen Anderson | d13db2c | 2010-07-21 22:09:45 +0000 | [diff] [blame] | 31 | INITIALIZE_PASS(PostDominatorTree, "postdomtree", |
Owen Anderson | ce665bd | 2010-10-07 22:25:06 +0000 | [diff] [blame] | 32 | "Post-Dominator Tree Construction", true, true) |
Nate Begeman | 442b32b | 2006-03-11 02:20:46 +0000 | [diff] [blame] | 33 | |
Owen Anderson | 471ab54 | 2007-10-03 03:20:17 +0000 | [diff] [blame] | 34 | bool PostDominatorTree::runOnFunction(Function &F) { |
Owen Anderson | d20cc14 | 2007-10-23 20:58:37 +0000 | [diff] [blame] | 35 | DT->recalculate(F); |
Owen Anderson | 471ab54 | 2007-10-03 03:20:17 +0000 | [diff] [blame] | 36 | return false; |
| 37 | } |
| 38 | |
Chris Lattner | 791102f | 2009-08-23 05:17:37 +0000 | [diff] [blame] | 39 | PostDominatorTree::~PostDominatorTree() { |
Torok Edwin | f605580 | 2008-05-03 20:25:26 +0000 | [diff] [blame] | 40 | delete DT; |
| 41 | } |
| 42 | |
Chris Lattner | 45cfe54 | 2009-08-23 06:03:38 +0000 | [diff] [blame] | 43 | void PostDominatorTree::print(raw_ostream &OS, const Module *) const { |
| 44 | DT->print(OS); |
Chris Lattner | 791102f | 2009-08-23 05:17:37 +0000 | [diff] [blame] | 45 | } |
| 46 | |
| 47 | |
Owen Anderson | 5771d6c | 2008-05-29 17:00:13 +0000 | [diff] [blame] | 48 | FunctionPass* llvm::createPostDomTree() { |
| 49 | return new PostDominatorTree(); |
| 50 | } |
| 51 | |