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" |
Owen Anderson | 9cb7f49 | 2007-10-03 21:25:45 +0000 | [diff] [blame] | 22 | #include "llvm/Analysis/DominatorInternals.h" |
Chris Lattner | cd7c287 | 2003-12-07 00:35:42 +0000 | [diff] [blame] | 23 | using namespace llvm; |
Brian Gaeke | d0fde30 | 2003-11-11 22:41:34 +0000 | [diff] [blame] | 24 | |
Chris Lattner | 94108ab | 2001-07-06 16:58:22 +0000 | [diff] [blame] | 25 | //===----------------------------------------------------------------------===// |
Owen Anderson | 3dc6776 | 2007-04-15 08:47:27 +0000 | [diff] [blame] | 26 | // PostDominatorTree Implementation |
Nate Begeman | 442b32b | 2006-03-11 02:20:46 +0000 | [diff] [blame] | 27 | //===----------------------------------------------------------------------===// |
| 28 | |
Devang Patel | 1997473 | 2007-05-03 01:11:54 +0000 | [diff] [blame] | 29 | char PostDominatorTree::ID = 0; |
| 30 | char PostDominanceFrontier::ID = 0; |
Owen Anderson | 3dc6776 | 2007-04-15 08:47:27 +0000 | [diff] [blame] | 31 | static RegisterPass<PostDominatorTree> |
Devang Patel | 9f83512 | 2008-03-20 23:27:18 +0000 | [diff] [blame] | 32 | F("postdomtree", "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 | 1f23e16 | 2008-04-16 04:21:16 +0000 | [diff] [blame^] | 36 | DEBUG(DT->dump()); |
Owen Anderson | 471ab54 | 2007-10-03 03:20:17 +0000 | [diff] [blame] | 37 | return false; |
| 38 | } |
| 39 | |
Chris Lattner | ccacd3c | 2006-01-08 08:22:18 +0000 | [diff] [blame] | 40 | //===----------------------------------------------------------------------===// |
Chris Lattner | 4c9df7c | 2002-08-02 16:43:03 +0000 | [diff] [blame] | 41 | // PostDominanceFrontier Implementation |
Chris Lattner | 1715229 | 2001-07-02 05:46:38 +0000 | [diff] [blame] | 42 | //===----------------------------------------------------------------------===// |
| 43 | |
Chris Lattner | 5d8925c | 2006-08-27 22:30:17 +0000 | [diff] [blame] | 44 | static RegisterPass<PostDominanceFrontier> |
Devang Patel | 9f83512 | 2008-03-20 23:27:18 +0000 | [diff] [blame] | 45 | H("postdomfrontier", "Post-Dominance Frontier Construction", true, true); |
Chris Lattner | 93193f8 | 2002-01-31 00:42:27 +0000 | [diff] [blame] | 46 | |
Chris Lattner | 1b7f7dc | 2002-04-28 16:21:30 +0000 | [diff] [blame] | 47 | const DominanceFrontier::DomSetType & |
Misha Brukman | 2b37d7c | 2005-04-21 21:13:18 +0000 | [diff] [blame] | 48 | PostDominanceFrontier::calculate(const PostDominatorTree &DT, |
Devang Patel | 2604242 | 2007-06-04 00:32:22 +0000 | [diff] [blame] | 49 | const DomTreeNode *Node) { |
Chris Lattner | 94108ab | 2001-07-06 16:58:22 +0000 | [diff] [blame] | 50 | // Loop over CFG successors to calculate DFlocal[Node] |
Chris Lattner | c444a42 | 2003-09-11 16:26:13 +0000 | [diff] [blame] | 51 | BasicBlock *BB = Node->getBlock(); |
Chris Lattner | 94108ab | 2001-07-06 16:58:22 +0000 | [diff] [blame] | 52 | DomSetType &S = Frontiers[BB]; // The new set to fill in... |
Chris Lattner | 706e61e | 2003-09-10 20:37:08 +0000 | [diff] [blame] | 53 | if (getRoots().empty()) return S; |
Chris Lattner | 94108ab | 2001-07-06 16:58:22 +0000 | [diff] [blame] | 54 | |
Chris Lattner | 706e61e | 2003-09-10 20:37:08 +0000 | [diff] [blame] | 55 | if (BB) |
| 56 | for (pred_iterator SI = pred_begin(BB), SE = pred_end(BB); |
Devang Patel | 5a713cc | 2007-04-18 01:19:55 +0000 | [diff] [blame] | 57 | SI != SE; ++SI) { |
Misha Brukman | 2f2d065 | 2003-09-11 18:14:24 +0000 | [diff] [blame] | 58 | // Does Node immediately dominate this predecessor? |
Devang Patel | 2604242 | 2007-06-04 00:32:22 +0000 | [diff] [blame] | 59 | DomTreeNode *SINode = DT[*SI]; |
Devang Patel | 5a713cc | 2007-04-18 01:19:55 +0000 | [diff] [blame] | 60 | if (SINode && SINode->getIDom() != Node) |
Chris Lattner | 706e61e | 2003-09-10 20:37:08 +0000 | [diff] [blame] | 61 | S.insert(*SI); |
Devang Patel | 5a713cc | 2007-04-18 01:19:55 +0000 | [diff] [blame] | 62 | } |
Chris Lattner | 94108ab | 2001-07-06 16:58:22 +0000 | [diff] [blame] | 63 | |
| 64 | // At this point, S is DFlocal. Now we union in DFup's of our children... |
| 65 | // Loop through and visit the nodes that Node immediately dominates (Node's |
| 66 | // children in the IDomTree) |
| 67 | // |
Devang Patel | 2604242 | 2007-06-04 00:32:22 +0000 | [diff] [blame] | 68 | for (DomTreeNode::const_iterator |
Chris Lattner | ce6ef11 | 2002-07-26 18:40:14 +0000 | [diff] [blame] | 69 | NI = Node->begin(), NE = Node->end(); NI != NE; ++NI) { |
Devang Patel | 2604242 | 2007-06-04 00:32:22 +0000 | [diff] [blame] | 70 | DomTreeNode *IDominee = *NI; |
Chris Lattner | ce6ef11 | 2002-07-26 18:40:14 +0000 | [diff] [blame] | 71 | const DomSetType &ChildDF = calculate(DT, IDominee); |
Chris Lattner | 94108ab | 2001-07-06 16:58:22 +0000 | [diff] [blame] | 72 | |
| 73 | DomSetType::const_iterator CDFI = ChildDF.begin(), CDFE = ChildDF.end(); |
| 74 | for (; CDFI != CDFE; ++CDFI) { |
Devang Patel | 9a51157 | 2007-06-07 17:47:21 +0000 | [diff] [blame] | 75 | if (!DT.properlyDominates(Node, DT[*CDFI])) |
Misha Brukman | dedf2bd | 2005-04-22 04:01:18 +0000 | [diff] [blame] | 76 | S.insert(*CDFI); |
Chris Lattner | 94108ab | 2001-07-06 16:58:22 +0000 | [diff] [blame] | 77 | } |
| 78 | } |
| 79 | |
| 80 | return S; |
| 81 | } |
Chris Lattner | a69fd90 | 2002-08-21 23:43:50 +0000 | [diff] [blame] | 82 | |
Reid Spencer | 4f1bd9e | 2006-06-07 22:00:26 +0000 | [diff] [blame] | 83 | // Ensure that this .cpp file gets linked when PostDominators.h is used. |
| 84 | DEFINING_FILE_FOR(PostDominanceFrontier) |