Move ensure_domtree out of Context and into DominatorTree.

This also moves the calls to it out of Context and into the passes that
actually need it, so that Context's functions don't have any logic of
their own.
This commit is contained in:
Dan Gohman
2017-09-12 13:47:17 -07:00
parent c7b1bb5f9e
commit 69f8174c03
4 changed files with 14 additions and 11 deletions

View File

@@ -237,6 +237,14 @@ impl DominatorTree {
!self.nodes.is_empty()
}
/// Conveneince function to call `compute` if `compute` hasn't been called
/// since the last `clear()`.
pub fn ensure(&mut self, func: &Function, cfg: &ControlFlowGraph) {
if !self.is_valid() {
self.compute(func, cfg)
}
}
/// Reset all internal data structures and compute a post-order for `cfg`.
///
/// This leaves `rpo_number == 1` for all reachable EBBs, 0 for unreachable ones.