diff --git a/hercules_ir/src/dom.rs b/hercules_ir/src/dom.rs index 9708e3b2e44aaae93a9704093d58c60aafa85203..f9046b434dc707224f8fbbddb6fec766eaf0b1b9 100644 --- a/hercules_ir/src/dom.rs +++ b/hercules_ir/src/dom.rs @@ -82,6 +82,9 @@ impl DomTree { * ancestor of the two nodes that is as far down the tree as possible. */ pub fn least_common_ancestor(&self, mut a: NodeID, mut b: NodeID) -> NodeID { + if a == self.root || b == self.root { + return self.root; + } while self.idom[&a].0 > self.idom[&b].0 { a = self.idom[&a].1; }