OSDN Git Service

[Dominators] Make slow walks shorter
authorJakub Kuderski <kubakuderski@gmail.com>
Tue, 31 Jul 2018 15:53:10 +0000 (15:53 +0000)
committerJakub Kuderski <kubakuderski@gmail.com>
Tue, 31 Jul 2018 15:53:10 +0000 (15:53 +0000)
commit8f61a2ac04195ff347df2bec9738ee5b982a48fc
treeaf79c7403a62fb580ae29f1f4c064983eca4aaff
parentd9904414c214ef94c480ce1cd76ebde0558403a0
[Dominators] Make slow walks shorter

Summary:
When DFS numbers are not yet calculated for a dominator tree, we have to walk it up to say whether one node dominates some other.

This patch makes the slow walks shorter by only walking until the level of the node we check against is reached. This is because a node cannot possibly dominate something higher in its tree.

When running opt with -O3, the patch results in:
* 25% fewer loop iterations for `opt` (fullLTO)
* 30% fewer loop iterations for sqlite

Reviewers: brzycki, asbirlea, chandlerc, NutshellySima, grosser

Reviewed By: NutshellySima

Subscribers: mehdi_amini, dexonsmith, llvm-commits

Differential Revision: https://reviews.llvm.org/D49955

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@338396 91177308-0d34-0410-b5e6-96231b3b80d8
include/llvm/Support/GenericDomTree.h