blob: 85817da2e4f21db05567d92f1ce6864a7b2c0d2c [file] [log] [blame]
Owen Anderson6cbd8da2009-06-09 19:30:45 +00001//===- LazyLiveness.cpp - Lazy, CFG-invariant liveness information --------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This pass implements a lazy liveness analysis as per "Fast Liveness Checking
11// for SSA-form Programs," by Boissinot, et al.
12//
13//===----------------------------------------------------------------------===//
14
15#define DEBUG_TYPE "lazyliveness"
16#include "llvm/CodeGen/LazyLiveness.h"
17#include "llvm/CodeGen/MachineDominators.h"
18#include "llvm/CodeGen/MachineRegisterInfo.h"
19#include "llvm/CodeGen/Passes.h"
20#include "llvm/ADT/DepthFirstIterator.h"
21#include "llvm/ADT/PostOrderIterator.h"
22using namespace llvm;
23
24char LazyLiveness::ID = 0;
Owen Andersonfdf72c62009-06-12 21:41:29 +000025static RegisterPass<LazyLiveness> X("lazy-liveness", "Lazy Liveness Analysis");
Owen Anderson6cbd8da2009-06-09 19:30:45 +000026
27void LazyLiveness::computeBackedgeChain(MachineFunction& mf,
28 MachineBasicBlock* MBB) {
29 SparseBitVector<128> tmp = rv[MBB];
30 tmp.set(preorder[MBB]);
31 tmp &= backedge_source;
32 calculated.set(preorder[MBB]);
33
34 for (SparseBitVector<128>::iterator I = tmp.begin(); I != tmp.end(); ++I) {
35 MachineBasicBlock* SrcMBB = rev_preorder[*I];
36
37 for (MachineBasicBlock::succ_iterator SI = SrcMBB->succ_begin();
38 SI != SrcMBB->succ_end(); ++SI) {
39 MachineBasicBlock* TgtMBB = *SI;
40
41 if (backedges.count(std::make_pair(SrcMBB, TgtMBB)) &&
42 !rv[MBB].test(preorder[TgtMBB])) {
43 if (!calculated.test(preorder[TgtMBB]))
44 computeBackedgeChain(mf, TgtMBB);
45
46 tv[MBB].set(preorder[TgtMBB]);
47 tv[MBB] |= tv[TgtMBB];
48 }
49 }
50
51 tv[MBB].reset(preorder[MBB]);
52 }
53}
54
55bool LazyLiveness::runOnMachineFunction(MachineFunction &mf) {
56 rv.clear();
57 tv.clear();
58 backedges.clear();
59 backedge_source.clear();
60 backedge_target.clear();
61 calculated.clear();
62 preorder.clear();
63
64 MRI = &mf.getRegInfo();
65
66 // Step 0: Compute preorder numbering for all MBBs.
67 unsigned num = 0;
68 for (df_iterator<MachineBasicBlock*> DI = df_begin(&*mf.begin());
Owen Andersonfdf72c62009-06-12 21:41:29 +000069 DI != df_end(&*mf.begin()); ++DI) {
Owen Anderson6cbd8da2009-06-09 19:30:45 +000070 preorder[*DI] = num++;
71 rev_preorder.push_back(*DI);
72 }
73
74 // Step 1: Compute the transitive closure of the CFG, ignoring backedges.
75 for (po_iterator<MachineBasicBlock*> POI = po_begin(&*mf.begin());
76 POI != po_end(&*mf.begin()); ++POI) {
77 MachineBasicBlock* MBB = *POI;
78 SparseBitVector<128>& entry = rv[MBB];
79 entry.set(preorder[MBB]);
80
81 for (MachineBasicBlock::succ_iterator SI = MBB->succ_begin();
82 SI != MBB->succ_end(); ++SI) {
83 DenseMap<MachineBasicBlock*, SparseBitVector<128> >::iterator SII =
84 rv.find(*SI);
85
86 // Because we're iterating in postorder, any successor that does not yet
87 // have an rv entry must be on a backedge.
88 if (SII != rv.end()) {
89 entry |= SII->second;
90 } else {
91 backedges.insert(std::make_pair(MBB, *SI));
92 backedge_source.set(preorder[MBB]);
93 backedge_target.set(preorder[*SI]);
94 }
95 }
96 }
97
98 for (SparseBitVector<128>::iterator I = backedge_source.begin();
99 I != backedge_source.end(); ++I)
100 computeBackedgeChain(mf, rev_preorder[*I]);
101
102 for (po_iterator<MachineBasicBlock*> POI = po_begin(&*mf.begin()),
103 POE = po_end(&*mf.begin()); POI != POE; ++POI)
104 if (!backedge_target.test(preorder[*POI]))
105 for (MachineBasicBlock::succ_iterator SI = (*POI)->succ_begin();
106 SI != (*POI)->succ_end(); ++SI)
Owen Andersonfdf72c62009-06-12 21:41:29 +0000107 if (!backedges.count(std::make_pair(*POI, *SI)) && tv.count(*SI)) {
108 SparseBitVector<128>& PBV = tv[*POI];
109 PBV = tv[*SI];
110 }
Owen Anderson6cbd8da2009-06-09 19:30:45 +0000111
112 for (po_iterator<MachineBasicBlock*> POI = po_begin(&*mf.begin()),
113 POE = po_end(&*mf.begin()); POI != POE; ++POI)
114 tv[*POI].set(preorder[*POI]);
115
116 return false;
117}
118
119bool LazyLiveness::vregLiveIntoMBB(unsigned vreg, MachineBasicBlock* MBB) {
120 MachineDominatorTree& MDT = getAnalysis<MachineDominatorTree>();
121
122 MachineBasicBlock* DefMBB = MRI->def_begin(vreg)->getParent();
123 unsigned def = preorder[DefMBB];
124 unsigned max_dom = 0;
125 for (df_iterator<MachineDomTreeNode*> DI = df_begin(MDT[DefMBB]);
126 DI != df_end(MDT[DefMBB]); ++DI)
127 if (preorder[DI->getBlock()] > max_dom) {
128 max_dom = preorder[(*DI)->getBlock()];
129 }
130
131 if (preorder[MBB] <= def || max_dom < preorder[MBB])
132 return false;
133
134 SparseBitVector<128>::iterator I = tv[MBB].begin();
135 while (I != tv[MBB].end() && *I <= def) ++I;
136 while (I != tv[MBB].end() && *I < max_dom) {
137 for (MachineRegisterInfo::use_iterator UI = MRI->use_begin(vreg);
138 UI != MachineRegisterInfo::use_end(); ++UI) {
139 MachineBasicBlock* UseMBB = UI->getParent();
140 if (rv[rev_preorder[*I]].test(preorder[UseMBB]))
141 return true;
142
143 unsigned t_dom = 0;
144 for (df_iterator<MachineDomTreeNode*> DI =
145 df_begin(MDT[rev_preorder[*I]]);
146 DI != df_end(MDT[rev_preorder[*I]]); ++DI)
147 if (preorder[DI->getBlock()] > t_dom) {
148 max_dom = preorder[(*DI)->getBlock()];
149 }
150 I = tv[MBB].begin();
151 while (I != tv[MBB].end() && *I < t_dom) ++I;
152 }
153 }
154
155 return false;
Sanjiv Guptacb597c92009-06-10 03:42:13 +0000156}
157